Mysql数据库时区和服务器时区不一致,造成数据库查询结果不一致
问题描述:测试环境是在服务器用docker进行部署的,构建一个服务中心,需要在上面拉取数据,在本地拉取数据是没有问题的,但是部署到测试环境中会出现数据丢失的问题,缺少将近一百条数据不能拉取,拉取的sql条件是用timestamp的传递值的。解决问题的过程直接使用tomcat启用项目(拉取数据没有问题)定位是docker容器使用的问题更换docker的tomcat镜像,再次启...
·
问题描述:
- 测试环境是在服务器用docker进行部署的,构建一个服务中心,需要在上面拉取数据,在本地拉取数据是没有问题的,但是部署到测试环境中会出现数据丢失的问题,缺少将近一百条数据不能拉取,拉取的sql条件是用timestamp的传递值的。
解决问题的过程
- 直接使用tomcat启用项目(拉取数据没有问题)
- 定位是docker容器使用的问题
- 更换docker的tomcat镜像,再次启动项目(拉取数据问题存在)
- 与tomcat镜像无关
- 修改代码,将时间戳改成字符串传值(拉取数据问题)
- 确认与时间戳有关系
- 更换docker时区,时间与宿主机一直(拉取数据没有问题)
docker run -v /etc/localtime:/etc/localtime -v /etc/timezone:/etc/timezone
/etc/localtime //修改时间
/etc/timezone //修改时区
- 最终确认解决方案
总结:
- 使用docker镜像一定保证与宿主机时区,时间一致
- 但是为啥因为时区和时间问题,会引发mysql查询问题,有待深入研究
后续(解答):
数据库和服务器的时区不一致,docker的美国时区传到宿主机数据库Mysql的时区会进行自动转换,比如docker传过来时间是8点的,转换成上海时区就是16点,是导致数据库查询不一致的根本原因。
所以一定到保证docker和mysql的时区是一致的
更多推荐
已为社区贡献1条内容
所有评论(0)