有时往k8s集群里部署一堆服务的时候,须要拷贝一堆yaml文件,固然还有其余方式部署,例如经过创建一个一个的流水线等方式,可是这太慢了,虽然是一劳永逸,可是若是说仅仅是部署一次那就可太费劲了,那么直接拷贝一堆yaml文件就简单了许多,可是若是以前的环境中镜像地址是走的内网,而如今放到另外一个环境中,网络不通时,就须要更改其中的镜像地址了python
假如以前的网络环境到阿里云内网镜像地址是通的,也就是长这样:registry-vpc.cn-beijing.aliyuncs.com/xxxx/xxxxx
docker
而后如今要部署到华为云上时,直接启动yaml文件确定是起不来的,须要修改下此镜像地址,改成:registry.cn-beijing.aliyuncs.com/xxxx/xxxx
,改为这样就能够拉了。数组
那么该如何实现呢?markdown
下面这段代码是经过k8s的接口,先去查当前命名空间下都有哪些服务,而后把这些服务都写道一个数组里,而后再去迭代这个数组,而后去修改整个命名空间下的全部pod的镜像地址网络
import re
from kubernetes import client, config
class deployServer:
def __init__(self, kubeconfig):
self.kubeconfig = kubeconfig
config.kube_config.load_kube_config(config_file=self.kubeconfig)
self._AppsV1Api = client.AppsV1Api()
# 这俩暂时用不到
# self._CoreV1Api = client.CoreV1Api()
# self._ExtensionsV1beta1Api = client.ExtensionsV1beta1Api()
def list_deploy(self, namespace_name):
''' :param namespace_name: 指定命名空间 :return: 返回一个deployment的列表 '''
deploySubj = self._AppsV1Api.list_namespaced_deployment(namespace_name)
return [ subj.metadata.name for subj in deploySubj.items ]
def patchMultiDeploy(self, namespace_name, newimgdomain):
for i in self.list_deploy(namespace_name):
self.patchDeploy(namespace_name, i, newimgdomain)
print("{}: {} patch success.".format(namespace_name, i))
def patchDeploy(self, deploy_namespace, deploy_name, newimgdomain, keyword='vpc'):
img_addr_rule = r"[^?]{1,}\.[^?]{1,}\.com(\/.*\:.*)"
img_domain_rule = r"([^?]{1,}\.[^?]{1,}\.com).*\:.*"
old_deploy = self._AppsV1Api.read_namespaced_deployment(
name=deploy_name,
namespace=deploy_namespace,
)
old_deploy_container = old_deploy.spec.template.spec.containers
# 迭代deployment的列表,获取deployment的名称以及它所在索引位置
for i, k in enumerate(old_deploy_container):
# 捕获处域名以外的镜像地址
oldImgAddr = re.findall(img_addr_rule, old_deploy_container[i].image)[0]
# 捕获镜像地址的域名,也能够不获取,可是获取会更准确些
oldImgDoamin = re.findall(img_domain_rule, old_deploy_container[i].image)[0]
# 符合条件的才会进行替换
if keyword in oldImgDoamin:
old_deploy_container[i].image = newimgdomain + oldImgAddr
self._AppsV1Api.patch_namespaced_deployment(
name=deploy_name,
namespace=deploy_namespace,
body=old_deploy
)
return
if __name__ == '__main__':
kubeconfig = r'kubeconfig/config'
k8s = deployServer(kubeconfig)
# 指定服务所在命名空间
namespace = 'ops-logging'
# 指定要替换的镜像的域名
img = 'docker.elastic.co'
k8s.patchMultiDeploy(namespace, img)
复制代码
注意这里须要指定kubeconfig
文件dom
上面那个是直接调接口,经过patch来进行修改,下面是直接修改yaml文件ui
import os
import re
def modifyImagesFromFile(originpath, src_img, dst_img):
_re_rule = r".*image: ([^?]{1,}\.[^?]{1,}\.com).*\:.*"
if os.path.isdir(originpath):
filesubj = os.walk(originpath)
filename = []
# 迭代指定路径下的全部文件
for path, _, file in filesubj:
# 把全部的文件拼成一个完整的路径,并写道一个列表里
filename = [os.path.join(path, f) for f in file]
if filename:
for f in filename:
with open(f, 'r+', encoding='utf-8') as fr:
fr_data = fr.read()
replace_list = re.findall(_re_rule, fr_data)
if replace_list:
for pattern in replace_list:
if src_img in pattern:
# 把匹配到的内容进行替换
fr_data = fr_data.replace(pattern, dst_img)
fr.seek(0)
fr.write(fr_data)
print("{} replace success".format(f))
else:
print("Unknown")
else:
print("{} not a directory".format(originpath))
if __name__ == '__main__':
originpath = r"E:\项目\DEV环境\sg-saas-pro-hbali\gldsg-gvs\deployments"
dst_img = 'registry.cn-beijing.aliyuncs.com'
src_img = 'registry-vpc.cn-beijing.aliyuncs.com'
modifyImagesFromFile(originpath)
复制代码
注意: 须要把全部的deployment文件都放到一个目录里阿里云
若是是在线修改的话,就用上面调k8s接口经过patch来修改,直接粘贴复制,指定好命名空间,指定好kubeconfig
的文件位置便可
若是是把全部的yaml文件都down下来了,那么就直接迭代目录下的全部文件,经过正则去捕获镜像地址,而后进行替换,再写入源文件就能够了。spa