ELK 項(xiàng)目監(jiān)控平臺(tái)部署+使用詳解之部署(二)

因?yàn)椴煌陌姹咎?hào)之間可能會(huì)有一定的差異揖闸,所以我這里為了保證大家能夠下一步下一步的順利執(zhí)行谓娃。先確認(rèn)一下版本號(hào)和部署的環(huán)境豺谈。

elasticsearch 5.5.1

logstash 5.5.1

kibana? 5.5.1

這三個(gè)服務(wù)器統(tǒng)一部署在一臺(tái)服務(wù)器泣栈。業(yè)務(wù)量大的可以考慮將elasticsearch分離開來做集群册烈。

為了方便以下都以es來代表elasticsearc。

es + kibana 為了不熟方便選擇使用docker

在linux 下安裝docker 后執(zhí)行:

docker pull docker.elastic.co/elasticsearch/elasticsearch:5.5.1

docker pull docker.elastic.co/kibana/kibana:5.5.1

logstash 使用源碼安裝:

wget https://artifacts.elastic.co/downloads/logstash/logstash-5.6.1.tar.gz

cp logstash-5.6.1.tar.gz /usr/share/logstash.tar.gz

tar -zxvf? logstash.tar.gz

cd? logstash

./bin/logstash -e 'input { stdin {} } output { stdout {} }'

測(cè)試安裝是否成功


現(xiàn)在嘗試啟動(dòng)es和kibana:

elasticsearch啟動(dòng):

docker?run?-p?9200:9200?-e?"http.host=0.0.0.0"?-e?"transport.host=127.0.0.1" --name?my-elastic?-d?docker.elastic.co/elasticsearch/elasticsearch:5.5.1

kibana啟動(dòng):

docker?run?-p?5601:5601?-e?"ELASTICSEARCH_URL=http://localhost:9200"?--name?my-kibana --network?host?-d?docker.elastic.co/kibana/kibana:5.5.1

這時(shí)如果一切執(zhí)行的順利的話應(yīng)該就可以訪問kibana了

訪問地址為你部署的http://ip:5601 訪問

當(dāng)然這個(gè)時(shí)候是沒有數(shù)據(jù)的骂倘,現(xiàn)在在項(xiàng)目服務(wù)器上部署采集數(shù)據(jù)的filebeat 和metricbeat

1.在項(xiàng)目服務(wù)器中下載這兩個(gè)文件:

wget https://artifacts.elastic.co/downloads/beats/filebeat/filebeat-5.6.1-linux-x86_64.tar.gz

wget https://artifacts.elastic.co/downloads/beats/metricbeat/metricbeat-5.6.1-linux-x86_64.tar.gz

2.解壓

tar -zxvf *.tar.gz

3.配置filebeat 以ngxin 日志為例

cd filebeat-5.6.1-linux-x86_64

vim nginx.yml

將以下文件內(nèi)容復(fù)制進(jìn)去

filebeat.prospectors:
- input_type: log
? paths:
??? - /var/log/nginx/access.log
? document_type: nginx_access
? #后續(xù)對(duì)日志進(jìn)行分組統(tǒng)計(jì)
? fields:
????? level: debug
? #Filebeat從文件尾開始監(jiān)控文件新增內(nèi)容眼滤,把新增的每一行文件作為一個(gè)事件依次發(fā)送
? tail_files: true

shipper:
??? tags: ['nginx-access']

# 項(xiàng)目名稱和項(xiàng)目服務(wù)的ip地址可自定義
tags: ["myserver", "101.110.56.78"]

output.logstash:
?? # logstash服務(wù)器的ip地址
?? hosts: ["11.142.42.77:5044"]



shipper 是logstash接收日志時(shí)做條件控制使用

output.logstash 配置logstash服務(wù)器的ip地址+端口號(hào)

啟動(dòng)filebeat

./filebeat -e -c ./nginx.yml -d "publish"

配置logstash

進(jìn)入logstash安裝目錄

vim logstash.yml

input {

beats {

port => 5044

}

}

filter {

? ? ? ? if [type]? == "nginx_access"? {

? ? ? ? ? ruby {

? ? ? ? ? ? ? ? init => "@kname = ['remote_addr','remote_user','time_local','request','status','body_bytes_sent','http_referer','http_user_agent','http_x_forwarded_for']"

? ? ? ? ? ? ? ? code => "event.append(LogStash::Event.new(Hash[@kname.zip(event.get('message').split(' | '))]))"

? ? ? ? ? }

? ? ? ? ? if [request] {

? ? ? ? ? ? ?? ruby {

? ? ? ? ? ? ? ? ? ? init => "@kname = ['method','uri','verb']"

? ? ? ? ? ? ? ? ? ? code => "event.append(LogStash::Event.new(Hash[@kname.zip(event.get('request').split(' '))]))"

? ? ? ? ? }

? ? ? ? ? if [uri] {

? ? ? ? ? ? ? ? ruby {

? ? ? ? ? ? ? ? ? ? init => "@kname = ['url_path','url_args']"

? ? ? ? ? ? ? ? ? ? code => "event.append(LogStash::Event.new(Hash[@kname.zip(event.get('request').split('?'))]))"

? ? ? ? ? ? ? ? }

? ? ? ? ? ? ? ? kv {

? ? ? ? ? ? ? ? ? ? prefix => "url_"

? ? ? ? ? ? ? ? ? ? source => "url_args"

? ? ? ? ? ? ? ? ? ? field_split => "& "

? ? ? ? ? ? ? ? ? ? remove_field => [ "url_args","uri","request" ]

? ? ? ? ? ? ? ? }

? ? ? ? ? }

? ? ? ? ? }

? ? ? ? ? mutate {

? ? ? ? ? ? ? ? convert => [ "body_bytes_sent" , "integer" ]

? ? ? ? ? }

? ? ? ? ? date {

? ? ? ? ? ? ? ? match => [ "time_local", "dd/MMM/yyyy:hh:mm:ss Z" ]

? ? ? ? ? ? ? ? locale => "en"

? ? ? ? ? }

? ? ? ? }

}

output {

? ? ? if [type] == "nginx_access" {

? ? ? ? stdout {

? ? ? ? ? ? codec => rubydebug

? ? ? ? }

? ? ? ? elasticsearch {

? ? ? ? ? ? ? ? ? ? ? hosts => ["localhost:9200"]

? ? ? ? ? ? ? ? ? ? ? index => "nginx_access_%{+YYYY.MM.dd}"

? ? ? ? ? ? ? ? ? ? ? user => "elastic"

? ? ? ? ? ? ? ? ? ? ? password => "changeme"

? ? ? ? }

? ? ? ? if [status] != "200"{

? ? ? ? ? ? ? ? exec {

? ? ? ? ? ? ? ? ? ? command? =>? "sh /root/sh/alarm.sh %{tags[0]}發(fā)現(xiàn)了BUG,請(qǐng)盡快處理 服務(wù)器IP:%{tags[1]} request:%{request} 訪問狀態(tài):%{status} 時(shí)間:%{time_local}"

? ? ? ? }

? ? ? ? }

? ? ? }

? ? ? else {

? ? ? ? stdout {

? ? ? ? ? ? codec => rubydebug

? ? ? ? }

? ? ? ? elasticsearch {

? ? ? ? ? ? ? hosts => ["localhost:9200"]

? ? ? ? ? ? ? index => "metricbeat-%{+YYYY.MM.dd}"

? ? ? ? ? ? ? user => "elastic"

? ? ? ? ? ? ? password => "changeme"

? ? ? ? }

? ? ? }

}



需要注意的是:

1.nginx.conf中需要配置一下nginx的格式便于logstash 做解析

log_format main "$remote_addr | $remote_user | $time_local | $request | $status | $body_bytes_sent | $http_referer | $http_user_agent | $http_x_forwarded_for";

access_log /var/log/nginx/access.log main;

2.需要安裝logstash插件exec 才能執(zhí)行腳本

3.腳本alarm.sh的內(nèi)容為:


啟動(dòng)logstash:

./logstash -f ./logstash.yml

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市历涝,隨后出現(xiàn)的幾起案子诅需,更是在濱河造成了極大的恐慌漾唉,老刑警劉巖,帶你破解...
    沈念sama閱讀 212,657評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件堰塌,死亡現(xiàn)場(chǎng)離奇詭異赵刑,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)场刑,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,662評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門般此,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人牵现,你說我怎么就攤上這事铐懊。” “怎么了瞎疼?”我有些...
    開封第一講書人閱讀 158,143評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵科乎,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我贼急,道長(zhǎng)茅茂,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,732評(píng)論 1 284
  • 正文 為了忘掉前任太抓,我火速辦了婚禮空闲,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘腻异。我一直安慰自己进副,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,837評(píng)論 6 386
  • 文/花漫 我一把揭開白布悔常。 她就那樣靜靜地躺著影斑,像睡著了一般。 火紅的嫁衣襯著肌膚如雪机打。 梳的紋絲不亂的頭發(fā)上矫户,一...
    開封第一講書人閱讀 50,036評(píng)論 1 291
  • 那天,我揣著相機(jī)與錄音残邀,去河邊找鬼皆辽。 笑死,一個(gè)胖子當(dāng)著我的面吹牛芥挣,可吹牛的內(nèi)容都是我干的驱闷。 我是一名探鬼主播,決...
    沈念sama閱讀 39,126評(píng)論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼空免,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼空另!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起蹋砚,我...
    開封第一講書人閱讀 37,868評(píng)論 0 268
  • 序言:老撾萬榮一對(duì)情侶失蹤扼菠,失蹤者是張志新(化名)和其女友劉穎摄杂,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體循榆,經(jīng)...
    沈念sama閱讀 44,315評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡析恢,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,641評(píng)論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了秧饮。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片映挂。...
    茶點(diǎn)故事閱讀 38,773評(píng)論 1 341
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖浦楣,靈堂內(nèi)的尸體忽然破棺而出袖肥,到底是詐尸還是另有隱情咪辱,我是刑警寧澤振劳,帶...
    沈念sama閱讀 34,470評(píng)論 4 333
  • 正文 年R本政府宣布,位于F島的核電站油狂,受9級(jí)特大地震影響历恐,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜专筷,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 40,126評(píng)論 3 317
  • 文/蒙蒙 一弱贼、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧磷蛹,春花似錦吮旅、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,859評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至槽驶,卻和暖如春责嚷,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背掂铐。 一陣腳步聲響...
    開封第一講書人閱讀 32,095評(píng)論 1 267
  • 我被黑心中介騙來泰國打工罕拂, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人全陨。 一個(gè)月前我還...
    沈念sama閱讀 46,584評(píng)論 2 362
  • 正文 我出身青樓爆班,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國和親辱姨。 傳聞我的和親對(duì)象是個(gè)殘疾皇子柿菩,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,676評(píng)論 2 351

推薦閱讀更多精彩內(nèi)容