如何为运行中的Kubernetes pod打补丁?

如何为运行中的Kubernetes pod打补丁?

比如说,假设你部署了一个含有Nginx容器的pod,但随后又想把Regis和MySQL容器添加进来。你无需把一切拆除下来并重新调整配置文件,只需运行patch命令即可添加新容器。

下面介绍如何做到这一点。虽然该例子很简单,但会演示patch选项如何与kubectl命令协同使用。

你需要什么?

完成这项工作只需要运行中的Kubernetes集群。

想搞清楚如何部署集群,请查看这篇教程:《如何在Ubuntu服务器上部署Kubernetes集群?》。一旦启动并运行了集群,我们可以继续下一步了。

如何部署Kubernetes服务?

我们要做的第一件事是部署Kubernetes服务。使用以下命令创建一个新目录:

mkdir ~/patch-demo 

使用以下命令进入到该新目录:

cd ~/patch-demo 

现在,为含有带基本模板的Nginx和两个副本的服务部署创建一个YAML文件。使用以下命令创建该文件:

nano deployment-patch.yaml 

在该文件中,粘贴以下内容:

apiVersion: apps/v1 # for versions before 1.9.0 use apps/v1beta2 
kind: Deployment 
metadata: 
  name: patch-demo 
spec: 
  replicas: 2 
  selector: 
    matchLabels: 
      app: nginx 
  template: 
    metadata: 
      labels: 
        app: nginx 
    spec: 
      containers: 
      - name: patch-demo-ctr 
        image: nginx 
      tolerations: 
      - effect: NoSchedule 
        key: dedicated 
        value: test-team 

保存并关闭文件。使用以下命令部署该配置:

kubectl apply -f deployment-patch.yaml 

现在你可以通过执行以下命令看到该pod处于运行中:

kubectl get pods 

该patch-demo补丁将被列为运行中(图A)。

如何为运行中的Kubernetes pod打补丁?
图A. 我们的Kubernetes patch-demo pod已启动并在运行中

如何为运行中的服务打补丁?

现在,我们将创建一个战略性合并补丁文件,该文件将为pod添加Redis容器。使用以下命令创建补丁文件:

nano patch-file.yaml 

在该文件中,粘贴以下内容:

spec: 
  template: 
    spec: 
      containers: 
      - name: patch-demo-ctr-2 
        image: redis 

保存并关闭文件。

为了给运行中的服务打补丁,执行以下命令:

kubectl patch deployment patch-demo --patch "$(cat patch-file.yaml)" 

该实例中发生的是,部署将终止旧pod,创建新pod。

你可以继续这一步。比如说,假设你想把MySQL添加进来。用以下命令创建另一个补丁文件:

nano patch-file-2.yaml 

在该文件中,粘贴以下内容:

spec: 
  template: 
    spec: 
      containers: 
      - name: patch-demo-ctr-3 
        image: mysql 

保存并关闭文件,重新运行patch命令,就像这样:

kubectl patch deployment patch-demo --patch "$(cat patch-file-2.yaml)" 

如果你执行该命令:

kubectl get deployment patch-demo --output yaml 

会看到Nginx、Redis和MySQL都在pod中(图B)。

如何为运行中的Kubernetes pod打补丁?

图B. 我们的Kubernetes pod现包括所有三个映像

对于该补丁系统,你无法做到的一件事就是为pod扩增副本的数量。为此,你要使用scale命令,就像这样:

kubectl scale --replicas=4 deployment patch-demo 

或者你可以把它缩减至0来删除pod,就像这样:

kubectl scale --replicas=0 deployment patch-demo 

相关推荐