- 第四种是apply patch:主要是指kubernetes 1.14版本开始的server-side apply,由APIServer 做 diff 和 merge 操作,很多原本易碎的现象都得到了解决(例如controller和kubectl都在更新),另外要格外注意的是:1.14版本默认是不开启server-side apply特性的,具体的开启操作在下面会详细讲解;
- 以上是对kubernetes四种patch的简介,讲得很浅,如果您想深入了解每种patch,建议参阅官方资料,接下来咱们聚焦java客户端对这些patch能力的实现;
[](()源码下载
- 如果您不想编码,可以在GitHub下载所有源码,地址和链接信息如下表所示(https://github.com/zq2599/blog_demos):
| 名称 | 链接 | 备注 |
| :-- | :-- | :-- |
| 项目主页 | https://github.com/zq2599/blog_demos | 该项目在GitHub上的主页 |
| git仓库地址(https) | https://github.com/zq2599/blog_demos.git | 该项目源码的仓库地址,https协议 |
| git仓库地址(ssh) | git@github.com:zq2599/blog_demos.git | 该项目源码的仓库地址,ssh协议 |
- 这个git项目中有多个文件夹,本章的应用在kubernetesclient文件夹下,如下图红框所示:
[](()实战步骤概述
-
接下来会创建一个springboot工程(该工程是kubernetesclient的子工程),针对四种patch咱们都有对应的操作;
-
每种patch都会准备对应的json文件,提前将这些文件的内容保存在字符串变量中,在程序里用kubernetes客户端的patch专用API,将此json字符串发送出去,流程简图如下:
- 编码完成后,就来动手验证功能,具体操作如下:
-
部署名为patch的deployment,这里面是咱们编码的SpringBoot工程,提供多个web接口;
-
浏览器访问/patch/deploy接口,就会创建名为test123的deployment,这个deployment里面是个nginx,接下来的patch操作都是针对这个名为test123的deployment;
-
浏览器访问test123的nginx服务,确保部署成功了;
-
浏览器访问/patch/json接口,该接口会修改test123的一个属性:terminationGracePeriodSeconds
-
浏览器访问/patch/fullmerge接口,该接口会提交全量merge请求,修改内容很少,仅增加了一个label属性;
-
接下来是对比merge patch和strategic merge patch区别,分别访问/patch/partmerge和/patch/strategic这两个接口,其实它们操作的是同一段patch内容(一个新的container),结果merge patch会替换原有的continer,而strategic merge patch不会动原有的container,而是新增container,导致test123这个deployment下面的pod从一个变为两个;
-
最后是apply yaml patch,访问接口/patch/apply,会将nginx容器的标签从1.18.0改为1.19.1,咱们只要在浏览器访问test123里面的nginx服务就能确定是否修改生效了;
[](()准备工作
准备工作包括创建工程、编写辅助功能代码、初始化代码等:
- 打开[《Kubernetes官方java客户端之一:准备 》](()一文创建的项目kubernetesclient,新增名为patch的子工程,pom.xml内容如下:
<project xmlns=“http://maven.apache.org/POM/4.0.0” xmlns:xsi=“http://www.w3.org/2001/XMLSchema-instance”
xsi:schemaLocation=“http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd”>
4.0.0
com.bolingcavalry
kubernetesclient
1.0-SNAPSHOT
…/pom.xml
com.bolingcavalry
patch
0.0.1-SNAPSHOT
patch
patch demo
jar
org.springframework.boot
spring-boot-starter-web
org.springframework.boot
spring-boot-starter-json
org.springframework.boot
spring-boot-starter-actuator
org.projectlombok
lombok
true
io.kubernetes
client-java
org.springframework.boot