我的基于twisted的客户端以环路方式发送UDP报文。因此,我使用类DatagramProtocol。这是来源:
#!/usr/bin/python
# -*- coding: utf-8 -*-
from twisted.application.service import Service
from twisted.internet import reactor
from twisted.internet.task import LoopingCall
from twisted.internet.protocol import DatagramProtocol
from twisted.python import log
import logging
class HeartbeatClient(Service):
def __init__(self, host, port, data, beat_period):
self.ip = host
self.port = int(port)
self.data = data
self.beat = int(beat_period)
def startService(self):
self._call = LoopingCall(self._heartbeat)
self._call.start(self.beat)
def stopService(self):
self._call.stop()
def _heartbeat(self):
protocol = DatagramProtocol()
protocol.noisy = False
port = reactor.listenUDP(0, protocol)
port.write(self.data, (self.ip, self.port))
port.stopListening()
现在,当我使用twistd运行这个客户端时,我永久地从Twisted类获得日志消息,即从类DatagramProtocol:
2011-09-11 18:39:25+0200 [-] (Port 55681 Closed)
2011-09-11 18:39:30+0200 [-] twisted.internet.protocol.DatagramProtocol starting on 44903
2011-09-11 18:39:30+0200 [-] (Port 44903 Closed)
2011-09-11 18:39:35+0200 [-] twisted.internet.protocol.DatagramProtocol starting on 50044
2011-09-11 18:39:35+0200 [-] (Port 50044 Closed)
2011-09-11 18:39:40+0200 [-] twisted.internet.protocol.DatagramProtocol starting on 37450
由于这些日志消息污染了我"自己的"日志,我想知道我是否可以禁用这些日志消息。正如您所看到的,我已经通过调用protocol.noisy = False
减少了日志的数量,但是我仍然得到其他Log消息。命令g = protocol.ClientFactory().noisy = False
也没有帮助。
是否有可能禁用所有Twisted-internal类的日志记录,以通用的方式-为所有模块?也许通过使用一些扭曲的日志配置?
Twisted的日志记录非常幼稚。然而,没有理由必须如此,因为twisted.python.log
非常有特色,并且能够进行您(和其他人)感兴趣的那种选择性报告。
日志事件只是一个包含任意键和值的字典。默认观察者知道带有'message'
键的字典。也许正因为如此,Twisted本身发出的大多数日志消息除了提供与该键相关联的人类可读的字符串外,不会尝试做任何事情(而且,许多发出的消息是在当前 Twisted日志系统之前添加的,因此更老、更原始的系统作为消费者也是如此)。
不久以前,这个问题困扰了一些人,他们被提示提交一个票证,并开始解决这个问题的UDP部分。问题已基本解决,但仍有几件事要做。
尝试的解决方案是记录传递相同信息的结构化消息,但没有消息,因此不会被默认观察者记录。这避免了默认情况下出现在日志中的消息,但允许对这些事件特别感兴趣的观察者观察它们并按需要处理它们。
这张票已经被搁置了一段时间了。对于某些人来说,捡起补丁并完成最后一点可能很容易。