当前位置: 首页 > news >正文

Docker启动PostgreSql并设置时间与主机同步

在这里插入图片描述

在 Docker 中启动 PostgreSql 时,需要配置容器的时间与主机同步。可以通过在 Dockerfile 或者 Docker Compose 文件中设置容器的时区,或者使用宿主机的时间来同步容器的时间。这样可以确保容器中的 PostgreSql 与主机的时间保持一致,避免在使用PostgreSql 的过程中遇到问题。

本文是在启动 PostgreSql 的时候,设置 PostgreSql 与宿主机的时间一致的方式

配置Docker与宿主机时间同步

可以在Docker启动容器时,将主机的时间挂载到容器中。这样,容器将使用宿主机的时间。例如,使用以下命令启动容器:

docker run -v /etc/localtime:/etc/localtime:ro <image_name>
使用案例

配置postgresql与宿主机时间同步

docker run -itd --privileged=true --name postgresql_test -v /opt/postgredata:/opt/postgredata -v /etc/localtime:/etc/localtime:ro -e POSTGRES_PASSWORD=<PostgreSql密码> -p 5435:5432 --shm-size 1G -d postgres:11.7
命令说明

在Docker容器中使用-v /etc/localtime:/etc/localtime:ro命令是将主机的/etc/localtime文件挂载到容器的/etc/localtime路径,并将挂载设置为只读模式(ro表示"read-only",只读)。

这个命令的作用是将主机的时区设置传递给容器,以便容器使用与主机相同的时间设置。通过将主机的/etc/localtime文件挂载到容器中,容器将直接使用主机的时区文件,从而与主机保持时间同步。

将挂载设置为只读模式是为了防止容器修改主机的时间设置。这样可以确保容器只能读取主机的时间设置,而不能修改它。这是为了保持时间同步的一种安全措施。

总结起来,-v /etc/localtime:/etc/localtime:ro命令的作用是将主机的时区文件挂载到容器中,并将挂载设置为只读模式,以实现时间同步并确保安全性。

验证时间是否一致

查看宿主机时间
date
查看容器时间
docker exec <容器名称|容器id> date
宿主机与容器时间对比

以上命令只能一个一个的查宿主机和容器的时间,在执行的时候,两个命令难免会有时间差,不能很好的对比两个之间的差别,可以将两个命令同时执行,以进行对比,可以使用 【;】 分号,同时执行以上两个命令

date ; docker exec <容器名称|容器id> date

该命令将通过返回宿主机和容器的时间

PostgreSql 时间与宿主机时间不一致会造成的问题

数据不一致

PostgreSql 是一个数据库管理系统,它依赖于正确的时间戳来记录和处理数据。如果容器中的 PostgreSql 与主机的时间不同步,可能会导致数据的时间戳不准确,从而导致数据不一致性。例如,如果容器中的时间比主机时间快,那么在容器中创建的数据可能会被错误地认为是未来的数据。

日志和故障排查困难

在容器中运行的 PostgreSql 会生成日志文件,用于故障排查和性能分析。如果容器中的时间与主机不同步,日志文件中的时间戳将不准确,使得故障排查变得困难。无法准确追踪事件发生的顺序和时间,从而增加了故障排查的复杂性。

安全性问题

PostgreSql 中的一些安全机制和协议可能依赖于正确的时间。例如,SSL/TLS 握手过程中会验证证书的有效期,如果容器中的时间与主机不同步,可能会导致证书验证失败,从而影响安全性。

http://www.lryc.cn/news/404608.html

相关文章:

  • 提升无线网络安全:用Python脚本发现并修复WiFi安全问题
  • #三元运算符(python/java/c)
  • 探索Python自然语言处理的新篇章:jionlp库介绍
  • Deepin系统,中盛科技温湿度模块读温度纯c程序(备份)
  • 文件包含漏洞: 函数,实例[pikachu_file_inclusion_local]
  • 学习计划2024下半年
  • RabbitMQ的学习和模拟实现|sqlite轻量级数据库的介绍和简单使用
  • AI批量剪辑,批量发布大模型矩阵系统搭建开发
  • SpringMVC源码深度解析(中)
  • Mojo模型动态批处理:智能预测的终极武器
  • 人、智能、机器人……
  • SpringCloud------Sentinel(微服务保护)
  • 【无标题】Elasticsearch for windows
  • Yolo-World网络模型结构及原理分析(一)——YOLO检测器
  • WEB前端06-BOM对象
  • Android11 framework 禁止三方应用开机自启动
  • Java | Leetcode Java题解之第263题丑数
  • 将AWS RDS MySQL实例从存储未加密改为加密的方案
  • nginx的配置:TLSv1 TLSv1.1 被暴露不安全
  • 揭开黑箱:目标检测中可解释性的重要性与实现
  • Mysql高价语句
  • ArcGIS Pro SDK (九)几何 6 包络
  • 单链表<数据结构 C版>
  • 监控电脑进程,避免程序在打开前就已经在运行
  • 【MySQL进阶篇】存储对象:视图、存储过程及触发器
  • 算法day05 master公式估算递归时间复杂度 归并排序 小和问题 堆排序
  • 基于jeecgboot-vue3的Flowable流程仿钉钉流程设计器-支持VForm3表单的选择与支持
  • 【刷题汇总 -- 压缩字符串(一)、chika和蜜柑、 01背包】
  • 《Exploring Aligned Complementary Image Pair for Blind Motion Deblurring》
  • vue2学习笔记9 - 通过观察vue实例中的data,理解Vue中的数据代理