最近使用.net core写了一个简单的网站存活监测小程序,每十分钟进行一次检测,如果异常或者网站无法访问就通过腾讯云短信服务进行通知。在Windows 和 Linux 系统中运行均正常,但放到Linux系统下Docker环境中,获取到的时间就慢8个小时,默认似乎不是东八区了。记得之前也遇到过这个问题,使用了一个.net Core类库(NodaTime)解决的,详情请见:.net Core 中DateTime在Linux Docker中与Windows时间不一致 。但是这次不想用多余的类库来解决,所以通过同步时间来解决。
共享主机的localtime
创建容器的时候指定启动参数,挂载localtime文件到容器内 ,保证两者所采用的时区是一致的。
docker run --name qq -v /etc/localtime:/etc/localtime -d dotnetcoreqqcloudsms
复制主机的localtime
docker cp /etc/localtime containerid:/etc/localtime
创建自定义的dockerfile
在原本dockerfile
文件中新增以下内容
#时区设置
RUN /bin/cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime \
&& echo ‘Asia/Shanghai’ >/etc/timezone
dockerfile
全部内容如下
FROM microsoft/dotnet:2.0-runtime AS base
WORKDIR /DotnetCoreQQCloudSms
COPY . /DotnetCoreQQCloudSms
#时区设置
RUN /bin/cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime \
&& echo ‘Asia/Shanghai’ >/etc/timezone
ENTRYPOINT ["dotnet", "DotnetCoreQQCloudSms.dll"]
保存后重新构建镜像运行即可。
.Net6使用以上时区设置无效
使用以上Dockerfile
时区设置,容器内部日期已经正常,但是.NET6
应用获取的日期还是存在问题,没有任何效果。
修改原有Dockerfile
时区设置,添加如下内容
#时区设置
RUN /bin/cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime \
&& echo ‘Asia/Shanghai’ >/etc/timezone \
&& ln -sf /usr/share/zoneinfo/Asia/Shanghai /etc/localtime
修改后Dockerfile
全部内容示例如下
FROM mcr.microsoft.com/dotnet/runtime:6.0 AS base
#时区设置
RUN /bin/cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime \
&& echo ‘Asia/Shanghai’ >/etc/timezone \
&& ln -sf /usr/share/zoneinfo/Asia/Shanghai /etc/localtime
WORKDIR /app
COPY . /app/
ENTRYPOINT ["dotnet", "JustHost.Ftp.ClearLog.dll"]
经过测试确认问题已经解决,需要注意一下时区设置并不需要这么多内容,只需要如下内容即可
#时区设置
RUN ln -sf /usr/share/zoneinfo/Asia/Shanghai /etc/localtime
简化后的Dockerfile
全部内容示例如下
FROM mcr.microsoft.com/dotnet/runtime:6.0 AS base
#时区设置
RUN ln -sf /usr/share/zoneinfo/Asia/Shanghai /etc/localtime
WORKDIR /app
COPY . /app/
ENTRYPOINT ["dotnet", "JustHost.Ftp.ClearLog.dll"]
转载请注明:清风亦平凡 » docker容器与Linux主机环境获取时间不一致