Python 日志问题

2017-10-20 11:30:19 +08:00
 p2pCoder

一个应用启动多个服务,如何使多个服务的日志输出到一个日志文件中?怎样配置,使用 logging 模块能实现吗?

2314 次点击
所在节点    Python
7 条回复
wcsjtu
2017-10-20 12:06:21 +08:00
Cooky
2017-10-20 15:36:11 +08:00
用外部日志吧,比如 syslog
focusheart
2017-10-20 16:01:17 +08:00
楼上说的都对,logging 模块的还提供了一个例子: https://docs.python.org/2/howto/logging-cookbook.html#network-logging 很清楚。
我们这边类似的情况,多个服务写日志,各写各的文件,然后用 logstash 收集到一起集中存储处理,也很方便的
lolizeppelin
2017-10-21 10:52:21 +08:00
可以 追加写的方式写入指定文件即可

追加写是原子性的
lolizeppelin
2017-10-21 10:57:54 +08:00
限 Linux 下
openstack 对多进程写日志没任何特殊处理

为此我专门查过 你可以参考

http://www.lolizeppelin.com/2017/08/05/linux-append-write/

我 blog 手机浏览器显示有问题
oneApple
2017-10-23 14:44:04 +08:00
python 的 logging 模块是线程安全的,写是追加模式可以当成是原子操作在多进程模式下也没问题。
有问题的是在多进程切割日志,多进程下会有问题。
参考下下面的,扩展了 logging 使 logging 进程安全。
https://pypi.python.org/pypi/ConcurrentLogHandler/0.9.1
chenqh
2017-10-24 13:19:26 +08:00
我是用 celery 做的,专门起一个 log 的 celery 进程来写日志

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/399193

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX