springboot2+logback+logstash 日志收集

适用人群

  • 运维人员
  • 熟练操作docker和对elk有基本认识的人(本文不涉及elk部署)
  • 由于本文涉及到的知识众多,且并没有加以描述,所以小白慎看

操作步骤

  1. 部署logstash
  2. 在springboot项目中引入net.logstash.logback:logstash-logback-encoder包
  3. 配置logback-spring.xml

部署logstash

笔者使用的是docker-compose部署logstash(docker同理,读者可自行转换)
先创建三个文件

  • logstash.conf
  • logstash.yml
  • docker-compose.yml

配置如下:

# logstash.conf
input {
    tcp {
    # 笔者启用了多个logstash,所以此处没有使用logstash的默认端口,读者也可按喜好配置
	port => 5045
	codec => "json_lines"
    }
}

output {
    elasticsearch {
    # hosts => "ip:端口"
	hosts => "elk:9200"
	# appname在logback中配置,前缀"logstash-logback"读者也可自定配置
	index => "logstash-logback-%{[appname]}-%{+YYYY.MM.dd}"
    }
}
# logstash.yml
http.host: "0.0.0.0"
xpack.monitoring.elasticsearch.hosts: [ "http://elasticsearch:9200" ]
# 前两行为logstash默认配置,笔者没有改动,仅加了第三行,禁用x-pack的监视功能
xpack.monitoring.enabled: false
# docker-compose.yml
version: '3'

services:
  logstash-logback:
    image: docker.elastic.co/logstash/logstash:7.2.0
    volumes:
      - /root/software/docker/elk/logstash/logstash.yml:/usr/share/logstash/config/logstash.yml
      - /root/software/docker/elk/logstash/logstash.conf:/usr/share/logstash/pipeline/logstash.conf
    restart: always
    container_name: logstash-logback
    ports:
    # 此处的端口号与logstash.conf配置的相同,格式 -> 主机端口:容器端口
      - "5045:5045"
    networks:
    # 由于笔者的elasticsearch也是启动在docker中,为保证可以直接用容器名称访问,则将elasticsearch和logstash放置在一个网桥中
      - elk
networks:
# 笔者先network创建了一个名为elk的网桥,在此处配置,使用外部网桥
  elk:
    external: true

随后启动容器即可

net.logstash.logback:logstash-logback-encoder包

笔者使用的是gradle,使用maven者同理

compile('net.logstash.logback:logstash-logback-encoder:6.1')

配置logback-spring.xml

在resources文件夹下创建logback-spring.xml文件

# logback-spring.xml
<?xml version="1.0" encoding="UTF-8"?>
<configuration><!--debug="true" scan="true" scanPeriod="30 seconds"-->
    <springProperty scope="context" name="logPath" source="log.path"/>

    <appender name="LOGSTASH" class="net.logstash.logback.appender.LogstashTcpSocketAppender">
   		<!-- 此处配置logstash的ip和端口 -->
        <destination>ip:5045</destination>
        <encoder charset="UTF-8" class="net.logstash.logback.encoder.LogstashEncoder">
        	<!-- 此处配置logstash的索引名称,在logstash.conf中配置了使用appname作为索引名称的一部分 -->
            <customFields>{"appname":"项目名称"}</customFields>
        </encoder>
    </appender>

    <root level="info">
        <appender-ref ref="LOGSTASH"/>
    </root>
</configuration>

启动项目,则可在kibana中看到索引

为了在Windows安装ADB工具,你可以按照以下步骤进行操作: 1. 首先,下载ADB工具包并解压缩到你自定义的安装目录。你可以选择将其解压缩到任何你喜欢的位置。 2. 打开运行窗口,可以通过按下Win+R键来快速打开。在运行窗口中输入"sysdm.cpl"并按下回车键。 3. 在系统属性窗口中,选择"高级"选项卡,然后点击"环境变量"按钮。 4. 在环境变量窗口中,选择"系统变量"部分,并找到名为"Path"的变量。点击"编辑"按钮。 5. 在编辑环境变量窗口中,点击"新建"按钮,并将ADB工具的安装路径添加到新建的路径中。确保路径正确无误后,点击"确定"按钮。 6. 返回到桌面,打开命令提示符窗口。你可以通过按下Win+R键,然后输入"cmd"并按下回车键来快速打开命令提示符窗口。 7. 在命令提示符窗口中,输入"adb version"命令来验证ADB工具是否成功安装。如果显示版本信息,则表示安装成功。 这样,你就成功在Windows安装ADB工具。你可以使用ADB工具来执行各种操作,如枚举设备、进入/退出ADB终端、文件传输、运行命令、查看系统日志等。具体的操作方法可以参考ADB工具的官方文档或其他相关教程。\[1\]\[2\]\[3\] #### 引用[.reference_title] - *1* [windows环境安装adb驱动](https://blog.youkuaiyun.com/zx54633089/article/details/128533343)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [Windows安装使用ADB简单易懂教程](https://blog.youkuaiyun.com/m0_37777700/article/details/129836351)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值