Jac*_*oMQ 2 kubernetes kubectl
当我使用“kubectl patch”删除数组中的特定对象时,我需要先检查该特定对象的索引,然后使用json/yaml路径进行kubectl patch。
例如,我有一个资源包含多个端口对象:
spec:
clusterIP: 100.12.143.76
externalTrafficPolicy: Cluster
ports:
- name: object1
nodePort: 30681
port: 1234
protocol: TCP
targetPort: 1234
- name: object2
nodePort: 31805
port: 9876
protocol: TCP
targetPort: 9876
Run Code Online (Sandbox Code Playgroud)
如果我需要删除端口中的“object1”,这是我现在使用的命令(kong-proxy 是该服务资源的名称):
kubectl patch service kong-proxy --type=json -p='[{"op": "remove", "path": "/spec/ports/0"}]' -n kong
Run Code Online (Sandbox Code Playgroud)
通过执行上面的命令,它会删除索引“0”处名为“object1”的对象。
但这需要人提前知道正确的索引号,如果数组中的对象太多,将很难管理和计算索引。
因此,我想知道如果不编写单独的 bash 脚本,是否可以删除带有标识符的对象。
如:
kubectl patch service kong-proxy --type=json -p='[{"op": "remove", "path": "/spec/ports/{name:object1}"}]' -n kong
Run Code Online (Sandbox Code Playgroud)
恐怕这是不可能的。该kubectl patch --type=json命令在底层使用JSON Patch,而后者又使用JSON Pointer。JSON 指针标准非常简单,不提供过滤/匹配功能。
您可以做的解决方法是在调用之前使用jq查找数组索引kubectl patch:
INDEX=$(kubectl get svc kong-proxy -n kong -o json | jq '.spec.ports | map(.name == "object1") | index(true)')
kubectl patch svc kong-proxy --type=json -p="[{'op': 'remove', 'path': '/spec/ports/$INDEX'}]" -n kong
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
2578 次 |
| 最近记录: |