作者热门文章
- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我有以下文件来配置日志记录:
[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 试图写入我没有必要权限的路径。
所以我的问题是,如何在此配置文件中指定相对路径。
最佳答案
Mark 是对的,您在配置文件中的路径是相对于 logging.config.fileConfig
调用时的当前目录的。这取决于您的部署方法的详细信息。
您可能需要为您的文件指定一个绝对路径,方法是在“test.log”前面加上您知道运行代码的进程可写的目录。
另一个问题可能只是您的 Django 进程在其下运行的用户的权限问题:通常在运行开发服务器时它在您的帐户下运行,您通常不会遇到权限问题。在部署(例如使用 Apache 和 mod_wsgi)时,Apache 进程和/或 mod_wsgi 守护进程在不同的帐户下运行,可能需要授予相关文件夹的权限。
如果您需要更多帮助,请提供有关您的部署的更多详细信息,包括方法、日志文件目录的位置等。
关于python - 如何在 Python 日志记录配置文件中指定相对路径?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2806376/
我是一名优秀的程序员,十分优秀!