k8s 创建job 执行oc命令 删除/操作宿主机内pod

2024-06-10 05:38

本文主要是介绍k8s 创建job 执行oc命令 删除/操作宿主机内pod,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

  1. 制作job 所使用的的容器 Dockerfile
FROM xxx.xxx.com/alpine:3.9
COPY glibd-2.23-r3.apk /opt/glibd-2.23-r3.apk
COPY ./ssh_config /etc/ssh/
COPY clock /etc/sysconfig/clockRUN echo "xxx.xxx.com/alpine/v3.9/main" >/etc/apk/repositories && \echo "xxx.xxx.com/alpine/v3.9/main" >/etc/apk/repositories && \apk add --no-cache sshpass openssh-client grep bash bash-doc bash-completion zip && \apk --allow-untrusted --force add /opt/glibc-2.23-r3.apk && \mkdir -p /root/.ssh && \rm /opt/glibc-2.23-r3.apk && \rm -rf /var/cache/apk/*COPY config /root/.ssh
copy delete_pod.sh \xxx.sh \/opt/

2.删除宿主机pod脚本

#!/bin/bashset -xif [ -f "/host/bin/oc_ori" ]; thenkubectl=/host/bin/oc_ori
elsekubectl=/host/bin/oc
fifunction check_kubectl() {echo "Info:check whether kubectl exists"for i in {1..20}; doif [ -f "$kubectl" ]; then return 0; else sleep10; fidoneecho "failed"return 1
}function delete_pod() {echo "get pod"names=`${kubectl} get deployment -n xxxxx-base | grep -i "ssssssxxxxx" | awk '{print $1}'`# 后续自己发挥
}

3.k8s job yaml文件

apiVersion: batch/v1
kind: Job
metadata:name: upgrade-jobnamespace: cl-baseannotations:"helm.sh/hook": post-install,post-upgrade"helm.sh/hook-weight": "90""helm.sh/hook-delete-policy": before-hook-creation
spec:backoffLimit: 6completions: 1parallelism: 1template:metadata:name: upgrade-jobspec:serviceAccountName: cl-base-adminnodeSelector:nodeType: controllercontainers:- image: os-harbor-svc.default.svc.cloudos:443/helm/dbs/init-job:{{ .Values.initImage.tag }}imagePullPolicy: Alwayscommand:- "/bin/bash"args:- "/opt/upgrade_delete_pod.sh"name: upgrade-jobresources:limits:cpu: 4memory: 8192Mirequests:cpu: 2memory: 4096MiterminationMessagePath: /dev/termination-logterminationMessagePolicy: FilevolumeMounts:- name: tz-configmountPath: /etc/localtime- name: host-binmountPath: /host/bin- name: host-kube-configmountPath: /root/.kubednsPolicy: ClusterFirstrestartPolicy: NeverschedulerName: default-schedulersecurityContext: {}terminationGracePeriodSeconds: 30volumes:- name: tz-confighostPath:path: /etc/localtime- name: host-binhostPath:path: /usr/bin- name: host-kube-confighostPath:path: /root/.kube/

这篇关于k8s 创建job 执行oc命令 删除/操作宿主机内pod的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1047340

相关文章

Java操作Word文档的全面指南

《Java操作Word文档的全面指南》在Java开发中,操作Word文档是常见的业务需求,广泛应用于合同生成、报表输出、通知发布、法律文书生成、病历模板填写等场景,本文将全面介绍Java操作Word文... 目录简介段落页头与页脚页码表格图片批注文本框目录图表简介Word编程最重要的类是org.apach

Mysql实现范围分区表(新增、删除、重组、查看)

《Mysql实现范围分区表(新增、删除、重组、查看)》MySQL分区表的四种类型(范围、哈希、列表、键值),主要介绍了范围分区的创建、查询、添加、删除及重组织操作,具有一定的参考价值,感兴趣的可以了解... 目录一、mysql分区表分类二、范围分区(Range Partitioning1、新建分区表:2、分

MySQL 删除数据详解(最新整理)

《MySQL删除数据详解(最新整理)》:本文主要介绍MySQL删除数据的相关知识,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录一、前言二、mysql 中的三种删除方式1.DELETE语句✅ 基本语法: 示例:2.TRUNCATE语句✅ 基本语

Python实现对阿里云OSS对象存储的操作详解

《Python实现对阿里云OSS对象存储的操作详解》这篇文章主要为大家详细介绍了Python实现对阿里云OSS对象存储的操作相关知识,包括连接,上传,下载,列举等功能,感兴趣的小伙伴可以了解下... 目录一、直接使用代码二、详细使用1. 环境准备2. 初始化配置3. bucket配置创建4. 文件上传到os

mysql表操作与查询功能详解

《mysql表操作与查询功能详解》本文系统讲解MySQL表操作与查询,涵盖创建、修改、复制表语法,基本查询结构及WHERE、GROUPBY等子句,本文结合实例代码给大家介绍的非常详细,感兴趣的朋友跟随... 目录01.表的操作1.1表操作概览1.2创建表1.3修改表1.4复制表02.基本查询操作2.1 SE

一文详解Git中分支本地和远程删除的方法

《一文详解Git中分支本地和远程删除的方法》在使用Git进行版本控制的过程中,我们会创建多个分支来进行不同功能的开发,这就容易涉及到如何正确地删除本地分支和远程分支,下面我们就来看看相关的实现方法吧... 目录技术背景实现步骤删除本地分支删除远程www.chinasem.cn分支同步删除信息到其他机器示例步骤

python删除xml中的w:ascii属性的步骤

《python删除xml中的w:ascii属性的步骤》使用xml.etree.ElementTree删除WordXML中w:ascii属性,需注册命名空间并定位rFonts元素,通过del操作删除属... 可以使用python的XML.etree.ElementTree模块通过以下步骤删除XML中的w:as

Golang如何对cron进行二次封装实现指定时间执行定时任务

《Golang如何对cron进行二次封装实现指定时间执行定时任务》:本文主要介绍Golang如何对cron进行二次封装实现指定时间执行定时任务问题,具有很好的参考价值,希望对大家有所帮助,如有错误... 目录背景cron库下载代码示例【1】结构体定义【2】定时任务开启【3】使用示例【4】控制台输出总结背景

c++中的set容器介绍及操作大全

《c++中的set容器介绍及操作大全》:本文主要介绍c++中的set容器介绍及操作大全,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录​​一、核心特性​​️ ​​二、基本操作​​​​1. 初始化与赋值​​​​2. 增删查操作​​​​3. 遍历方

MySQL追踪数据库表更新操作来源的全面指南

《MySQL追踪数据库表更新操作来源的全面指南》本文将以一个具体问题为例,如何监测哪个IP来源对数据库表statistics_test进行了UPDATE操作,文内探讨了多种方法,并提供了详细的代码... 目录引言1. 为什么需要监控数据库更新操作2. 方法1:启用数据库审计日志(1)mysql/mariad