参考文章:
https://blog.csdn.net/weixin_34311210/article/details/113195996
https://www.jianshu.com/p/2d78ce6bc504
mkdir -p /data/elk/{elasticsearch/data,logstash} #新建目录
2、编写docker-compose.yml
可以在data/elk目录中
version: '3'
services:
elasticsearch:
image: elasticsearch:7.7.0 #镜像
container_name: elk_elasticsearch #定义容器名称
restart: always #开机启动,失败也会一直重启
environment:
- "cluster.name=elasticsearch" #设置集群名称为elasticsearch
- "discovery.type=single-node" #以单一节点模式启动
- "ES_JAVA_OPTS=-Xms512m -Xmx1024m" #设置使用jvm内存大小
volumes:
- /data/elk/elasticsearch/plugins:/usr/share/elasticsearch/plugins #插件文件挂载
- /data/elk/elasticsearch/data:/usr/share/elasticsearch/data #数据文件挂载
ports:
- 9200:9200
kibana:
image: kibana:7.7.0
container_name: elk_kibana
restart: always
depends_on:
- elasticsearch #kibana在elasticsearch启动之后再启动
environment:
- ELASTICSEARCH_URL=http://elasticsearch:9200 #设置访问elasticsearch的地址
ports:
- 5601:5601
logstash:
image: logstash:7.7.0
container_name: elk_logstash
restart: always
volumes:
- /data/elk/logstash/logstash-springboot.conf:/usr/share/logstash/pipeline/logstash.conf #挂载logstash的配置文件
depends_on:
- elasticsearch #kibana在elasticsearch启动之后再启动
links:
- elasticsearch:es #可以用es这个域名访问elasticsearch服务
ports:
- 4560:4560
3、新建Logstash配置文件
#授权目录
cd /data/elk
chmod 777 elasticsearch/data
#新建logstash/logstash-springboot.conf文件,新增以下内容
input {
tcp {
mode => "server"
host => "0.0.0.0"
port => 4560
codec => json_lines
}
}
output {
elasticsearch {
hosts => "es:9200"
index => "springboot-logstash-%{+YYYY.MM.dd}"
}
}
4、启动
#安装,运行ELK docker-compose up -d # 查看是否运行 docker ps5、访问
注:第一次启动可能很久才会成功,一开始一直在怀疑是不是因为启动不成功,结果等待一段时间之后就可以了。
- 查看elasticsearch是否访问成功
ip:9200
- 查看kibana是否启动成功
ip:5601
docker exec -it elk_kibana /bin/bash -c "echo "i18n.locale: zh-CN" >> /opt/kibana/config/kibana.yml" docker restart elk_kibanaspringboot整合elk 1、添加pom依赖
2、添加日志配置文件logback-spring.xml ,将该文件添加到resources下面, 修改下面的日志收集ip和端口net.logstash.logback logstash-logback-encoder 5.3
3、编写测试方法,并多次执行${APP_NAME} ${LOG_FILE_PATH}/${APP_NAME}-%d{yyyy-MM-dd}.log 30 ${FILE_LOG_PATTERN} 192.168.56.10:4560
@GetMapping("/test")
public R test(){
log.info("xxxxxxxxxxxxxx");
return R.success("test sucessful");
}
4、设置kibana索引
可以查到我们想要的结果的了
Couldn’t find any Elasticsearch data
解决方式:然后重启,多发送几条请求



