? ELK是elasticsearch、Logstashh和Kibana三個系統(tǒng)的首字母組合。當我們部署集群服務(wù)器的時候,日志文件就會散落在多臺服務(wù)器上。查看日志信息就需要到各個服務(wù)器上去取和查看,我們把這些日志文件歸集到一個地方統(tǒng)一管理。
讓客戶滿意是我們工作的目標,不斷超越客戶的期望值來自于我們對這個行業(yè)的熱愛。我們立志把好的技術(shù)通過有效、簡單的方式提供給客戶,將通過不懈努力成為客戶在信息化領(lǐng)域值得信任、有價值的長期合作伙伴,公司提供的服務(wù)項目有:主機域名、虛擬空間、營銷軟件、網(wǎng)站建設(shè)、大化網(wǎng)站維護、網(wǎng)站推廣。Elasticsearch是個開源分布式搜索引擎,它的特點有:分布式,零配置,自動發(fā)現(xiàn),索引自動分片,索引副本機制,restful風格接口,多數(shù)據(jù)源,自動搜索負載等。
Logstash是一個完全開源的工具,他可以對你的日志進行收集、過濾,并將其存儲供以后使用(如,搜索)。
Kibana也是一個開源和免費的工具,Kibana可以為 Logstash 和 ElasticSearch 提供的日志分析友好的 Web 界面,可以幫助您匯總、分析和搜索重要數(shù)據(jù)日志。
名稱 | 角色 | 地址 |
---|---|---|
centos 7-1 | node1+kibana | 192.168.142.221 |
centos 7-2 | node1 | 192.168.142.132 |
centos 7-3 | Logstash+web | 192.168.142.136 |
這里我將WEB端與日志文件系統(tǒng)安裝在了,各位可以根據(jù)個人情況,全部獨立出去。(虛擬機開太多了,電腦頂不住?。?/p>
添加域名解析。方便后期使用
[root@node1 ~]# vim /etc/hosts
//添加
192.168.142.221 node1
192.168.142.132 node2
檢查JAVA版本(沒有安裝的可以使用yum install java進行安裝)
[root@node1 ~]# java -version
openjdk version "1.8.0_131"
OpenJDK Runtime Environment (build 1.8.0_131-b12)
OpenJDK 64-Bit Server VM (build 25.131-b12, mixed mode)
部署elasticsearch服務(wù)(端口號:9200)
//部署elasticsearch服務(wù)
[root@node1 ~]# rpm -ivh elasticsearch-5.5.0.rpm
//加載系統(tǒng)服務(wù)
[root@node1 ~]# systemctl daemon-reload
[root@node1 ~]# systemctl enable elasticsearch.service
修改ES配置文件
[root@node1 ~]# vim /etc/elasticsearch/elasticssearch.yml
//以下幾行取消注釋
17/ cluster.name: my-elk-eluster //集群名字(所有節(jié)點必須一樣)
23/ node.name: node1 //節(jié)點名字(每個節(jié)點不同)
33/ path.data:/data/elk_data //數(shù)據(jù)存放路徑
37/ path.logs:/var/log/elasticsearch/ //日志存放路徑
43/ bootstrap.memorylock: false //不在啟動的時候鎖定內(nèi)存
55/ network.host: 0.0.0.0 //提供服務(wù)綁定的IP地址,0. 0. 0. 0代表所有地址
59/ http.port: 9200 //偵聽端口為9200
68/ discovery.zen.ping.unicast.hosts: ["node1", "node2"] //集群發(fā)現(xiàn)通過單播實現(xiàn)
建立數(shù)據(jù)文件存放目錄,并開啟服務(wù)
[root@node1 ~]# mkdir -p /data/elk_data
[root@node1 ~]# chown -R elasticsearch:elasticsearch /data/elk_data //修改屬主屬組
[root@node1 ~]# systemctl start elasticsearch.service
[root@node1 ~]# netstat -atnp | grep 9200
驗證服務(wù)是否開啟
使用宿主機瀏覽器訪問:http://192.168.142.132:9200
,即可獲取到相應(yīng)的節(jié)點信息,如下:
{
"name" : "node1",
"cluster_name" : "my-elk-cluster",
"cluster_uuid" : "mi3-z72CRqS-ofc4NhjXdQ",
"version" : {
"number" : "5.5.0",
"build_hash" : "260387d",
"build_date" : "2017-06-30T23:16:05.735Z",
"build_snapshot" : false,
"lucene_version" : "6.6.0"
},
"tagline" : "You Know, for Search"
}
解壓并編譯安裝
[root@node1 ~]# yum install gcc gcc-c++ make -y
//安裝node組件包
[root@node1 ~]# tar zxf node-v8.2.1.tar.gz -C /opt
//在node目錄中
[root@node1 ~]# ./configure
[root@node1 ~]# make //異常費時,大概耗時20min
[root@node1 ~]# make install
安裝phantomjs前端框架
[root@node1 ~]# tar jxf phantomjs-2.1.1-linux-x86_64.tar.bz2 -C /usr/local/src
[root@node1 ~]# cp /usr/local/src/phantomjs-2.1.1-linux-x86_64/bin/phantomjs /usr/local/bin
安裝elasticsearch-head數(shù)據(jù)可視化工具
[root@node1 ~]# tar zxf elasticsearch-head.tar.gz -C /usr/local/src
//在elasticsearch-head目錄中
[root@node1 ~]# npm install //使用npm工具進行安裝(node組件自帶)
修改elasticsearch-head配置文件
[root@node1 ~]# vim /etc/elasticsearch/elasticsearch.yml
//末行添加
http.cors.enabled: true //開啟跨域訪問支持
http.cors.allow-origin: "*" //跨域訪問允許的域名地址,*號為全網(wǎng)段
開啟elasticsearch-head工具
[root@node1 ~]# systemctl restart elasticsearch //重啟ES服務(wù)
[root@node1 ~]# cd /usr/local/src/elasticsearch-head/
[root@node1 elasticsearch-head]# npm run start & //保持后臺運行
安裝WEB服務(wù)
任意web服務(wù)均可(Apache、nginx、Tomcat均可),不再進行詳細解釋。
這里使用的Apache服務(wù)
安裝logstash系統(tǒng)
[root@apache ~]# rpm -ivh logstash-5.5.1.rpm
[root@apache ~]# systemctl start logstash.service //啟動logstash
[root@apache ~]# systemctl enable logstash.service //設(shè)置為開機自啟
[root@apache ~]# ln -s /usr/share/logstash/bin/logstash /usr/local/bin //建立軟鏈接方便使用
設(shè)置logstash與elasticsearch進行對接
? logstash配置文件由三部分組成:input(入)、output(出)、filter
[root@apache log]# chmod o+r messages?
[root@apache log]# ll /var/log/messages?
-rw----r--. 1 root root 483737 Dec 18 17:54 /var/log/messages
[root@apache log]# vim /etc/logstash/conf.d/system.conf
//手動添加
input {
? ? ? ? file{
? ? ? ? ? path => "/var/log/messages" //收集日志的路徑
? ? ? ? ? type => "system" //便簽名稱
? ? ? ? ? start_position => "beginning" //收集方式,"beginning"從頭開始
? ? ? ? ? }
? ? ? ? }
output {
? ? ? ? elasticsearch {
? ? ? ? ? hosts => ["192.168.142.136:9200"] //es服務(wù)地址
? ? ? ? ? index => "system-%{+YYYY.MM.dd}" //索引名稱
? ? ? ? ? }
? ? ? ? }
[root@apache log]# systemctl restart logstash.service ? ?//重啟服務(wù)
結(jié)果驗證
字段描述解釋:
-f 通過這個選項可以指定logstash的配置文件,根據(jù)配置文件配置logstash
-e后面跟著字符串該字符串可以被當做logstash的配置 (如果是””,則默認使用stdin做為輸入、stdout作為輸出)
-t 測試配置文件是否正確,然后退出
1、輸入、輸出均為標準模式
[root@apache ~]# logstash -e 'input { stdin{} },output { stdout{} }'
##輸入直接輸出在屏幕上
輸入:www.baidu.com
輸出:apache www.baidu.com
2、使用codec解碼器,使用rubydebug顯示詳細輸出
[root@apache ~]# logstash -e 'input { stdin{} },output { stdout { codec=>rubydebug } }'
##會按照編碼格式進行輸出
輸入:www.baidu.com
輸出:
{
"@timestamp"=> 2018-10-12T02: 15:39.136Z, #時間
"@version=> "1", #版本
"host" => "apache", #使用Apache服務(wù)
"message" => "www.baidu. com" #訪問網(wǎng)頁
}
3、將信息寫入elasticsearch中
[root@apache ~]# logstash -e 'input { stdin{} },output {elasticsearch { hosts=>["192.168.142.221:9200"] } }'
##會在elasticsearch中生成索引
輸入:www.baidu.com
輸出:在elasticsearch中生成lostash-2019.12.17
在node1中進行安裝
[root@node1 ~]# cd /abc/elk/
[root@node1 elk]# rpm -ivh kibana-5.5.1-x86_64.rpm?
[root@node1 kibana]# cp kibana.yml kibana.yml.bak
修改Kibana配置文件
[root@node1 kibana]# vim kibana.yml
//按照下圖進行修改
2/ server.port: 5601 ? ? ? ? ? ? ? ? //打開端口
7/ server.host: "0.0.0.0" ? ? ? ? ? ? ? ? ? ?//監(jiān)聽的地址
21/ elasticsearch.url: "http://192.168.142.136:9200" ? ? ?//與elasticsearch建立聯(lián)系
30/ kibana.index: ".kibana" ? ? ? ? ? ? ? ? ?//在elasticsearch中添加.kibana索引
啟動Kibana
[root@node1 kibana]# systemctl start kibana.service ? ? ? ? //開啟kibana服務(wù)
[root@node1 kibana]# systemctl enable kibana.service ? ? ? //設(shè)為開機自啟動
web服務(wù)與elasticsearch進行對接后,使用kibana進行可視化
[root@apache log]# cd /etc/logstash/conf.d/
//修改配置文件(空的自行添加)
[root@apache conf.d]# vim apache_log.conf
input {
? ? ? ? file{
? ? ? ? ? path => "/etc/httpd/logs/access_log" //針對于Apache的access日志
? ? ? ? ? type => "access"
? ? ? ? ? start_position => "beginning"
? ? ? ? ? }
? ? ? ? file{
? ? ? ? ? path => "/etc/httpd/logs/error_log" //針對于Apache的error日志
? ? ? ? ? type => "error"
? ? ? ? ? start_position => "beginning"
? ? ? ? ? }
? ? ? ? }
output {
? ? ? ? if [type] == "access" {
? ? ? ? elasticsearch {
? ? ? ? ? hosts => ["192.168.142.136:9200"] //elasticsearch地址
? ? ? ? ? index => "apache_access-%{+YYYY.MM.dd}"
? ? ? ? ? }
? ? ? ? }
? ? ? ? if [type] == "error" {
? ? ? ? elasticsearch {
? ? ? ? ? hosts => ["192.168.142.136:9200"] //elasticsearch地址
? ? ? ? ? index => "apache_error-%{+YYYY.MM.dd}"
? ? ? ? ? }
? ? ? ? }
? ? ? ? }
[root@apache conf.d]# /usr/share/logstash/bin/logstash -f apache_log.conf? //僅對于該日志文件進行生效
在可視化界面進行配置
在瀏覽器輸入http://192.168.142.136:5601/
首次登錄時創(chuàng)建一個索引(對接系統(tǒng)日志文件):
輸入:access-*
點擊create按鈕進行創(chuàng)建
點擊Discover按鈕,會發(fā)現(xiàn)access-*信息
故障集:
19:43:59.210 [LogStash::Runner] FATAL logstash.runner - Logstash could not be started because there is already another instance using the configured data directory.
If you wish to run multiple instances, you must change the "path.data" setting.
解決方案
//查看logstash配置文件
vim /etc/logstash/logstash.yml
//找到path.data路徑
/var/lib/logstash/
//刪除緩存
rm -rf .lock
//帶路徑重啟
logstash -f /etc/logstash/conf.d/nginx_log.conf --path.data=/var/lib/logstash
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)建站www.cdcxhl.com,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機、免備案服務(wù)器”等云主機租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。