在函数计算中,云函数的默认时区是 UTC,然而,它与北京时间存在8小时的时差,这可能在处理时间相关的函数时引发一些偏差。为了解决这个问题,您可以通过配置环境变量 TZ 来设定您所需的时区。具体来说,当您选择了一个特定的时区后,系统会自动添加对应时区的 TZ 环境变量。这样,您就可以根据业务需求来调整和获取正确的时间了。
函数计算默认是UTC时间,可以配置环境变量进行修改。
可以配置环境变量进行时区修改:TZ = Asia/Shanghai 如何配置环境变量
需要注意的是,在nodejs环境中,console.log(date) 会转成utc 时间,可以直接先转成 string , 然后在console.log,
var date = new Date();
console.info(date.toTimeString());
或者自己重写 console.log, 如下面代码所示
'use strict';
var util = require('util');
function _writeToStdout(level, msg) {
const now = new Date();
// 自定义格式
const timeStr = $now.getFullYear()-$now.getMonth()+1-$now.getDate()T$now.getHours():$now.getMinutes():$(now.getSeconds()*1000+now.getMilliseconds())/1000Z
// const timeStr = now.toLocaleString();
let requestID = process._fc && process._fc.requestId ? process._fc.requestId : '';
let logMsg = $timeStr $requestID [$level] $msg;
logMsg = logMsg.replace(/\n/g, "\r");
process.stdout.write(logMsg + "\n");
}
var log = function (level, msg, ...params) {
var logMsg = util.format(msg, ...params);
_writeToStdout(level, logMsg);
};
console.log = function (msg, ...params) {
log('verbose', msg, ...params);
};
console.info = function (msg, ...params) {
log('info', msg, ...params);
};
console.warn = function (msg, ...params) {
log('warn', msg, ...params);
};
console.error = function (msg, ...params) {
log('error', msg, ...params);
};
console.debug = function (msg, ...params) {
log('debug', msg, ...params);
};
exports.handler = (event, context, callback) => {
// const eventObj = JSON.parse(event.toString());
console.log('hello world');
callback(null, 'hello world');
}
此回答来自钉群阿里函数计算官网客户。
您可以通过设置层或环境变量来定制操作系统环境。以时区定制为例,函数实例默认以UTC时间运行,也就是0时区,当您设置环境变量TZ的值为Asia/Shanghai后,函数计算的时区被修改为东8区,即北京时间。https://help.aliyun.com/zh/fc/user-guide/basics?spm=a2c4g.11186623.0.i132
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。