首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

如何打印日志

如何打印日志 日志打印对研发来说,是很有必要的, 如何打印日志,让日志能反映出处理流程,让日志能反映出问题所在,这个很重要,不好的日志,会加大研发排查问题的难度,过多的日志也会对研发造成干扰,如何打印日志...日志存在的问题 安全问题 将用户的敏感信息打印在了日志 日志级别不合理 warning日志较为泛滥,且少有人关注 部分阻塞业务流程的错误,未正确使用error日志 错误日志重复打印 同一个错误在不同的位置重复打印...无效日志较为泛滥 一个正常处理的请求触发上千条info日志 日志缺乏关键信息 日志缺乏关键的信息,进而导致难以定位问题 好的日志 快速定位线上问题 日志是定位线上问题的重要途径 杜绝安全问题 随意的日志打印可能会造成用户信息泄漏...当前服务warn日志泛滥的情况较为普遍,且很少有人关注warn日志,在大家的日常日志打印应更加谨慎的使用warn日志。...] base response illegal") logger.Errorf(ctx, "[AggregateTimeline] checkBaseResp failed") 问题:同一错误在不同日志重复打印

40320

如何打印日志

1.选择恰当的日志级别 error warn info debug 2.日志打印出参入参数 方便甩锅 3.选择合适的日志格式 时间戳 线程名字 日志级别等 4.if-else ,switch 等分支语句都建议打印日志...,方便排查 5.对一些比较低的日志级别进行判断,使用log.isXXXX()方法判断 如果日志不被记录,但是日志内的字符拼接,对象的toString方法也会执行,浪费性能 6.不建议直接使用log4j...,logback等日志系统,建议使用slf4j框架,方便统一处理 7.建议使用参数占位符{},而不是+拼接,简洁且提升性能 8.建议使用异步日志,能有效提升IO性能 9.不要使用e.printStackTrace...()打印错误信息,因为太多信息,且是堆栈信息,会使得内存溢出 10.异常不要只打一半,要完成输出 11.禁止在线上开启debug 会把磁盘打满 12.不要记录了异常,又抛出异常 13.避免重复打印日志...,浪费磁盘空间 14.日志文件分离,不同级别日志存放在不同文件 15.核心功能模块,建议打印详细的日志

8210
您找到你想要的搜索结果了吗?
是的
没有找到

日志到底该如何打印

今天,我们来看第一个问题: 日志到底该如何打印? 咋一看,这个问题很简单,其实不然,我随手写几个,您看看。...,比如,用户ID,关键参数,同时,如果是捕获异常里面打印日志,必须把原来的e打印出来,否则,排查日志想死的心都有了。...比如,我最近就遇到一个同学,他把远程调用用一个try catch包着,并在catch捕获了异常,打印日志"远程调用错误xxx",呵呵,有一次请求失败,非要说远程调用失败,对方出错了,对方说我没收到请求呀...源码已经明确写了如果最后一个参数是Exception类型,就不会参与字符串格式化,会单独拿出来打印,同时,可以打印出堆栈信息。看源码去吧,我在地铁上,就不截图了。 你以为本篇文章就结束了吗?...有没有更优雅的日志打印方式呢? 我认为,最好的日志是以解决问题的方式打印日志。 怎么理解呢? 我们以服务注册为例,当注册中心地址不通的时候,我们能不能这样打印呢?

87940

如何安全地打印日志

如何打印日志?这不是很简单,直接使用android.util.Log这个类不就行了?...安全的概念本来就是相对的,如果破解你程序的代价远远大于破解得到的价值,那么就可以认为程序是“安全的”;这里就分析一下,为了提高程序的安全性,在打印日志的时候应该注意什么。...首先看看绝大部分公司以及开发者的做法: 日志开关+日志类 为了在release版本里面没有日志输出,一个最简单的想法是:把所有打印日志的语句放在一个if(DEBUG)的语句里面;在日常开发的时候,DEBUG...让release版本里面不包含日志代码 从上面的分析我们得到一个结论:如果需要程序是“日志安全的”,那么release版本里面不应该存在输出日志的代码。 如何做到这一点呢?...我们可以做一个工具,开发的时候,正常打印日志;一旦需要发布版本,把所有打印日志的语句代码,全部删除掉。代码很简单,用一些正则表达式就可以做到。

1.3K30

如何关掉Parsed mapper file日志打印

你是如何找到的?...首先我们搜索Parsed mapper file(因为这个日志大概率是硬编码存在于源码之中的,除非是做了日志本地化,会在配置文件里) 这里排除掉一个纯依赖模块,一个注解模块,挨个到com包搜索,在最后一个...extension模块搜到了 进到源码,果然是它打印的,那我们将这个类的日志级别设为INFO应该就搞定了,但是没有生效 我们打个断点,看看什么情况,等断点停到日志这里,我们按下F7 点这个亮着的debug...可以看到这里逻辑: 如果是debug等级,就进行日志打印 我们继续按下F7深入,发现问题了。。...此处使用的StdOutImpl是没有进行日志等级管理的 那找到问题了,我们可以换一个日志框架打印 将原来的 log-impl: org.apache.ibatis.logging.stdout.StdOutImpl

2.5K41

【Log日志打印mybatissql日志并存放到指定文件

打印mybatissql日志并存放到指定文件 logback-spring.xml (如果是logbackx.xml 动态路径会失效) root> configuration> 几个关键点 文件名需要为logback-spring.xml; 动态日志路径才会生效...; 属性文件配置 log.path=xxx; 【Log日志】logback.xml动态配置属性值(包括接入的第三方配置) levle 需要是DEBUG等级; 因为sql日志是DEBUG等级的;...# 这个配置会将执行的sql打印出来,这个可以存放在文件 StdOutImpl的是只能打印到控制台 log-impl: org.apache.ibatis.logging.slf4j.Slf4jImpl...我之前就是一直配置的是 log-impl: org.apache.ibatis.logging.stdout.StdOutImpl ;导致文件只能出现在控制台;却没有打印到文件; 参数值的默认值设置

1.8K30

聊聊日志打印日志审计

二.日志切面 ​ springboot默认提供的日志打印功能无法打印函数的入参与出参信息。现在如果有个bug在生产环境可以复现,测试环境怎么也复现不了,本地代码又无法连接生产环境进行调试。...生产环境一般一般情况下指挥打印info级别的日志。这个时候就头疼了,无法定位解决问题。 ​ 因此线上环境能有一个功能帮我们打印函数的详细的入参或者出参这个功能是很重要的。...这里可以选择在在xml配置日志每天保存一份归档,保存至多7天或者30天【根据业务场景自己配置】。...拦截到输入的参数并进行解析,存储到kafka。logstash拉取kafka上的日志信息存储至es。到这一步日志数据链路已经打通了。...那对于日志数据如何进行解析有两种方式,一种是利用kibana上面默认提供的一些报表功能,另外一种就是需要集成在当前应用系统内的报表数据展示,做二次业务应用开发。 ​

2.3K10

Ijkplayer打印FFMpeg日志

背景 在打印Ijkplayer播放日志的过程,在ijkplayer中日志可以正常输出。...但是涉及到FFMpeg的日志,则无法输出 原因 由于FFMPeg的libavutil/log.c中使用的是fprintf,所以输出到了标准输出,而Android有自己的一套输出日志的端口。...ffp_global_init通过av_log_set_callback注册好回调函数,然后即可通过该函数将ffmpeg库的输出重定向到ijkplayer 这步完成后,发现还是打印不出来日志...最后,一怒之下,把ijksdl_log.h日志打印都换成了android jni的日志打印,就打印出来了 #ifdef EXTRA_LOG_PRINT #define VLOG(level, TAG...((void)__android_log_print(level, TAG, __VA_ARGS__)) #endif 最后在修改完ffmpeg日志后,需要进入/ijkplayer/android

2.4K30

Python 打印彩色日志

我相信每一个开发者都有打印日志的习惯,好看的日志可以加快调试的速度,可以更好的了解程序中发生的事情。本文分享一个技巧,可以让 Python 在控制台输出彩色的日志。...安装 coloredlogs pip install coloredlogs 使用 首先,和正常打印日志一样,我们创建一个 logger logging.basicConfig() logger =...white'), funcName=dict(color='white'), lineno=dict(color='white'), ) ) 接下来就和正常使用日志一样了...,配置一个流处理器,让日志显示在控制台: ch = logging.StreamHandler(stream=sys.stdout) ch.setFormatter(fmt=coloredFormatter...) logger.addHandler(hdlr=ch) logger.setLevel(level=logging.DEBUG) 接下来就可以输入日志信息了: logger.debug(msg="this

1.5K30
领券