यहाँ और अन्य स्थानों से चीजों को एक साथ मिलाते हुए, यह वही है जो मैं 12.04 और सेंटोस 6 पर काम करता है
/etc/rsyslog.d/
उस फ़ाइल को अंत में .conf में बनाएँ और निम्नलिखित पाठ जोड़ें
local6.* /var/log/my-logfile
पुनः आरंभ rsyslog
, पुनः लोड करना नई लॉग फ़ाइलों के लिए काम नहीं करता था। हो सकता है कि यह केवल मौजूदा कॉन्फिडेंस फाइल को पुनः लोड करता हो?
sudo restart rsyslog
फिर आप इस परीक्षण कार्यक्रम का उपयोग यह सुनिश्चित करने के लिए कर सकते हैं कि यह वास्तव में काम करता है।
import logging, sys
from logging import config
LOGGING = {
'version': 1,
'disable_existing_loggers': False,
'formatters': {
'verbose': {
'format': '%(levelname)s %(module)s P%(process)d T%(thread)d %(message)s'
},
},
'handlers': {
'stdout': {
'class': 'logging.StreamHandler',
'stream': sys.stdout,
'formatter': 'verbose',
},
'sys-logger6': {
'class': 'logging.handlers.SysLogHandler',
'address': '/dev/log',
'facility': "local6",
'formatter': 'verbose',
},
},
'loggers': {
'my-logger': {
'handlers': ['sys-logger6','stdout'],
'level': logging.DEBUG,
'propagate': True,
},
}
}
config.dictConfig(LOGGING)
logger = logging.getLogger("my-logger")
logger.debug("Debug")
logger.info("Info")
logger.warn("Warn")
logger.error("Error")
logger.critical("Critical")