我在服务器上启动了个服务,结果发现打印的日志时间不太对,发现时区不是北京时区,修改后重新启动报错:
ValueError: Timezone offset does not match system offset: 0 != 28800.
经过一番搜索,发现是一个定时任务库scheduler出现的问题。
解决办法:
首先查看服务器时区是上海,然后需要修改两个地方:
-
在配置文件中添加SCHEDULER_TIMEZONE = 'Asia/Shanghai'
-
在初始化时scheduler = APScheduler(BackgroundScheduler(timezone="Asia/Shanghai"))
原因是:时区会被解析两次,如果没有加时区,就会调用默认的self.timezone = astimezone(config.pop('timezone', None)) or get_localzone(),由于时区与系统不匹配,会报错。