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 是无缓存的,即时输出。
Towxml 是一个让小程序(微信/QQ)可以解析Markdown、HTML的解析库。能够使小程序完美解析Markdown内容。
tcpdum命令是一个截获网络数据包的包分析工具。tcpdump可以将网络中传递的数据包的头完全截获下来提供分析。他支持针对网络层、协议、主机、端口等过滤,并支持与、或、非逻辑语句协助过滤的有效信息。 如果系统没有tcpdump命令,则可以使用下面的命令来安装: yum -y install tcpdump
默认情况下 pip 使用的是国外的镜像,在下载的时候速度非常慢,本文我们介绍使用国内源对pip进行加速。
最近搭建一套监控系统,本文主要记录Prometheus的安装配置
最近在对项目进行压测的过程中发现我们代码服务器都是集群部署的,但是既然是集群那么我们发布代码的时候该如何做到同时发布的效果,不可能每个服务器都是git pull下吧!所以这里想到了rsync,文件同步服务器。本文就主要记录如何搭建rsync服务,并且如何做到同步代码。
快速生成表格
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问题