原来 Docker 容器中设置时区这么简单

本文涉及的产品
容器镜像服务 ACR,镜像仓库100个 不限时长
简介: 大家好, 我是老麦。 今天我们一起讨论一下容器时区的问题。

Docker 容器中设置时区

大家好, 我是老麦。 今天我们一起讨论一下容器时区的问题。

在 linux 中, 通过 /etc/timezone 这个文件设置。 可以通过如下命令 持久化 时区设置, 其中 Asia/Shanghai 是我们需要的时区。

cp -a /usr/share/zoneinfo/Asia/Shanghai /etc/timezone

容器中设置时区一直是独立于宿主机的。 可以通过挂载 /etc/timezone 的方式保持与宿主机时间一致。

docker run --rm -it -v /etc/timezone:/etc/timezone debian bash

这种方法只适合 本地的、简单的、临时的 容器。

容器有一个很重要的特点, 就是 一处编译, 处处运行。 另外, 容器运行环境本身应该是 独立/隔离 的, 即使是时区也不应该依赖于宿主机。

通过 TZ 环境变量 设置时区

在 Linux 中, 还可以通过 TZ 这个环境变量来设置时区。 但是这种设置并不能实现持久化, 只能在 当前进程和其子进程 中生效。

export TZ=Asia/Shanghai

这种方式在 Linux 系统中不合适, 但是在容器中却相当合适。 因为容器核心就是 单进程应用, 不会像 Linux 系统上启动很多。

$ date
Wed Dec 21 14:06:44 UTC 2022

$ export TZ=Asia/Shanghai
$ date
Wed Dec 21 22:06:52 CST 2022

如果需要是用 TZ 环境变量 实现时区控制, 需要安装 tzdata 这个包。

debian/ubuntu 中安装。

debian 的基础镜像默认情况下已经安装了 tzdata,而 ubuntu 并没有。
tzdata 安装时有交互操作, 需要选择默认时区。 通过 DEBIAN_FRONTEND=noninteractive 进入非交互模式, 直接安装。

DEBIAN_FRONTEND=noninteractive apt install -y tzdata

alpine 中安装

apk add --no-cache tzdata

容器中通过 TZ 环境变量 实现时区控制

  1. 我们需要在构建业务镜像的时候安装 tzdata 并设置 默认时区
  2. 在容器启动的时候, 根据需要再通过注入环境变量的方式设置时区。

Dockerfile 以 nginx:debian 为例

FROM nginx:1.23 

# 安装 tzdata
RUN apk update \
    && DEBIAN_FRONTEND=noninteractive apt install -y tzdata \
    && rm -rf /var/lib/apt/lists/*

# 设置默认时区
ENV TZ=Asia/Shanghai

# ...省略

假设通过上述 Dockerfile 构建的镜像名为 nginx:1.23-tz-shanghai。 通过 注入变量 修改时区。

直接使用, 我们将得到 CST 时区。

以下就不通过上述 Dockerfile 构建镜像了。 时区反着来。

默认 nginx:1.23 使用的是 Etc/UTC 时间。

$ docker run --rm nginx:1.23 date
Wed Dec 21 14:23:03 UTC 2022

在启动的时候, 注入上海时区的环境变量

$ docker run --rm -e "TZ=Asia/Shanghai" nginx:1.23 date
Wed Dec 21 22:23:30 CST 2022

docker-composeKubernetes 通过各自的方式注入环境变量即可。

全球所有可用时区, 参考地址 https://en.wikipedia.org/wiki/List_of_tz_database_time_zones#List

相关文章
|
22天前
|
监控 Kubernetes 安全
还没搞懂Docker? Docker容器技术实战指南 ! 从入门到企业级应用 !
蒋星熠Jaxonic,技术探索者,以代码为笔,在二进制星河中书写极客诗篇。专注Docker与容器化实践,分享从入门到企业级应用的深度经验,助力开发者乘风破浪,驶向云原生新世界。
还没搞懂Docker? Docker容器技术实战指南 ! 从入门到企业级应用 !
|
14天前
|
NoSQL 算法 Redis
【Docker】(3)学习Docker中 镜像与容器数据卷、映射关系!手把手带你安装 MySql主从同步 和 Redis三主三从集群!并且进行主从切换与扩容操作,还有分析 哈希分区 等知识点!
Union文件系统(UnionFS)是一种**分层、轻量级并且高性能的文件系统**,它支持对文件系统的修改作为一次提交来一层层的叠加,同时可以将不同目录挂载到同一个虚拟文件系统下(unite several directories into a single virtual filesystem) Union 文件系统是 Docker 镜像的基础。 镜像可以通过分层来进行继承,基于基础镜像(没有父镜像),可以制作各种具体的应用镜像。
158 5
|
15天前
|
监控 Linux 调度
【赵渝强老师】Docker容器的资源管理机制
本文介绍了Linux CGroup技术及其在Docker资源管理中的应用。通过实例演示了如何利用CGroup限制应用程序的CPU、内存和I/O带宽使用,实现系统资源的精细化控制,帮助理解Docker底层资源限制机制。
102 6
kde
|
18天前
|
存储 关系型数据库 MySQL
MySQL Docker 容器化部署全指南
MySQL是一款开源关系型数据库,广泛用于Web及企业应用。Docker容器化部署可解决环境不一致、依赖冲突问题,实现高效、隔离、轻量的MySQL服务运行,支持数据持久化与快速迁移,适用于开发、测试及生产环境。
kde
198 4
|
2月前
|
Kubernetes Docker Python
Docker 与 Kubernetes 容器化部署核心技术及企业级应用实践全方案解析
本文详解Docker与Kubernetes容器化技术,涵盖概念原理、环境搭建、镜像构建、应用部署及监控扩展,助你掌握企业级容器化方案,提升应用开发与运维效率。
550 108
|
3月前
|
存储 监控 测试技术
如何将现有的应用程序迁移到Docker容器中?
如何将现有的应用程序迁移到Docker容器中?
321 57
|
2月前
|
缓存 Ubuntu Docker
Ubuntu环境下删除Docker镜像与容器、配置静态IP地址教程。
如果遇见问题或者想回滚改动, 可以重启系统.
191 16