前几天在使用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学习资源
分享到:
相关推荐
Calico作为一款流行的网络插件,为k8s提供了高性能、灵活且可扩展的网络解决方案。下面我们将详细探讨Calico的核心特性、工作原理以及如何配置和使用`calico.yaml`文件。 Calico的主要特点: 1. **网络策略**:...
因此,本文总结了 k8s 中常见的故障处理方法,以便快速诊断和解决问题。 一、k8s 之连接异常(集群故障) 在 k8s 集群中,pod 是最小的调度单元,每个 pod 代表集群上正在运行的一个进程。pod 中可以封装一个或多...
Kubernetes(简称K8s)是Google开源的一种容器编排系统,用于自动化容器化的应用程序部署、扩展和管理。作为现代云原生应用的核心平台,K8S已经成为了企业级基础设施的重要组成部分。本“K8S入门基础课件docx版本”...
### K8s之Lens使用详解 #### 一、引言 随着Kubernetes(简称K8s)成为容器编排领域的主流...掌握其使用方法能够显著提高日常工作中对K8s集群的操作效率和管理能力。希望本文能帮助大家更好地利用Lens这款优秀的工具。
二进制部署k8s高可用集群(二进制-V1.20) 基于提供的文件信息,本文将对二进制部署k8s高可用集群进行详细的知识点总结。 1. 生产环境部署 K8s 集群的两种方式 在生产环境中,部署 K8s 集群有两种方式:一种是...
1. **数据源配置**:模板会预设Prometheus作为数据源,因为Prometheus是k8s社区广泛使用的监控解决方案。它能收集到丰富的k8s API指标,如节点、Pod、服务的性能指标。 2. **面板设计**:面板是Grafana中的可视化...
Kubernetes(K8S)是Google在2014年发布的一个开源项目,用于自动化容器化应用程序的部署、扩展和管理。Kubernetes通常结合docker容器工作,并且整合多个运行着docker容器的主机集群。 适用人群 零基础以及有一定运维...
总结,k8s高可用部署方案旨在提供一个稳定、高效且易于管理的容器化平台。通过精心设计的架构和组件,确保即使在部分硬件或服务故障的情况下,整个系统依然能够持续提供服务。同时,通过统一的入口点和自动化部署...
kubernetes/k8s自动安装程序,版本对应:v1.18.2,linux环境 使用kubeadm安装,改程序若环境不符合要求,是不能一键安装的,需按照程序指示分布安装,该程序是为了搭建测试环境时,简化繁琐的配置时所用,不能用作...
k8s技术分享ppt
Rancher-K8s作为一款高效的企业级私有云平台解决方案,它不仅提供了强大的容器编排能力,还支持Kubernetes集群的管理和部署。对于企业而言,Rancher-K8s能够帮助快速构建稳定可靠的Kubernetes环境,简化复杂的基础...
Prometheus 是一个流行的开源监控系统和时间序列数据库,它被广泛用于监视各种应用程序和服务,包括 Kubernetes (k8s) 集群。本详细文档将介绍如何使用 Prometheus 监控 k8s 集群,并结合 Alertmanager 实现报警功能...
在Kubernetes(简称k8s)环境中,证书是保障集群安全和通信的重要组成部分。默认情况下,k8s的证书有效期通常为一年,但这可能会导致在证书即将到期时需要频繁进行更新,增加了管理负担。本教程将详细介绍如何将k8s...
### K8s概述 Kubernetes(简称K8s)是一个高度可扩展的开源容器编排系统,用于自动化部署、...无论是微服务架构、大数据处理还是机器学习平台,K8s都能够提供灵活、高效的解决方案,帮助企业实现数字化转型的目标。
k8s架构图整体框架知识合集 k8s架构图整体框架知识合集是对kubernetes架构的深入剖析和总结,本文对k8s的架构、设计、实现原理、存储、网络、调度、监控、安全、应用管理等方面进行了详细的介绍和分析。 一、k8s...
在IT行业中,Kubernetes(简称k8s)已经成为容器编排和管理的主流平台,它为企业提供了高效、灵活且可扩展的基础设施管理解决方案。"cloud-运维平台_k8s_k8s运维平台_cloud_"这个标题暗示了我们正在讨论的是一个针对...
Prometheus是一款强大的开源系统监控和警报工具,而Grafana则是一款优秀的数据可视化平台,两者结合能够提供一套完整的监控解决方案。在这个“使用prometheus监控k8s的grafana模板”主题中,我们将深入探讨如何利用...
在IT行业中,Kubernetes(简称K8s)已经成为容器编排和管理的首选平台,而Java作为广泛应用的编程语言,其在K8s环境中的应用是企业级微服务架构的关键部分。本文将深入探讨如何利用Java进行K8s环境的日常操作与运维...
k8s集群pod经常重启问题排查总结
### kubeadm初始化k8s证书过期解决方案 #### 概述 Kubernetes(简称k8s)作为当前主流的容器编排工具之一,在实际部署过程中常常采用kubeadm进行快速部署与管理。然而,在长期运行的过程中,kubeadm初始化时生成的...