一次线上大日志打挂机器引发的思考

本文通过一次日志打满问题引发的一次思考,探讨了常用日志问题的解决套路,引申思考了2个技术问题,其一:如何大日志预防与监控;其二:老应用如何快速支持日志降级能力,并在最后提供了一点技术上的解法思路供参考。

前序

收到监控报警短信,一看是某线上机器磁盘被打满,已经快100%了,线上业务反馈页面请求无响应,出现舆情,作为开发的我,立马用运维工具,执行应用日志清理,过一段时间,继续看xflush磁盘监控,发现日志磁盘日志在15分钟内又将被打满,思考下今天并不是发布日,最近也没有任何线上变更,只能硬着头皮继续不断清理日志,同时定位问题。。。。

思考

这是最近一次我碰到的磁盘问题解决过程描述,大部分同学应该都会遵循“先止损再排查”的稳定性故障解决思路,即先采取措施快速进行止损,降低业务损失,或恢复/降级用户体验,再事后进行问题定位,将问题进行刨根问底,直至解决问题,线上恢复,最后进行复盘整治等等。

套路

每一个专业的开发,在不断的事件解决过程中,都形成一套成熟的、有效的、满足上述过程的脚手架,或者问题解决套路。比如我的“磁盘打满问题解决套路”:

  • 快速止损

  1. 执行日志清理,可选择的方式包括:1)登录跳板机,使用pgp进行批量定点清理,这种方式一般适用于脚本失效情况下使用,大促前最好先把脚本写好;2)直接登录机器,使用sudo rm -f xxx;注意:不能删除一个正在写入的日志,否则磁盘空间不能释放。4)针对日志代码写的有问题情况,比如直接写大量日志到了service_stdout.log(很久没有重启也有可能),不能强删,可以echo " " > service_stdout.log解决。
  2. 线上直接置换机器。好端端的为何要进行机器置换呢?这个主要针对日志打的过快,造成机器已经不堪重负,命令脚本都已经无法执行了,甚至机器都登录不了,这种情况只能进行置换解决。需要注意的是:置换完成后,要检查sls的监控机器配置,如果是写死的,要记得调整。
  1. 日志降级(若有)。使用开关方式开启日志降级,比如只打印error级别日志、完全不打印日志,在大促前要有预案。

  • 问题定位

登录机器,使用du -h --max-depth=0 ./* 2>&1 | sort -t ' ' -k1gr命令走一遍,把日志有问题的文件找到。找到日志文件后,要揪出这个小鬼来,有时候不太容易。比较常见的情形是某代码不断循环打印了超大日志,比如打印了导入的文件。。。。当碰到这种情况,去机器下看日志就像下面一样。

根本看不到日志是从哪里打印的。。。。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Sequelize 是 Node.js 环境下的 ORM 框架,提供了比较完善的数据库操作支持。Sequelize 的连接池是其关键特性之一,可以在多个请求之间共享数据库连接,提升数据库查询性能。但是,连接池的配置和使用也需要注意一些细节。 在线上环境中,我们曾经遇到过 Sequelize 连接池报错“ResourceRequest timed out”的问题。经过排查,我们发现该问题主要有以下几个原因: 1. 连接池配置不合理 Sequelize 的连接池有很多配置项,比如最大连接数、最小连接数、连接超时时间等。如果这些参数设置不合理,就容易导致连接池资源不足或者连接过期。因此,我们需要根据实际需求和服务器性能,进行合理的配置。 2. 数据库连接未释放 在使用 Sequelize 连接池时,我们需要手动释放连接资源。如果没有正确释放,就会导致连接池资源耗尽。通常我们可以使用 Promise.then 或 .finally 方法来释放连接资源。 3. 数据库连接泄露 数据库连接泄露是指在应用中创建的数据库连接未被正确关闭,从而导致连接池中的连接资源逐渐耗尽。通常我们可以使用 Sequelize 提供的 sequelize.close() 方法来关闭所有数据库连接,确保连接池资源得到释放。 4. 高并发压力过大 当应用面临高并发压力时,连接池中的连接资源可能会被快速消耗完毕。此时,我们需要调整连接池的配置或者增加服务器资源,来满足高并发请求的需求。 总之,Sequelize 连接池的问题排查需要综合考虑多个因素。在实际项目中,我们可以通过监控工具、日志分析等手段,及时发现和解决连接池问题,确保应用的稳定性和性能表现。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值