gunicorn部署的flask,多进程日志问题,

使用flask时候,我们经常使用logging来写日志。

但是gunicorn是多进程启动的,logging进程不安全!

日志经常会缺,只有一部分日志。

就算整合到gunicorn的日志中

if __name__ != '__main__':
    gunicorn_logger = logging.getLogger('gunicorn.error')
    app.logger.handlers = gunicorn_logger.handlers
    app.logger.setLevel(gunicorn_logger.level)

还是只有部分日志。

 

问题苦恼了我很久,今天无意间发现了一个包concurrent_log

https://github.com/huanghyw/concurrent_log

可以解决此类问题,具体使用方法在git上很明白,我就不赘述了。

源码也简单看了看,很简洁,简单的思想就是用了2个锁。

一个锁是静态变量,基于GIL就可以保证python的线程安全。

另一个是进程锁,用的是PortaLock文件锁,实现了nt和posix,所以大部分部署gunicorn的地方都能用。

concurrent_log就可以分别保证线程和进程安全,就git作者的测试来说(500k行log),性能还有所提高。

 

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值