Pod Preset玩转K8S容器时区自动配置

news/2024/7/8 2:52:06
摘要: 通过Pod Preset自动配置容器的时区

缘由

默认的情况,在K8S里启动一个容器,该容器的设置的时区是UTC0,但是对于很多客户而言,其主机环境并不在UTC0。例如中国客户在UTC8。如果不把容器的时区和主机主机设置为一致,则在查找日志等时候将非常不方便,也容易造成误解。但是K8S以及Docker容器没有一个简便的设置/开关在系统层面做配置。都需要我们从单个容器入手做设置,具体方法如下:

纯Docker的时区设置方式

Docker引擎提供了两种设置方式,分别是通过环境变量以及挂载主机文件方式来完成

方式一:设置容器的时区环境变量

先看看没有设置前,容器的情况:

clipboard.png

clipboard.png

从输出可以看出,容器和主机差了8个时区

我们通过环境变量的方式来改变容器的时区:

clipboard.png

clipboard.png

从输出可以看出,虽然没有改变对应的localtime文件,但是容器和主机的时区是一致的了。

方式二:挂载主机的时区文件到容器中

clipboard.png

clipboard.png

从输出可以看出,容器和主机的时区是一致的了,而且使用了本机的时区文件。

Kubernetes的时区设置方式

在K8S中,可以参考Docker的方式进行设置

通过环境变量设置

clipboard.png

通过挂载主机时区文件设置

clipboard.png

这里引出了一个问题,难道每次每个容器都要做这样的配置才可以么?可否在系统层面设置,而无需在对应yaml文件体现呢?不然yaml文件将过于啰嗦。答案是使用K8S的特性Pod Preset来控制容器启动前先配置好对应时区环境变量,或者挂载主机文件。下面我们通过配置环境变量的方式说明,挂载文件是类似的,就不重复了。

通过Pod Preset预设置时区环境变量

激活Pod Preset

Pod Preset目前还是alpha阶段,默认是没有激活的,所以需要通过以下步骤激活:

咱们以阿里云的Kubernetes服务为例(如果还没有,可以尝试一下,一键就可以开通,还免费哦)。阿里云的Kubernetes服务的master组件(API Server, Scheduler, Controller)都是通过Static Pod的方式用Kubelet启动,所以需要更改对应的yaml来激活Pod Preset:

编辑/etc/kubernetes/manifests/kube-apiserver.yaml,

• 在-runtime-config增加settings.k8s.io/v1alpha1=true

• 在--admission-control增加PodPreset`

保存后kubelet会自动重启kube-apiserver组件。我们需要同时更改3台机器的master才可以。在期间你将收到类似以下的告警,在api server重启成功后会自动恢复

clipboard.png

验证配置成功

• 确保api server已经恢复,如果恢复将收到如下通知信息:

clipboard.png

• kubectl可以查询Pod Preset。在开关没有开启成功前,是无法调用以下命令的

clipboard.png

配置设置时区的Pod Preset

对应的Pod Preset对象创建文件如下:

clipboard.png

这里需要注意的地方是,一定需要写selector...matchLabels,但是matchLabels为空,标示应用于所有容器,这个正式我们所期望的

clipboard.png

clipboard.png

可以得到创建成功的Pod Preset列表:

clipboard.png

以普通的方式创建容器,但是环境变量被Pod Preset注入了

clipboard.png

进入容器看看对应的环境变量:

clipboard.png

从输出可以看出,容器已经被默认配置了时区的环境变量,对应的时区是Asia/Shanghai

小结

至此,我们就完成了容器的时区的"自动"配置了。Pod Preset的预设功能还是非常便利的,目前这块还在演进中,但是已经能大大简化了相关的管理工作,将这些配置从开发者手中解脱出来,变成系统管理配置。

需要注意的是,Pod Preset是namespace级别的对象,其作用范围只能是同一个命名空间下容器。

给社区的建议

建议Kubernetes社区可以在kubelet的启动参数重,增加一个开关,用来设置容器的默认时区,毕竟这个是很常见的实践

参考文档

Pod Preset: https://kubernetes.io/docs/co...

Static Pod: https://kubernetes.io/docs/ta...

label-selectors: https://kubernetes.io/docs/co...

本文作者:了哥-duff

阅读原文

本文为云栖社区原创内容,未经允许不得转载。


http://www.niftyadmin.cn/n/2205213.html

相关文章

一个该死的Linux权限问题

今天在一个全新的Ubuntu16.04主机上配置PHP,MySQL,Nginx环境。 这种事情我已经做过很多遍了。应该是信手拈来。 环境很快就搭建起来了,本地浏览器访问主机IP后确始终显示不出来页面。 我配置的是8001端口,难道防火墙限制了&#x…

早上起床后不想动,让 Python 来帮你朗读网页吧

是不是有的时候懒得自己看新闻?那么不妨试试用 Python 来朗读给你听吧。 网页转换成语音,步骤无外乎: 网页正文识别,获取到正文的文本内容; 文本转语音,通过接口将文本转换成语音文件; 语音文件…

[源码阅读]解析Anime(JS动画库)核心(1)

本次解析将分为2篇文章,当前是第一篇,第二篇在这里 另外,为了能更好的理解这个库,个人写了一个此库的压缩版,实现了核心的功能(主要也是为了更好理解核心功能),内容更少方便阅读,地址在这里 介绍…

微信小程序--手写一个地区选择器(多级联动)

前言 通过微信小程序官方文档,我们可以看到表单组件中有picker这类滚动选择器。 现支持五种选择器,通过mode来区分,默认是普通选择器。 普通选择器多列选择器时间选择器日期选择器省市区选择器需求场景:官方的地区选择器是三级联动…

HTML和CSS属性的正确书写规范

网页的重要性评级: 网页的排名。标签的语义化,正确的标签做正确的事情。提升网页的加载速度。1. CSS代码优化,代码的正确排列顺序,不正确的代码会导致浏览器解析代码回流,会拖慢浏览器的加载速度。 减少图片服务器的请…

Redis进阶实践之十六 Redis大批量增加数据

2019独角兽企业重金招聘Python工程师标准>>> Redis进阶实践之十六 Redis大批量增加数据 一、介绍 有时候,Redis实例需要在很短的时间内加载大量先前存在或用户生成的数据,以便尽可能快地创建数百万个键。这就是所谓的批量插入&…

LINUX-centos7tomcat安装教程

1.yum install -y tomcat (jdk,依赖自动给装好了)2.systemctl start tomcat(打开tomcat)3.ps -aux | grep tomcat(查询是否打开)4.systemctl stop firewalld.service(关闭防火墙)5.systemctl disable firew…

动画效果

显示动画 方式一: $("div").show(); 解释:无参数,表示让指定的元素显示出来。其实这个方法的底层就是通过display:block;实现 方式二: $("div").show(3000); 解释:通过控制…