当前位置: 首页 > news >正文

logback 自定义log字段(MDC)推送到logstash(spring boot + logback+ logstash)

直接上代码:

1.创建FIlter,往 MDC 里面追加内容

@WebFilter
@Component
public class LogBackFilter implements Filter {@Overridepublic void init(FilterConfig filterConfig) throws ServletException {}@Overridepublic void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)throws IOException, ServletException {// LOGSTASH 日志附加信息追加addMDC(request,response,chain);}@Overridepublic void destroy() {rmMDC();}private void addMDC(ServletRequest request, ServletResponse response, FilterChain chain){HttpServletRequest httpServletRequest = ((HttpServletRequest) request);String uuid = UUID.randomUUID().toString();MDC.put(LogConstant.REQUEST_ID, uuid);String remoteIp = request.getRemoteAddr();MDC.put(LogConstant.REQUEST_RM_IP, remoteIp);String remoteHost = request.getRemoteHost();MDC.put(LogConstant.REQUEST_RM_HOST, remoteHost);String uri =  httpServletRequest.getRequestURI();MDC.put(LogConstant.REQUEST_URI, uri);AuthUser authUser = UserContext.getCurrentUser();if(authUser!=null){MDC.put(LogConstant.REQUEST_USER_ID, authUser.getId());}}private void rmMDC(){MDC.remove(LogConstant.REQUEST_ID);MDC.remove(LogConstant.REQUEST_RM_IP);MDC.remove(LogConstant.REQUEST_RM_HOST);MDC.remove(LogConstant.REQUEST_URI);MDC.remove(LogConstant.REQUEST_USER_ID);}
}

2.logback配置:

includeMdcKeyName 标签 追加 mdc中的key

 <!--输出到elk的LOGSTASH--><appender name="LOGSTASH" class="net.logstash.logback.appender.LogstashTcpSocketAppender"><!-- 配置elk日志收集 配饰的是 LOGSTASH 的地址--><destination>${LOGSTASH_SERVER}</destination><encoder charset="UTF-8" class="net.logstash.logback.encoder.LogstashEncoder"><providers><timestamp><timeZone>UTC</timeZone></timestamp></providers><includeCallerData>true</includeCallerData><includeMdc>true</includeMdc><!-- MDC字段 --><includeMdcKeyName>X-Request-Id</includeMdcKeyName><includeMdcKeyName>X-Request-Uri</includeMdcKeyName><includeMdcKeyName>X-Request-UserId</includeMdcKeyName><includeMdcKeyName>X-Request-Rm-Ip</includeMdcKeyName><includeMdcKeyName>X-Request-Rm-Host</includeMdcKeyName><!--自定义字段 区分项目--><customFields>{"appName":"${APP_NAME}"}</customFields></encoder></appender>

http://www.lryc.cn/news/96071.html

相关文章:

  • 1253. 重构 2 行二进制矩阵
  • 安全—01day
  • 【Git】Please commit your changes or stash them before you merge的解决方法
  • 网卡收发包系统结构收发包流程,tcp/ip协议,socket套接字缓冲区,滑动窗口,mtu/mss
  • VUE之axios使用,跨域问题,拦截器添加Token
  • 阿里云函数计算签名认证(iOS实现细节备注)
  • 成都爱尔蔡裕:泡在“糖”里的脆弱血管,暴露在眼睛深处
  • 神经网络小记-过拟合与欠拟合
  • 外贸行业企业邮箱选择:安全好用的邮箱服务
  • flutter开发实战-RepaintBoundary实现Widget截图功能
  • vue中路由懒加载的写法
  • 【Spring MVC】小文件上传的多种方法
  • UE5.1移动端PreintegratedSkinBxDF解析
  • WebSocket心跳机制(笔记大全)
  • Spring Boot日志:SLF4J和Logback
  • [C++] C++入门第二篇 -- 引用 -- 内联函数inline -- auto+for
  • Latex | 将MATLAB图并导入Latex中的方法
  • JSON格式Python,Java,PHP等封装根据关键词搜索获取淘宝商品列表数据API
  • MySQL MHA高可用配置及故障切换
  • PHP8知识详解:PHP8开发工具VS Code的安装
  • Sui Move与标准Move的有哪些区别和根本性创新
  • 构建自己的ChatGPT:从零开始构建个性化语言模型
  • 【react】react18的学习(十二)– 底层原理(二)之 迭代器 iterator
  • 一遍过JavaSE基础知识
  • 【云原生】Kubernetes之ConfigMap
  • 8.python设计模式【组合模式】
  • tkinter制作任意图形窗口
  • 视频监控综合管理平台EasyCVR多分屏默认播放协议的配置优化
  • 2023杭电多校第三场 1012.Noblesse Code
  • ubuntu qt 环境变量配置