在eggjs项目发布到服务器后,查看打印日志,出出现日期时间和当前时间对不上。
首先排查服务器时间:
root@wx-control-55495fb78c-hc8lx:/data# date -R
Fri, 22 Jul 2022 17:10:27 +0800
root@wx-control-55495fb78c-hc8lx:/data# node -v
v14.17.0
root@wx-control-55495fb78c-hc8lx:/data# node
Welcome to Node.js v14.17.0.
Type ".help" for more information.
> new Date();
2022-07-22T09:10:41.858Z
> new Date().toLocaleString();
'7/22/2022, 9:11:00 AM'
> .exit
root@wx-control-55495fb78c-hc8lx:/data#
检查结果认定服务器时间正确,那日志为啥打印的时间少8个小时
解决方案
在eggjs项目app.js中添加代码改变时区,代码如下:
// app.js
module.exports = (app) => {
process.env.TZ = "Asia/Shanghai";//调整上海时区
……
}
发布后重新查看日志:
文章和个人网站同步: