如何在Python日志配置文件中指定相对路径?

os8fio9y  于 2023-04-10  发布在  Python
关注(0)|答案(2)|浏览(230)

我有以下文件来配置日志记录:

[loggers]
keys=root

[handlers]
keys = root

[formatters]
keys = generic

# Loggers
[logger_root]
level = DEBUG
handlers = root

# Handlers
[handler_root]
class = handlers.RotatingFileHandler
args = ("test.log", "maxBytes=1*1024*1024", "backupCount=10")
level = NOTSET
formatter = generic

# Formatters
[formatter_generic]
format = %(asctime)s,%(msecs)03d %(levelname)-5.5s [%(name)s] %(message)s
datefmt = %Y-%m-%d %H:%M:%S

在开发中,这很好用,但是当我部署应用程序时,test.log试图写入到一个我没有必要权限的路径中。
所以我的问题是,我怎么做才能在这个配置文件中指定一个相对路径。

llmtgqce

llmtgqce1#

Mark是对的,配置文件中的路径是相对于调用logging.config.fileConfig时当前的目录的。这取决于部署方法的细节。
您可能需要指定文件的 * 绝对 * 路径,方法是在'test.log'前面加上一个您知道可由运行代码的进程写入的目录。
另一个问题可能只是Django进程运行的用户的权限问题:通常当运行开发服务器时,它在您的帐户下运行,您通常不会遇到权限问题。当部署(例如使用Apache和mod_wsgi)时,Apache进程和/或mod_wsgi守护进程在不同的帐户下运行,这些帐户可能需要被授予相关文件夹的权限。
如果您需要更多帮助,请给予有关部署方法,日志文件目录位置等的更多详细信息。

mwg9r5ms

mwg9r5ms2#

只要整合一点,配置中指定的日志文件实际上是相对于您运行程序的位置的。例如,当我部署运行在根文件“/path/to/root”的Apache服务器时。您指定的日志配置将尝试写入“/path/to/root/test.log”
再看看这个thread:Using program variables in python logging configuration file

相关问题