ELK是三个开源软件的缩写,分别表示:Elasticsearch , Logstash, Kibana , 它们都是开源软件。新增了一个FileBeat,它是一个轻量级的日志收集处理工具(Agent),Filebeat占用资源少,适合于在各个服务器上搜集日志后传输给Logstash,官方也推荐此工具。
下载elasticsearch(6.8.7版本)
elastic下载地址:https://www.elastic.co/cn/downloads/past-releases/elasticsearch-6-8-7
遇到的问题:
# 经历将该目录放在当前的用户目录下,否则可能会报权限拒绝问题
tar -zxvf elasticsearch-6.8.7.tar.gz
ls
cd elstaicsearch-6.8.7/bin/
./elstaicsearch
后台启动可以 ./elasticsearch -d
如果curl没有安装,需要使用apt安装一下curl
curl 127.0.0.1:9200
vi elasticsearch.yml
需要修改的配置内容,cluster.name(集群名称),path.data(数据存放位置),path.logs(日志存放位置),network.host(集群ip),http.port(集群端口)
cluster.name: my-application
path.data: /home/grid/elasticsearch-6.8.7/data
path.logs: /home/grid/elasticsearch-6.8.7/logs
network.host: 192.168.171.101
http.port: 9200
./elstaicsearch
若出现错误,无法启动:请自行百度原因
启动成功,访问网址测试连接http://127.0.0.1:9200/
elasticsearch-head-master
是es的集群管理工具,可以用来数据的浏览和查询。
head是开源软件,托管在github,需要在github下载,地址:git://github.com/mobz/elasticsearch-head.git。
head的运行需要用到grunt,而grunt需要npm,所以需要安装nodejs。
es5.0之后,head已经不做为插件方在plugins目录,直接拷贝在本地就行。
安装教程: https://baijiahao.baidu.com/s?id=1714641263988021723&wfr=spider&for=pc
下载地址:https://github.com/mobz/elasticsearch-head
下载zip后,解压到文件夹中。
npm install -g grunt-cli
来到head目录下安装head的依赖包,
cd elasticsearch-head-master/
npm install -g cnpm --registry=https://registry.npm.taobao.org
或者
npm install
grunt -version
修改Gruntfile.js配置文件vim Gruntfile.js
在connect–>server–>options下面添加:hostname:’*’,允许所有IP可以访问hostname:'*',
修改_site目录下的 app.js 中 head 的默认连接地址
cd _site
vi app.js
“http://localhost:9200"改成"http://192.168.171.101:9200”
配置es允许跨域访问,es目录下的config的elasticsearch.yml
cd config
vi elasticsearch.yml
在文件末尾追加
http.cors.enabled: true
http.cors.allow-origin: "*"
启动head
grunt server
http://127.0.0.1:9100/
tar -zxvf kibana-6.8.7-linux-x86_64.tar.gz
cd kibana-6.8.7-linux-x86_64/config/
vi kibana.yml
修改为以下内容:
server.port: 5601
server.host: "127.0.0.1"
elasticsearch.hosts: ["http://127.0.0.1:9200"]
启动kibana之前需要先启动elasticsearch
./kibana
浏览器访问:http://127.0.0.1:5601
下载网址:https://github.com/medcl/elasticsearch-analysis-ik
将解压后的ik文件夹移动到es的plugins目录下
tar -zxvf logstash-6.8.7.tar.gz
./logstash -e 'input { stdin { } } output { stdout {} }'
./logstash -f ../demo/xxx.conf
启动 elasticsearch
elasticsearch目录下(master)./bin/elasticsearch
启动 elasticsearch-head-master
elasticsearch-head-master目录下 grunt server
启动 kibana
kibana目录下./bin/kibana
启动logstash(选择性是否启动)
logstash目录下./bin/logstash -e 'input {stdin {} } output{ stdout {}}'
至此ELK都安装成功