supervisord管理python进程,print内容不能输出到指定的日志文件
简介用supervisord管理python进程,python程序中的print内容不能输出到指定的日志文件
在用supervisord管理python进程时,如果python程序中有pring语句,想把输出的内容写入到supervisord的日志文件中,却发现没有写入,这个问题的解决方法有如下两种:
1、使用logging代替print语句
import logging
# 配置logging模块
logging.basicConfig(level=logging.DEBUG,
format='%(asctime)s - %(name)s - %(levelname)s - %(message)s',
filename='/path/to/your/logfile.log', # 与supervisord配置中指定的相同
filemode='a') # 'a'表示追加模式
# 使用logging来记录信息
logging.info('这是一条信息')
2、在supervisor配置python进程command命令添加-u参数
command=/usr/bin/python -u py-file.py
-u 参数用于强制 Python 程序的标准输出(stdout)不通过缓存直接打印到屏幕,与标准错误(stderr)的输出机制一致。默认情况下,stdout 有缓存机制,需要积累到一定量或遇到换行才会显示输出,而 stderr 是无缓存的,即时输出。
Flutter 提供了基本路由和命名路由两种方式,来管理页面间的跳转。其中,基本路由需要自己手动创建页面实例,通过 Navigator.push 完成页面跳转;而命名路由需要提前注册页面标识符和页面创建方法,通过 Navigator.pushNamed 传入标识符实现页面跳转。
记一次Mysql占用内存过高的优化过程
mkdir(make dirctories的简写),功能为创建目录,默认情况下,如果要创建的目录已经存在,则会提示此文件存在,而不会继续创建目录
php中的array_walk_recursive函数对数组中的每个成员递归地应用用户函数
用supervisord管理python进程,python程序中的print内容不能输出到指定的日志文件
快速生成表格
Electron页面跳转、浏览器打开链接和打开新窗口
在使用Git的过程中,不想每次都输入用户名和密码去拉取代码,所以就需要保存这些信息,那么既然有保存了,就必须有清除功能。
在Mac电脑中,如何对Git的用户名和密码进行修改呢?起初不懂Mac,所以整了很久,本文将记录如何对这个进行操作,以便后期使用。
Docker编译镜像出现:fetch http://dl-cdn.alpinelinux.org/alpine/v3.12/main/x86_64/APKINDEX.tar.gz
ERROR: http://dl-cdn.alpinelinux.org/alpine/v3.12/main: temporary error (try again later)
WARNING: Ignoring APKINDEX.2c4ac24e.tar.gz: No such file or directory问题