前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >如何为Docker容器设置环境变量?

如何为Docker容器设置环境变量?

作者头像
用户1560186
发布2019-11-20 17:05:27
4.1K0
发布2019-11-20 17:05:27
举报
文章被收录于专栏:运维录

开始之前

上一篇文章介绍了如何创建一个Docker容器,本篇文章(2017-08)介绍如何设置Docker容器环境变量,例如示例中的时区环境变量,需要注意的是容器的环境变量需要在创建容器时指定,容器时运行无法添加或者更改。

问题描述

发现使用 docker创建的 tomcat容器日志时区不正确(时差8小时),即使挂载了宿主机 /etc/localtime文件(宿主机时区是正确的),虽然容器的操作系统时间正常了,但是 tomcat的日志时区仍然是错误的,这对容器日志分析带来麻烦,我们的目标是为创建的tomcat容器设置正确的时区。

环境描述

1. 软件版本

代码语言:javascript
复制
Tomcat:9 On Docker 1.13.1

2. 宿主机时区文件

代码语言:javascript
复制
tail -n1 /etc/localtime
CST-8

3. 创建容器使用的命令

代码语言:javascript
复制
docker run -tid --name test -p 10080:8080 \
 -v /usr/local/tomcat/logs \
 -v /etc/localtime:/etc/localtime \
 --label aliyun.logs.catalina=stdout \
 --label aliyun.logs.access=/usr/local/tomcat/logs/localhost_access_log.*.txt \
 tomcat:9

如果对 docker命令参数不熟悉可以使用 --help 帮助,或者参考这篇文章 <<创建一个Docker容器>>

4. 日志时区

代码语言:javascript
复制
docker logs --tail 1 test

10-Aug-2017 06:43:48.390 INFO [Thread-5] org.apache.coyote.AbstractProtocol.destroy Destroying ProtocolHandler ["ajp-nio-8009"]

注意: 日志时间 06:43:48 是不正确的。

解决方法

创建容器时指定TZ时区环境变量,例如设置时区为 Asia/Chongqing 。

代码语言:javascript
复制
docker run -tid --name new -p 10080:8080 \
    -v /usr/local/tomcat/logs \
    -e TZ=Asia/Chongqing \
    --label aliyun.logs.catalina=stdout \
    --label aliyun.logs.access=/usr/local/tomcat/logs/localhost_access_log.*.txt \
    tomcat:9

再次验证容器时区

代码语言:javascript
复制
docker logs --tail 1 new
10-Aug-2017 14:44:51.736 INFO [main] org.apache.catalina.core.StandardService.startInternal Starting service [Catalina]

注意: 日志时间 14:44:51 才是正确的。

命令帮助

run子命令 -e 参数设置容器的环境变量可以指定多次,多个环境变量还可以使用读取文件的方式 。

代码语言:javascript
复制
docker run --help | grep -i '\-env'
  -e, --env list        Set environment variables
      --env-file list   Read in a file of environment variables

参考文章

docker 设置容器环境变量 http://zongming.net/read-1092

如何解决 docker 环境 tomcat 时区问题

http://zongming.net/read-1325

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2019-09-12,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 运维录 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 开始之前
  • 问题描述
  • 环境描述
  • 解决方法
  • 注意: 日志时间 14:44:51 才是正确的。
  • 命令帮助
  • 参考文章
相关产品与服务
容器服务
腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档