架构
服务产生的日志,通过logstash收集到es中,并通过kibana展示出来,这里不再介绍三者的作用
部署es+Kibana
这三个的版本尽量要保持一致,我使用的是7.13.4
通过docker部署es
命令:
bash
docker run --name elasticsearch -d -e ES_JAVA_OPTS="-Xms1024m -Xmx1024m" /
-e "discovery.type=single-node" -p 9200:9200 -p 9300:9300 docker镜像
参数解释
-e ES_JAVA_OPTS="-Xms1024m -Xmx1024m" 限制内存大小,es比较吃内存,这里建议可以设置大一点
-e "discovery.type=single-node" 以单节点启动
-p 将端口映射出来
elasticsearch的9200端口是供外部访问使用;9300端口是供内部访问使用集群间通讯
docker部署kibana
bash
docker run -d --name kibana -e ELASTICSEARCH_HOSTS=es服务ip:端口 / -p 5601:5601 docker镜像
启动之后,如果需要可以配置一下这里面的用户,具体可以自己查询
部署logstash
这个是部署在你项目服务器上的,用于采集项目运行时产生的日志
bash
wget https://artifacts.elastic.co/downloads/logstash/logstash-对应版本-linux-x86_64.tar.gz
解压到你想在的目录下
tar -zxvf 压缩包
解压完进入logstash/config目录配置日志的输入源和输出位置
vim 你想要的名字.conf
conf
#添加配置文件
input {
# 从文件读取日志信息 输送到控制台
file {
# 日志文件目录
path => "/home/shuxue/service/shuxueservice/web_app.log"
codec => "json" ## 以JSON格式读取日志
type => "elasticsearch"
# 从头开始输出
start_position => "beginning"
}
}
# filter {
#
# }
output {
# 标准输出
# stdout {}
# 输出进行格式化,如果不想在控制台输出,就把下面这一行注掉
# stdout { codec => rubydebug }
elasticsearch {
hosts => ["es服务地址:9200"]
index => "es索引"
}
}
然后启动logstash,今日logstash/bin目录
bash
./logstash -f ../config/上面的文件名.conf
这个时候访问kibana就能看到创建出来的索引了
但是这个时候你在ctrl+c的时候会退出,这个时候可以使用systemd让他常驻后台就可以了。