社区首页 >问答首页 >Python-守护进程:继续日志记录

Python-守护进程:继续日志记录
EN

Stack Overflow用户
提问于 2013-02-03 08:43:10
回答 2查看 4.2K关注 0票数 3

我有一个脚本,它将一些数据记录到磁盘上:

logging.basicConfig(filename='davis-debug.log',level=logging.DEBUG) logging.basicConfig(filename='davis-error.log',level=logging.ERROR) logging.basicConfig(filename='davis-error.log',level=logging.WARNING) logging.basicConfig(filename='davis-error.log',level=logging.CRITICAL)

当我像这样使用时,日志记录就停止了。

代码语言:javascript
代码运行次数:0
复制
try:
  with daemon.DaemonContext():
  station = VantageProStation()
  station.run()

except KeyboardInterrupt:
  logging.critical('Stopping user aborted with CTRL+C')
pass

我尝试过file_preserve,但是logging.basicConfig不返回流。

另外,我不能使用files_preserve传递几个流。

我当然希望我的日志记录继续进行,我尝试将日志定义放在我的类init中,这也没有帮助。

EN

回答 2

Stack Overflow用户

发布于 2013-02-03 09:07:49

在守护进程中配置记录器怎么样?这对我来说很管用:

代码语言:javascript
代码运行次数:0
复制
#!/usr/bin/env python

import daemon
import logging
import logging.handlers
from time import sleep
from datetime import datetime

def time_logging_daemon():
    logger = logging.getLogger('time_logging_daemon')
    logger.addHandler(logging.handlers.SysLogHandler(address='/dev/log'))
    logger.setLevel(logging.INFO)
    while True:
        logger.info(datetime.now())
        sleep(1)

with daemon.DaemonContext():
    time_logging_daemon()
票数 6
EN

Stack Overflow用户

发布于 2016-12-22 13:52:19

守护进程上下文将所有文件处理程序关闭为“行为良好的守护进程”,但files_preserve中指定的守护进程除外。你的方向是对的。

有一种方法可以从logging获取文件处理程序,但我建议您显式地创建文件记录器。

代码语言:javascript
代码运行次数:0
复制
#!/usr/bin/env python

import daemon
import logging
import logging.handlers
from time import sleep
from datetime import datetime

logging.basicConfig()

file_logger = logging.FileHandler("/tmp/aaa.log", "w")

logger = logging.getLogger()
logger.addHandler(file_logger)
logger.setLevel(logging.INFO)

with daemon.DaemonContext(files_preserve=[file_logger.stream.fileno()]):
    while True:
        logger.info(datetime.now())
        sleep(1)
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/14674733

复制
相关文章
无请求不响应?
前几天我们学习了HttpServletResponse,今天就让我们了解一下HttpServletRequest。和HttpServletResponse一样,在service方法中的request的类型是ServletRequest,而doGet/doPost方法的request的类型是HttpServletRequest,HttpServletRequest是ServletRequest的子接口,功能和方法更加强大。
阿Q说代码
2021/05/13
1.2K0
无请求不响应?
Nslookup命令_nslookup命令反解ip
nslookup用于查询DNS的记录,查询域名解析是否正常,在网络故障时用来诊断网络问题
全栈程序员站长
2022/11/02
8200
windows nslookup命令详解_nslookup unknown
今天是特别傻逼,既然问了一个很愚蠢的问题,登录后台需要相关的ip,但是我只有域名,这么太突然来,我既然不知道用nslookup命令,好吧,先记录起来,希望下次不要犯这样的傻逼错误
全栈程序员站长
2022/11/02
1.1K0
windows nslookup命令详解_nslookup unknown
Linux 命令 | nslookup
它可以通过输入一个域名来获取相应的IP地址,并提供其他相关信息,如域名服务器、主机名等。
小林C语言
2023/09/02
4010
Linux 命令 | nslookup
RocketMQ-NameServer原理
在系统中肯定是做命名服务,服务治理方面的工作,功能应该是和zookeeper差不多 早期的版本中,使用的是 Zookeeper 做为配置中心,改名 RocketMQ 后使用了自己开发的 NameServer。 是一个几乎无状态的节点,可集群部署,节点之间无任何信息同步
潇洒
2023/10/20
3030
RocketMQ-NameServer原理
nslookup指定服务器是什么命令,nslookup命令详解_nslookup命令指定dns[通俗易懂]
nslookup命令作用是用于查询dns解析域名记录,一般我们使用都是通过此命令可以检测DNS是否正常或者有时候我们把域名A记录更改的ip址,通常更改A记录需要一定的时间才生效,我们可以通过此命令解析域名的A记录是否生效。
全栈程序员站长
2022/11/19
6.5K0
nslookup指定服务器是什么命令,nslookup命令详解_nslookup命令指定dns[通俗易懂]
NameServer模块划分
在进行NameServer的模块划分讨论前,先整理一下NameServer的功能:
林一
2018/07/24
4410
NameServer模块划分
深入剖析RocketMQ源码-NameServer
通过上图可以看到,RocketMQ的核心组件主要包括4个,分别是NameServer、Broker、Producer和Consumer,下面我们先依次简单说明下这四个核心组件:
冬夜先生
2021/10/12
5460
nslookup命令解析域名_nslookup是什么意思
非权威应答:Non-authoritative answer,除非实际存储DNS Server中获得域名解析回答的,都称为非权威应答。也就是从缓存中获取域名解析结果。
全栈程序员站长
2022/11/19
5.5K0
nslookup命令解析域名_nslookup是什么意思
nslookup命令的使用方法_nslookup测试命令
nslookup(name server lookup)是和dig类似的命令,都是用来查询域名信息的指令,但是在功能上没有dig强大,这个指令在Windows系统是自带的,要想在Linux中使用,就需要下载和dig相同的工具包
全栈程序员站长
2022/11/02
1.2K0
Linux DNS之nslookup命令
---- 概述 在我文章中有一篇专门讲解DNS如何工作的,今天我们采用linux下nslookup工具来查询DNS。nslookup全称是”query Internet name server interactively”,主要是是用来查询DNS。 使用 在使用nslookup之前,先确保已经安装了它。nslookup属于bind-utils包下一个命令,bind-utils软件包中很多DNS工具,比如:dig和nslookup等。通过如下命令来检查: [root@lv-centos ~]# rpm -q
吕海峰
2018/04/03
10.1K0
linux常用命令介绍-nslookup
nslookup(Name Server Lookup)是一种用于查询DNS(Domain Name System,域名系统)信息的命令行工具。它可以查询DNS服务器,获取域名对应的IP地址、反向解析、查询MX记录等信息。nslookup通常用于网络故障排查和网络配置调试。
玖叁叁
2023/04/11
2.3K0
DNS域传送漏洞(一)
DNS(Domain Name System,域名管理系统)是万维网WWW的重要基础。它建立在一个分布式数据库基础之上,在这个数据库里,保存了IP地址和域名的相互映射关系。
HACK学习
2019/08/07
1.9K0
js keypress 对输入中文不响应
动态添加js类对象的属性,需要[]来操作,js 不响应需要绑定 input 与 propertychange事件
Dylan Liu
2019/07/01
5.2K0
nslookup命令的使用方法_怎么退出nslookup命令
nslookup是一款查询DNS (Internet domain name server)的程序。用来网络管理工具,帮助诊断和解决DNS相关的问题。除此之外,也有其他DNS工具,如dig命令和host命令。
全栈程序员站长
2022/11/02
1.6K0
nslookup命令的使用方法_怎么退出nslookup命令
linux nslookup命令安装,在CentOS中安装nslookup命令
域名查询工具nslookup并不是Win系统的专利,Linux系统中也可以使用,不过要安装,默认没有。
全栈程序员站长
2022/11/02
5.8K0
RocketMQ NameServer深入剖析
本文将深入剖析rocketmq为什么选择自己开发NameServer,而不是选择类似于ZK这样的开源组件。同时对rocketmq的路由注册、路由发现、路由剔除进行剖析。并通过结合核心源码,对笔者的观点进行验证。同时对不同类型消息的重试机制,以及客户端选择nameserver的策略进行深入讲解。
田守枝
2019/11/24
4.5K0
采坑指南——域名解析问题排查过程
前几天,在ucloud上搭建的k8s集群(搭建教程后续会发出)。今天发现域名解析不了。
我的小碗汤
2019/07/30
4.6K2
RocketMQ-启动Nameserver
//ubuntu 下加 sudo 反而报错。最简单的命令: nohup sh mqnamesrv &
潇洒
2023/10/20
4050
每天学一个 Linux 命令(69):nslookup
nslookup(name server lookup)命令用于查询域名 DNS 信息的工具。nslookup 有两种工作模式,即“交互模式”和“非交互模式”。
民工哥
2021/03/30
8190
每天学一个 Linux 命令(69):nslookup

相似问题

regex交替选择错误匹配

23

regex:交替字符/顺序数字

32

regex模式选择交替匹配。

12

MySQL中的逻辑交替顺序

10

匹配交替字符的Regex表达式

23
添加站长 进交流群

领取专属 10元无门槛券

AI混元助手 在线答疑

扫码加入开发者社群
关注 腾讯云开发者公众号

洞察 腾讯核心技术

剖析业界实践案例

扫码关注腾讯云开发者公众号
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文