django时区和postgres时区

1. 背景

公司有个任务,功能要求:限制用户24小时发送的任务数,同时要告诉用户什么时间可以重试。

但是............,发现几个问题:

  • django代码打印出来的timezone.now(),跟北京时间差8个小时
  • django的日志打印,最前边的部分,是跟北京时间一样的
  • postgres时区,跟北京时间差8个小时
python 复制代码
# 查看django的timezone的当前时间,时区
from django.utils import timezone
print(timezone.now())
# 输出 datetime.datetime(2024, 4, 30, 8, 45, 27, 427727, tzinfo=<UTC>)



# 查看系统的当前时间和时区,一般跟服务器一样
from datetime import datetime
from django.utils import timezone
print(datetime.now()) # 结果跟北京时间一样
timezone.make_aware(datetime.now())
# 输出 datetime.datetime(2024, 4, 30, 16, 47, 51, 43601, tzinfo=<DstTzInfo 'Asia/Shanghai' CST+8:00:00 STD>)


# 查看postgres的时区
show timezone # 结果是ETC/UTC
select now() # 结果的时间,跟北京时间差8个小时

从结果来看,django的timezone=postgres的时区,但是和datetime.now()是不一样的。什么原因呢?先看原理

2. 需要明白的知识

django的timezone是根据settings的配置来显示的,需要两个参数来控制

python 复制代码
from django.utils import timezone
# 输出时区
print(timezone.get_current_timezone_name())
# 'Asia/Shanghai'
print(settings.USE_TZ) # True

datetime的时间是同步于系统的,而且django的日志模块Logging,就是跟datetime的时间是一样的。

postgres的时区是在postgres.conf里配置的,这个自己GPT

3. 最后解决方法

  1. django的timezone和数据库的timezone必须是一致的
  2. 在展示给用户重试的时间,在数据库中查找24小时内的比对任务数,然后取最早的时间,使用timezone.localtime(create_time)进行转换。
python 复制代码
timezone.localtime(create_time)

然后就解决了。

4. 最后

解决问题先救急后优化。一定不能慌,慢慢来,纠细节,别老用加8小时-24小时,这种太不确定了。思路捋不顺,多跟小鸭子讲讲。欢迎大家评论指正

相关推荐
喵手4 分钟前
Python爬虫实战:数据质量治理实战 - 构建企业级规则引擎与异常检测系统!
爬虫·python·爬虫实战·异常检测·零基础python爬虫教学·数据质量治理·企业级规则引擎
m***06684 分钟前
MySQL —— 配置文件
数据库·mysql·adb
e***13625 分钟前
mysql之日期时间函数
数据库·mysql
heimeiyingwang9 分钟前
如何用向量数据库构建企业级语义检索系统
数据库·mongodb·nosql·milvus
头发够用的程序员10 分钟前
Python 魔法方法 vs C++ 运算符重载全方位深度对比
开发语言·c++·python
Web打印15 分钟前
Phpask(php集成环境)之03安装mysql
数据库·mysql
加成BUFF22 分钟前
基于DeepSeek+Python开发软件并打包为exe(VSCode+Anaconda Prompt实操)
vscode·python·prompt·conda·anaconda
p***199430 分钟前
实操解决Navicat连接postgresql时出现‘datlastsysoid does not exist‘报错的问题
数据库·postgresql
52Hz1181 小时前
力扣46.全排列、78.子集、17.电话号码的字母组合
python·leetcode
子午1 小时前
【宠物识别系统】Python+深度学习+人工智能+算法模型+图像识别+TensorFlow+2026计算机毕设项目
人工智能·python·深度学习