线上系统打日志你了解多少?

本文涉及的产品
日志服务 SLS,月写入数据量 50GB 1个月
简介: 以上文章讲述的是【Redis入门知识点】接下来我总结一下【线上系统打如何正确打日志】。
  • 日志有哪些?
  • 何时打日志?
  • 写法细节?
  • 级别应用?
  • 日志如何搭配使用?
  • 为什么这么搭配?


日志有哪些


  1. Slf4j:门面模式框架,有利用维护和各个类日志处理方式的统一
  2. Commons logging:门面模式框架
  3. log4j:是日志实现类方案,如果考虑log4j的话请入手logback!
  4. logbcak:是日志实现类方案,实时性更好。

门口模式框架:为系统提供一个统一的高层接口使子系统更容易使用

日志类实现方案:调用者不需要关注具体的实现,只需要关注接口即可


何时打日志


  1. 经常以功能为核心进行开发,你应该在提交代码前,可以确定通过日志可以看到整个流程
  2. 当你遇到问题的时候,只能通过debug功能来确定问题,你应该考虑打日志,良好的系统,是可以通过日志进行问题定为的。
  3. 当你碰到if…else 或者 switch这样的分支时,要在分支的首行打印日志,用来确定进入了哪个分支


写法细节


logger.debug("Processing trade with id:[{}] and symbol : [{}] ", id, symbol);

参考以上代码做一个简单介绍吧!

打日志的时候你们也知道肯定会有变量。有变量的情况下一定不要字符串拼接,因为垃圾回收机制有可能不会立即回收变量的内存。而打日志的时候有可能并发存在声明多个变量会占用多个内存。所以为了性能的优化,打日志的时候尽量避免使用字符串拼接!直接变量替换的方式!


级别应用


  1. error:影响到程序正常运行的时候使用,但是有一点需要注意的是,如果在try catch语句块中异常处理的情况不要打日志,应由最终处理方处理当前的异常问题!
  2. warn:不应该出现的问题,不影响程序的正常运行!这条级别的话主要针对程序的健壮性做的一个处理,可以通过此方式优化程序健壮性的细节问题。
  3. info:系统的运行信息以及外部接口的参数调用结果
  4. debug:通过debug方式可以监测所有自己想知道的信息,但是有一点细节的是线上系统不要开启debug操作,如果非要开启,必须要有一个关闭的按钮也就是说自定义的按钮。(线上系统运行量大有可能日志文件极其庞大导致影响性能问题)
  5. trance:特别详细的记录系统信息,业务类系统建议不要使用这个trance。除非特定的业务需求需要这一级别!


如何搭配使用


log4j与logback都是同一个作者,logback是log4j的升级版

slf4j与logback搭配

log4j与commons logging搭配


为什么这么搭配


我们暂时不做全部的介绍,挑选一组介绍一下它的优点吧!应用场景中常用的就是slf4j和logback组合

特点

  1. slf4j限制少,应用范围广,编译的时候绑定本地的log库比commos logging通用性更好。
  2. logback拥有更好的性能。举一个例子吧。比如判断是否记录一条日志语句。
  3. logback 3 纳秒,log4j 30 纳秒。创建记录器 logback 13 毫秒,log4j23毫秒。获取已存在的记录器 logback94纳秒,log4j2234纳秒  (核心)
  4. commons logging开销更高
  5. logback的文档全部免费,log4j的文档部分免费!


相关实践学习
【涂鸦即艺术】基于云应用开发平台CAP部署AI实时生图绘板
【涂鸦即艺术】基于云应用开发平台CAP部署AI实时生图绘板
相关文章
|
25天前
|
Prometheus 监控 Cloud Native
基于docker搭建监控系统&日志收集
Prometheus 是一款由 SoundCloud 开发的开源监控报警系统及时序数据库(TSDB),支持多维数据模型和灵活查询语言,适用于大规模集群监控。它通过 HTTP 拉取数据,支持服务发现、多种图表展示(如 Grafana),并可结合 Loki 实现日志聚合。本文介绍其架构、部署及与 Docker 集成的监控方案。
234 122
基于docker搭建监控系统&日志收集
WGLOG日志管理系统是怎么收集日志的
WGLOG通过部署Agent客户端采集日志,Agent持续收集指定日志文件并上报Server,Server负责展示与分析。Agent与Server需保持相同版本。官网下载地址:www.wgstart.com
|
4月前
|
监控 API 开发工具
HarmonyOS Next的HiLog日志系统完全指南:从入门到精通
本文深入解析HarmonyOS Next的HiLog日志系统,涵盖日志级别、核心API、隐私保护与高级回调功能,助你从入门到精通掌握这一重要开发工具。
213 1
|
14天前
|
Ubuntu
在Ubuntu系统上设置syslog日志轮替与大小限制
请注意,在修改任何系统级别配置之前,请务必备份相应得原始档案并理解每项变更可能带来得影响。
63 2
|
3月前
|
存储
WGLOG日志管理系统可以采集网络设备的日志吗
WGLOG日志审计系统提供开放接口,支持外部获取日志内容后发送至该接口,实现日志的存储与分析。详情请访问:https://www.wgstart.com/wglog/docs9.html
|
8月前
|
存储 前端开发 数据可视化
Grafana Loki,轻量级日志系统
本文介绍了基于Grafana、Loki和Alloy构建的轻量级日志系统。Loki是一个由Grafana Labs开发的日志聚合系统,具备高可用性和多租户支持,专注于日志而非指标,通过标签索引而非内容索引实现高效存储。Alloy则是用于收集和转发日志至Loki的强大工具。文章详细描述了系统的架构、组件及其工作流程,并提供了快速搭建指南,包括准备步骤、部署命令及验证方法。此外,还展示了如何使用Grafana查看日志,以及一些基本的LogQL查询示例。最后,作者探讨了Loki架构的独特之处,提出了“巨型单体模块化”的概念,即一个应用既可单体部署也可分布式部署,整体协同实现全部功能。
2558 70
Grafana Loki,轻量级日志系统
|
7月前
|
存储 消息中间件 缓存
MiniMax GenAI 可观测性分析 :基于阿里云 SelectDB 构建 PB 级别日志系统
基于阿里云SelectDB,MiniMax构建了覆盖国内及海外业务的日志可观测中台,总体数据规模超过数PB,日均新增日志写入量达数百TB。系统在P95分位查询场景下的响应时间小于3秒,峰值时刻实现了超过10GB/s的读写吞吐。通过存算分离、高压缩比算法和单副本热缓存等技术手段,MiniMax在优化性能的同时显著降低了建设成本,计算资源用量降低40%,热数据存储用量降低50%,为未来业务的高速发展和技术演进奠定了坚实基础。
273 1
MiniMax GenAI 可观测性分析 :基于阿里云 SelectDB 构建 PB 级别日志系统
|
7月前
|
存储 JSON Go
PHP 日志系统的最佳搭档:一个 Go 写的远程日志收集服务
为了不再 SSH 上去翻日志,我写了个 Go 小脚本,用来接收远程日志。PHP 负责记录日志,Go 负责存储和展示,按天存储、支持 API 访问、可远程管理,终于能第一时间知道项目炸了。
114 10
|
存储 监控 安全
5款 Syslog集中系统日志常用工具对比推荐
集中管理Syslog有助于持续监控网络中的恶意活动,确保日志的搜索和分析更为便捷。常用工具包括Rsyslog、Syslog-ng、Logstash和Fluentd,它们各有优劣。Rsyslog通过多种协议确保日志传输的安全性;Syslog-ng支持高效收集和转发日志;Logstash能解析多源日志并索引;Fluentd将日志转换为JSON格式。卓豪EventLog Analyzer则提供一体化的日志管理,支持日志分析、报表生成、用户行为分析及实时告警,是全面的日志管理解决方案。
|
9月前
|
存储 安全 Java
Spring Boot 3 集成Spring AOP实现系统日志记录
本文介绍了如何在Spring Boot 3中集成Spring AOP实现系统日志记录功能。通过定义`SysLog`注解和配置相应的AOP切面,可以在方法执行前后自动记录日志信息,包括操作的开始时间、结束时间、请求参数、返回结果、异常信息等,并将这些信息保存到数据库中。此外,还使用了`ThreadLocal`变量来存储每个线程独立的日志数据,确保线程安全。文中还展示了项目实战中的部分代码片段,以及基于Spring Boot 3 + Vue 3构建的快速开发框架的简介与内置功能列表。此框架结合了当前主流技术栈,提供了用户管理、权限控制、接口文档自动生成等多项实用特性。
567 8