前几天在使用k8s中的CronJob时发现了一个很奇怪的问题, 按照官方文档的demo跑起来是没有任何问题的,
但是当我想要设置每天一个固定时间点例如12点20执行一个job的时候,到了时间之后无论如何都不会执行。
一开始怀疑是cron表达式写的有问题,但是经过多次试验倒是没问题,然后就想到了时区的问题。
首先我先尝试使用PodPreset来修改所有容器的时区(在pod 创建时,用户可以使用 podpreset 对象将特定信息注入 pod 中,这些信息可以包括 secret、 卷、 卷挂载和环境变量)
默认k8s是没有开启PodPreset的,开启PodPreset需要修改master节点上的/etc/kubernetes/manifests/kube-apiserver.yaml文件
<figure class="highlight dockerfile"><table><tr>
<td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br></pre></td>
<td class="code"><pre><span class="line">首先在<span class="keyword">CMD</span><span class="bash">末尾添加一个--runtime-config=settings.k8s.io/v1alpha1=<span class="literal">true</span></span></span><br><span class="line"><span class="bash">在--<span class="built_in">enable</span>-admission-plugins的后面增加一个PodPreset</span></span><br><span class="line"><span class="bash">重启k8s systemctl restart kubelet</span></span><br></pre></td>
</tr></table></figure>
创建一个yml,为所有的pod挂载一个时区的环境变量
<figure class="highlight less"><table><tr>
<td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br><span class="line">6</span><br><span class="line">7</span><br><span class="line">8</span><br><span class="line">9</span><br><span class="line">10</span><br><span class="line">11</span><br></pre></td>
<td class="code"><pre><span class="line"><span class="attribute">apiVersion</span>: settings.k8s.io/v1alpha1</span><br><span class="line"><span class="attribute">kind</span>: PodPreset</span><br><span class="line"><span class="attribute">metadata</span>:</span><br><span class="line"> <span class="attribute">name</span>: tz-env</span><br><span class="line"> <span class="attribute">namespace</span>: unicode-pay</span><br><span class="line"><span class="attribute">spec</span>:</span><br><span class="line"> <span class="attribute">selector</span>:</span><br><span class="line"> <span class="attribute">matchLabels</span>:</span><br><span class="line"> <span class="attribute">env</span>:</span><br><span class="line"> - <span class="attribute">name</span>: TZ</span><br><span class="line"> <span class="attribute">value</span>: Asia/Shanghai</span><br></pre></td>
</tr></table></figure>
注意:
- Pod Preset是namespace级别的对象,其作用范围只能是同一个命名空间下容器
- matchLabels为空代表选择所有
此时再次尝试CronJob之后发现还是不执行,然后进入该命名空间下的其他pod之后查看时间发现也没问题。
此时想到了虽然把pod的时区更改了,但是k8s调度器可不是按照pod的时间进行调度的,原来此时需要修改的是k8s的时区
再次来到/etc/kubernetes/manifests目录,使用如下方式修改此目录下4个k8s的组件的时间
<figure class="highlight routeros"><table><tr>
<td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br><span class="line">6</span><br><span class="line">7</span><br><span class="line">8</span><br><span class="line">9</span><br><span class="line">10</span><br><span class="line">11</span><br><span class="line">12</span><br><span class="line">13</span><br><span class="line">14</span><br></pre></td>
<td class="code"><pre><span class="line">apiVersion: v1</span><br><span class="line">kind: Pod</span><br><span class="line">metadata:</span><br><span class="line"> name: time</span><br><span class="line">spec:</span><br><span class="line"> containers:</span><br><span class="line"> volumeMounts:</span><br><span class="line"> - name: config</span><br><span class="line"> mountPath: /etc/localtime</span><br><span class="line"> readOnly: <span class="literal">true</span></span><br><span class="line"> volumes:</span><br><span class="line"> - name: config</span><br><span class="line"> hostPath:</span><br><span class="line"> path: /etc/localtime</span><br></pre></td>
</tr></table></figure>
重启k8s,搞定
systemctl restart kubelet
推荐阅读
- SpringCloud学习系列汇总
- 为什么一线大厂面试必问redis,有啥好问的?
- 多线程面试必备基础知识汇总
- Java集合源码分析汇总-JDK1.8
- Linux常用命令速查-汇总篇
- JVM系列文章汇总
- MySQL系列文章汇总
- RabbitMQ系列文章汇总
博客所有文章首发于公众号《Java学习录》转载请保留
扫码关注公众号即可领取2000GJava学习资源
分享到:
相关推荐
k8s课件
calico是一个比较有趣的虚拟网络解决方案,它完全利用路由规则实现动态组网,通过BGP协议通告路由。
Kubernetes(K8S)是Google在2014年发布的一个开源项目,用于自动化容器化应用程序的部署、扩展和管理。Kubernetes通常结合docker容器工作,并且整合多个运行着docker容器的主机集群。 适用人群 零基础以及有一定运维...
kubernetes/k8s自动安装程序,版本对应:v1.18.2,linux环境 使用kubeadm安装,改程序若环境不符合要求,是不能一键安装的,需按照程序指示分布安装,该程序是为了搭建测试环境时,简化繁琐的配置时所用,不能用作...
k8s技术分享ppt
k8s集群pod经常重启问题排查总结
K8S入门课件
k8s集群搭建redis集群 k8s集群搭建redis集群 k8s集群搭建redis集群 k8s集群搭建redis集群 k8s集群搭建redis集群
K8s V1.8.2升级到K8s V1.9.7版本升级步骤,以上是在虚机环境上安装的,1个是master节点,一个是node节点
k8s.gcr.io的相关images,版本v1.14.1使用说明在里面··
k8s搭建Nacos集群,制作Nacos镜像 Nacos版本是:2.0.2
├ k8s-1、搭建docker+kubernetes │ │ k8s-1、搭建docker+kubernetes.pdf │ │ VMware启动.mp4 │ └ 安装docker和k8s.mp4 ├ k8s-2、k8s安装网络插件Flannel │ │ k8s-2、k8s安装网络插件Flannel.pdf │ └ ...
k8s-day1 01-k8s集群的安装.mp4 02-为什么要使用k8s.mp4 03-k8s的功能特性和基础架构.mp4 04-k8s的基础单元pod.mp4 k8s-day2 01-副本控制器rc.mp4 02-新副本控制器deployment.mp4 03-容器的网络访问service.mp4 04-...
helm部署应用到k8s集群(helm+k8s)——详细文档
k8s(kubernetes)常见故障处理总结——详细文档
k8s离线文件包 Ubuntu 使用Kubeadm 离线安装k8s 参考连接 https://blog.csdn.net/u010952056/article/details/127276191?spm=1001.2014.3001.5501
介绍k8s搭建,核心资源使用等等
K8s搭建部署、docker部署、linux内核升级,k8s升级操作
k8s集群v1.18.1一键安装 博客地址:https://mp.csdn.net/mp_blog/creation/editor/126865214 百度云 链接:https://pan.baidu.com/s/1-ZuRxpGdL7mBnyOK2s_yCw 提取码:fr7r 执行setup_master.sh 安装 master-node...
我个人给公司开发的使用ansible部署k8s的脚本,支持vagrant调用ansbile,和直接ansible执行两种方式。k8s二进制组件使用最新的1.23.5 部署以下模块内容包括: preinstall 安装前准备,主机环境初始化,二进制文件...