
เดเดดเตเดคเดฟ เดเตเดฑเดเตเดเต เดธเดฎเดฏเด เดเดดเดฟเดเตเดเต , เดเดพเตป jsonnet เดเด gitlab เดเด เดธเดฎเตผเดคเตเดฅเดฎเดพเดฏเดฟ เดเตเดเดพเดฐเตเดฏเด เดเตเดฏเตเดฏเตเดจเตเดจเดฟเดเดคเตเดคเต, เดชเตเดชเตเดชเต เดฒเตเดจเตเดเตพ เดคเตเตผเดเตเดเดฏเดพเดฏเตเด เดจเดฒเตเดฒเดคเดพเดฃเตเดจเตเดจเตเด เดเดจเตเดจเดพเตฝ เด เดจเดพเดตเดถเตเดฏเดฎเดพเดฏเดฟ เดธเดเตเดเตเตผเดฃเตเดฃเดตเตเด เด เดธเตเดเดฐเตเดฏเดฎเตเดณเตเดณเดคเตเดฎเดพเดฃเตเดจเตเดจเต เดเดพเตป เดฎเดจเดธเตเดธเดฟเดฒเดพเดเตเดเดฟ.
เดฎเดฟเดเตเด เดเตเดธเตเดเดณเดฟเดฒเตเด, เดเดฐเต เดธเดพเดงเดพเดฐเดฃ เดเดพเดธเตเดเต เดเดตเดถเตเดฏเดฎเดพเดฃเต: "YAML เดธเตเดทเตเดเดฟเดเตเดเต เดเตเดฌเตผเดจเตเดฑเตเดฑเดธเดฟเตฝ เดเดเตเด." เดฏเดฅเดพเตผเดคเตเดฅเดคเตเดคเดฟเตฝ, เดเดคเดพเดฃเต เดเตผเดเต เดธเดฟเดกเดฟ เดถเตเดฐเดฆเตเดงเตเดฏเดฎเดพเดฏเดฟ เดเตเดฏเตเดฏเตเดจเตเดจเดคเต.
เดเดฐเต Git เดฑเดฟเดชเตเดชเตเดธเดฟเดฑเตเดฑเดฑเดฟ เดเดฃเดเตเดฑเตเดฑเตเดเตเดฏเตเดฏเดพเดจเตเด เด เดคเดฟเดจเตเดฑเต เด เดตเดธเตเดฅ เดเตเดฌเตผเดจเตเดฑเตเดฑเดธเดฟเดฒเตเดเตเดเต เด เดฏเดฏเตเดเตเดเดพเดจเตเด Argo CD เดจเดฟเดเตเดเดณเต เด เดจเตเดตเดฆเดฟเดเตเดเตเดจเตเดจเต. เดธเตเดฅเดฟเดฐเดธเตเดฅเดฟเดคเดฟเดฏเดพเดฏเดฟ, เดจเดฟเดฐเดตเดงเดฟ เดคเดฐเดคเตเดคเดฟเดฒเตเดณเตเดณ เดเดชเตเดฒเดฟเดเตเดเตเดทเดจเตเดเตพเดเตเดเตเดณเตเดณ เดชเดฟเดจเตเดคเตเดฃเดฏเตเดฃเตเดเต: เดเดธเตเดฑเตเดฑเดฎเตเดธเต, เดนเตเตฝเด เดเดพเตผเดเตเดเตเดเตพ, เดเตโเดธเตเดฃเดฑเตเดฑเต, เดฌเตเดฏเตผ เดเตเดธเตเดจเตเดฑเตเดฑเต เด เดฒเตเดฒเตเดเตเดเดฟเตฝ YAML/JSON เดฎเดพเดจเดฟเดซเตเดธเตเดฑเตเดฑเตเดเดณเตเดณเตเดณ เดกเดฏเดฑเดเตเดเดฑเดฟเดเตพ.
เด เดธเตเดฑเตเดฑเต เดฎเดฟเดเตเด เดเดชเดฏเตเดเตเดคเดพเดเตเดเตพเดเตเดเตเด เดฎเดคเดฟเดฏเดพเดเตเด, เดเดจเตเดจเดพเตฝ เดเดฒเตเดฒเดพเดตเตผเดเตเดเตเด เด เดฒเตเดฒ. เดเดฒเตเดฒเดพเดตเดฐเตเดเตเดฏเตเด เดเดตเดถเตเดฏเดเตเดเตพ เดจเดฟเดฑเดตเตเดฑเตเดฑเตเดจเตเดจเดคเดฟเดจเดพเดฏเดฟ, เดเตผเดเต เดธเดฟเดกเดฟเดเตเดเต เดเดทเตโเดเดพเดจเตเดธเตเดค เดเตเดณเดฟเดเดเต เดเดชเดฏเตเดเดฟเดเตเดเดพเดจเตเดณเตเดณ เดเดดเดฟเดตเตเดฃเตเดเต.
เดเดจเตเดจเดพเดฎเดคเดพเดฏเดฟ, เดชเดฟเดจเตเดคเตเดฃ เดเตเตผเดเตเดเตเดจเตเดจเดคเดฟเดจเตเดณเตเดณ เดธเดพเดงเตเดฏเดคเดฏเดฟเตฝ เดเดจเดฟเดเตเดเต เดคเดพเตฝเดชเตเดชเดฐเตเดฏเดฎเตเดฃเตเดเต ะธ , เดฎเตเตป เดฒเตเดเดจเดคเตเดคเดฟเตฝ เดชเตเตผเดฃเตเดฃเดฎเดพเดฏเดฟ เดเตผเดเตเด เดเตเดฏเตเดคเดต.
เดจเดฟเดเตเดเตพ เดเตเตบเดซเดฟเดเดฑเตเดทเตป เดเดฐเดเดญเดฟเดเตเดเตเดจเตเดจเดคเดฟเดจเต เดฎเตเดฎเตเดชเต, เดเตผเดเต เดธเดฟเดกเดฟ เดเดเตเดเดจเต เดชเตเดฐเดตเตผเดคเตเดคเดฟเดเตเดเตเดจเตเดจเตเดตเตเดจเตเดจเต เดจเดฟเดเตเดเตพ เดเดฆเตเดฏเด เดฎเดจเดธเตเดธเดฟเดฒเดพเดเตเดเตเดฃเตเดเดคเตเดฃเตเดเต.
เดเตเตผเดคเตเดค เดเดฐเต เดเดชเตเดฒเดฟเดเตเดเตเดทเดจเตเด เดฐเดฃเตเดเต เดเดเตเดเดเตเดเดณเตเดฃเตเดเต:
- เดเดตเดฏเต โ เดตเดฟเดจเตเดฏเดพเดธเดคเตเดคเดฟเดจเต เดฎเตเดฎเตเดชเตเดณเตเดณ เดชเตเดฐเดพเดฐเดเดญ เดคเดฏเตเดฏเดพเดฑเตเดเตเดชเตเดชเต, เดเดตเดฟเดเต เดเดจเตเดคเตเด เดธเดเดญเดตเดฟเดเตเดเดพเด: เดกเดฟเดชเตปเดกเตปเดธเดฟเดเตพ เดกเตเตบเดฒเตเดกเต เดเตเดฏเตเดฏเตเด, เดฐเดนเดธเตเดฏเดเตเดเตพ เด เตบเดชเดพเดเตเดเต เดเตเดฏเตเดฏเตเด เดเดจเตเดจเดฟเดตเดฏเตเด เดฎเดฑเตเดฑเตเด.
- เดเดจเดฑเตเดฑเตเดฑเต โ เดจเตเดฐเดฟเดเตเดเต เดฎเดพเดจเดฟเดซเตเดธเตเดฑเตเดฑเต เดเดจเดฑเตเดทเตป เดเดฎเดพเตปเดกเต เดเดเตเดธเดฟเดเตเดฏเตเดเตเดเต เดเตเดฏเตเดฏเตเดจเตเดจเต, เดเดเตเดเตเดชเตเดเตเดเต เดเดฐเต เดธเดพเดงเตเดตเดพเดฏ YAML เดธเตเดเตเดฐเตเด เดเดฏเดฟเดฐเดฟเดเตเดเดฃเด, เดเดคเดพเดฃเต เดเตเดฒเดธเตเดฑเตเดฑเดฑเดฟเดฒเตเดเตเดเต เดชเตเดฐเดฏเตเดเดฟเดเตเดเตเดจเตเดจเดคเต.
เดนเตเตฝเด เดเตพเดชเตเดชเตเดเต เดเดคเต เดคเดฐเดคเตเดคเดฟเดฒเตเดณเตเดณ เดเดชเตเดฒเดฟเดเตเดเตเดทเดจเดฟเดฒเตเด เดเตผเดเต เด เดธเดฎเตเดชเดจเด เดชเตเดฐเดฏเตเดเดฟเดเตเดเตเดจเตเดจเต เดเดจเตเดจเดคเดพเดฃเต เดถเตเดฐเดฆเตเดงเตเดฏเดฎเดพเดฏ เดเดพเดฐเตเดฏเด. เด เดคเดพเดฏเดคเต, เดเตผเดเต เดธเดฟเดกเดฟเดฏเดฟเตฝ เดนเตเตฝเด เดเตเดฒเดธเตเดฑเตเดฑเดฑเดฟเดฒเตเดเตเดเต เดฑเดฟเดฒเตเดธเตเดเตพ เดตเดฟเดจเตเดฏเดธเดฟเดเตเดเตเดจเตเดจเดฟเดฒเตเดฒ, เดฎเดฑเดฟเดเตเดเต เดฎเดพเดจเดฟเดซเตเดธเตเดฑเตเดฑเตเดเตพ เดธเตเดทเตเดเดฟเดเตเดเดพเตป เดฎเดพเดคเตเดฐเดฎเดพเดฃเต เดเดชเดฏเตเดเดฟเดเตเดเตเดจเตเดจเดคเต.
เด เดคเดฟเดจเตเดฑเต เดญเดพเดเดฎเดพเดฏเดฟ, เดเตผเดเตเดฏเตเดเตเดเต เดนเตเตฝเด เดนเตเดเตเดเตเดเตพ เดจเตเดฑเตเดฑเตเดตเต เดเดฏเดฟ เดชเตเดฐเตเดธเดธเตเดธเต เดเตเดฏเตเดฏเดพเตป เดเดดเดฟเดฏเตเด, เดเดคเต เดฑเดฟเดฒเตเดธเตเดเตพ เดชเตเดฐเดฏเตเดเดฟเดเตเดเตเดจเตเดจเดคเดฟเดจเตเดฑเต เดฏเตเดเตเดคเดฟ เดฒเดเดเดฟเดเตเดเดพเดคเดฟเดฐเดฟเดเตเดเดพเตป เด เดจเตเดตเดฆเดฟเดเตเดเตเดจเตเดจเต.
เดเตเดฏเตเดฌเดฟเดเดธเดฟ
jsonnet เดเดชเดฏเตเดเดฟเดเตเดเตเดณเตเดณ เดเดชเตเดฒเดฟเดเตเดเตเดทเดจเตเดเตพ เดธเตเดเดฐเตเดฏเดชเตเดฐเดฆเดฎเดพเดฏเดฟ เดตเดฟเดตเดฐเดฟเดเตเดเดพเตป Qbec เดจเดฟเดเตเดเดณเต เด เดจเตเดตเดฆเดฟเดเตเดเตเดจเตเดจเต, เดเตเดเดพเดคเต เดนเตเตฝเด เดเดพเตผเดเตเดเตเดเตพ เดฑเตเตปเดกเตผ เดเตเดฏเตเดฏเดพเดจเตเดณเตเดณ เดเดดเดฟเดตเตเด เดเดฃเตเดเต, เดเตเดเดพเดคเต Argo CD เดจเต เดธเดพเดงเดพเดฐเดฃเดฏเดพเดฏเดฟ Helm เดนเตเดเตเดเตเดเตพ เดชเตเดฐเตเดธเดธเตเดธเต เดเตเดฏเตเดฏเดพเตป เดเดดเดฟเดฏเตเดฎเตเดจเตเดจเดคเดฟเดจเดพเตฝ, Argo CD เดเดชเดฏเตเดเดฟเดเตเดเต เด เดธเดตเดฟเดถเตเดทเดค เดเดชเดฏเตเดเดฟเดเตเดเตเดจเตเดจเดคเต เดเตเดเตเดคเตฝ เดถเดฐเดฟเดฏเดพเดฏ เดซเดฒเดเตเดเตพ เดจเตเดเดพเตป เดจเดฟเดเตเดเดณเต เด เดจเตเดตเดฆเดฟเดเตเดเตเดจเตเดจเต.
qbec เดชเดฟเดจเตเดคเตเดฃ argocd-เดฒเตเดเตเดเต เดเตเตผเดเตเดเตเดจเตเดจเดคเดฟเดจเต เดจเดฟเดเตเดเตพเดเตเดเต เดฐเดฃเตเดเต เดเดพเดฐเตเดฏเดเตเดเตพ เดเดตเดถเตเดฏเดฎเดพเดฃเต:
- เดเตผเดเต เดธเดฟเดกเดฟ เดเตเตบเดซเดฟเดเดฑเดฟเตฝ, เดจเดฟเดเตเดเดณเตเดเต เดเดทเตโเดเดพเดจเตเดธเตเดค เดชเตเดฒเดเดฟเดจเตเด เดฎเดพเดจเดฟเดซเตเดธเตเดฑเตเดฑเตเดเตพ เดธเตเดทเตโเดเดฟเดเตเดเตเดจเตเดจเดคเดฟเดจเตเดณเตเดณ เดเดฎเดพเตปเดกเตเดเดณเตเด เดจเดฟเตผเดตเดเดฟเดเตเดเดฟเดฐเดฟเดเตเดเดฃเด.
- เดเดตเดถเตเดฏเดฎเดพเดฏ เดฌเตเดจเดฑเดฟเดเตพ เดเดฟเดคเตเดฐเดคเตเดคเดฟเตฝ เดฒเดญเตเดฏเดฎเดพเดฏเดฟเดฐเดฟเดเตเดเดฃเด เดเตผเดเตเดธเดฟเดกเดฟ-เดฑเดฟเดชเตเดชเต-เดธเตเตผเดตเตผ.
เดเดฆเตเดฏ เดเตเดฎเดคเดฒ เดตเดณเดฐเต เดฒเดณเดฟเดคเด:
# cm.yaml
data:
configManagementPlugins: |
- name: qbec
generate:
command: [sh, -xc]
args: ['qbec show "$ENVIRONMENT" -S --force:k8s-namespace "$ARGOCD_APP_NAMESPACE"'](เดเตเด เดเดตเดฏเต เดเดชเดฏเตเดพเดเดฟเดเตเดเดฟเดเตเดเดฟเดฒเตเดฒ)
$ kubectl -n argocd patch cm/argocd-cm -p "$(cat cm.yaml)"เดฌเตเดจเดฑเดฟเดเตพ เดเตเตผเดเตเดเดพเตป เดจเดฟเตผเดฆเตเดฆเตเดถเดฟเดเตเดเตเดจเตเดจเต , เด เดฒเตเดฒเตเดเตเดเดฟเตฝ เดเดชเดฏเตเดเดฟเดเตเดเตเด :
# deploy.yaml
spec:
template:
spec:
# 1. Define an emptyDir volume which will hold the custom binaries
volumes:
- name: custom-tools
emptyDir: {}
# 2. Use an init container to download/copy custom binaries into the emptyDir
initContainers:
- name: download-tools
image: alpine:3.12
command: [sh, -c]
args:
- wget -qO- https://github.com/splunk/qbec/releases/download/v0.12.2/qbec-linux-amd64.tar.gz | tar -xvzf - -C /custom-tools/
volumeMounts:
- mountPath: /custom-tools
name: custom-tools
# 3. Volume mount the custom binary to the bin directory (overriding the existing version)
containers:
- name: argocd-repo-server
volumeMounts:
- mountPath: /usr/local/bin/qbec
name: custom-tools
subPath: qbec
- mountPath: /usr/local/bin/jsonnet-qbec
name: custom-tools
subPath: jsonnet-qbec$ kubectl -n argocd patch deploy/argocd-repo-server -p "$(cat deploy.yaml)"เดเดชเตเดชเตเตพ เดจเดฎเตเดฎเตเดเต เดเดชเตเดฒเดฟเดเตเดเตเดทเตป เดฎเดพเดจเดฟเดซเตเดธเตเดฑเตเดฑเต เดเดเตเดเดจเตเดฏเดพเดฏเดฟเดฐเดฟเดเตเดเตเดฎเตเดจเตเดจเต เดจเตเดเตเดเดพเด:
apiVersion: argoproj.io/v1alpha1
kind: Application
metadata:
name: qbec-app
namespace: argocd
spec:
destination:
namespace: default
server: https://kubernetes.default.svc
project: default
source:
path: qbec-app
plugin:
env:
- name: ENVIRONMENT
value: default
name: qbec
repoURL: https://github.com/kvaps/argocd-play
syncPolicy:
automated:
prune: trueเดเดฐเต เดตเตเดฐเดฟเดฏเดฌเดฟเดณเดฟเตฝ ENVIRONMENT เดฎเดพเดจเดฟเดซเตเดธเตเดฑเตเดฑเตเดเตพ เดธเตเดทเตเดเดฟเดเตเดเตเดฃเตเด เดชเดฐเดฟเดธเตเดฅเดฟเดคเดฟเดฏเตเดเต เดชเตเดฐเต เดเดเตเดเตพ เดเตเดฎเดพเดฑเตเดจเตเดจเต.
เดจเดฎเตเดเตเดเต เดเดคเต เดชเตเดฐเดฏเตเดเดฟเดเตเดเต เดจเดฎเตเดเตเดเต เดเดจเตเดคเดพเดฃเต เดฒเดญเดฟเดเตเดเตเดจเตเดจเดคเตเดจเตเดจเต เดจเตเดเตเดเดพเด:

เดเดชเตเดฒเดฟเดเตเดเตเดทเตป เดตเดฟเดจเตเดฏเดธเดฟเดเตเดเต, เดเตเดณเตเดณเดพเด!
git-crypt
เดจเดฟเดเตเดเดณเตเดเต เดฑเดฟเดชเตเดชเตเดธเดฟเดฑเตเดฑเดฑเดฟเดเตเดเดพเดฏเดฟ เดธเตเดคเดพเดฐเตเดฏเดฎเดพเดฏ เดเตปเดเตเดฐเดฟเดชเตเดทเตป เดธเดเตเดเตเดเดฐเดฟเดเตเดเดพเตป Git-crypt เดจเดฟเดเตเดเดณเต เด เดจเตเดตเดฆเดฟเดเตเดเตเดจเตเดจเต. เดธเตเตปเดธเดฟเดฑเตเดฑเตเดตเต เดกเดพเดฑเตเดฑ เดจเตเดฐเดฟเดเตเดเต git-เตฝ เดธเดเดญเดฐเดฟเดเตเดเตเดจเตเดจเดคเดฟเดจเตเดณเตเดณ เดฒเดณเดฟเดคเดตเตเด เดธเตเดฐเดเตเดทเดฟเดคเดตเตเดฎเดพเดฏ เดฎเดพเตผเดเดฎเดพเดฃเดฟเดคเต.
เดเดฟเดฑเตเดฑเต-เดเตเดฐเดฟเดชเตเดฑเตเดฑเต เดจเดเดชเตเดชเดฟเดฒเดพเดเตเดเตเดจเตเดจเดคเต เดเตเดเตเดคเตฝ เดฌเตเดฆเตเดงเดฟเดฎเตเดเตเดเตเดณเตเดณเดคเดพเดฏเดฟ เดฎเดพเดฑเดฟ.
เดธเตเดฆเตเดงเดพเดจเตเดคเดฟเดเดฎเดพเดฏเดฟ เดจเดฎเตเดเตเดเต เดเตเดฏเตเดฏเดพเตป เดเดดเดฟเดฏเตเด git-crypt unlock เดเดเตเดเดณเตเดเต เดเดทเตโเดเดพเดจเตเดธเตเดค เดชเตเดฒเดเดฟเดจเตเดฑเต init เดเดเตเดเดคเตเดคเดฟเตฝ, เดชเดเตเดทเต เดเดคเต เดตเดณเดฐเต เดธเตเดเดฐเตเดฏเดชเตเดฐเดฆเดฎเดฒเตเดฒ, เดเดพเดฐเดฃเด เดเดคเต เดจเตเดฑเตเดฑเตเดตเต เดตเดฟเดจเตเดฏเดพเดธ เดฐเตเดคเดฟเดเตพ เดเดชเดฏเตเดเดฟเดเตเดเดพเตป เด
เดจเตเดตเดฆเดฟเดเตเดเดฟเดฒเตเดฒ. เดเดฆเดพเดนเดฐเดฃเดคเตเดคเดฟเดจเต, เดนเตเตฝเดฎเดฟเดจเตเดฑเตเดฏเตเด เดเตเดธเตเดฃเดฑเตเดฑเดฟเดจเตเดฑเตเดฏเตเด เดเดพเดฐเตเดฏเดคเตเดคเดฟเตฝ, เดเดชเตเดฒเดฟเดเตเดเตเดทเตป เดเตเตบเดซเดฟเดเดฑเตเดทเตป (เดฎเตเดฒเตเดฏ เดซเดฏเดฒเตเดเตพ เดฎเตเดคเดฒเดพเดฏเดต) เดฒเดณเดฟเดคเดฎเดพเดเตเดเดพเตป เดเดเตเดเดณเต เด
เดจเตเดตเดฆเดฟเดเตเดเตเดจเตเดจ เดเดฐเต เดซเตเดฒเตเดเตเดธเดฟเดฌเดฟเตพ เดเดฟเดฏเตเด เดเดจเตเดฑเตผเดซเตเดธเต เดเดเตเดเตพเดเตเดเต เดจเดทเตโเดเดชเตเดชเตเดเตเด.
เด เดคเตเดเตเดฃเตเดเดพเดฃเต เดเตเดฒเตเดฃเดฟเดเดเต เดธเดฎเดฏเดคเตเดคเต เดถเตเดเดฐเด เดเดฆเตเดฏเดเดเตเดเดคเตเดคเดฟเตฝ เด เดเตเดเดเดฟเดเตเดเดพเตป เดเดพเตป เดเดเตเดฐเดนเดฟเดเตเดเดคเต.
เดถเตเดเดฐเด เดธเดฎเดจเตเดตเดฏเดฟเดชเตเดชเดฟเดเตเดเตเดจเตเดจเดคเดฟเดจเตเดณเตเดณ เดนเตเดเตเดเตเดเดณเตเดจเตเดจเตเด เดตเดฟเดตเดฐเดฟเดเตเดเดพเดจเตเดณเตเดณ เดเดดเดฟเดตเต เดเดชเตเดชเตเตพ เดเตผเดเต เดธเดฟเดกเดฟ เดจเตฝเดเตเดจเตเดจเดฟเดฒเตเดฒ เดเดจเตเดจเดคเดฟเดจเดพเตฝ, เดเดฟเดฑเตเดฑเต เดเดฎเดพเตปเดกเดฟเดจเต เดชเดเดฐเด เดตเดฏเตเดเตเดเตเดจเตเดจ เดเดฐเต เดคเดจเตเดคเตเดฐเดชเดฐเดฎเดพเดฏ เดทเตเตฝ เดธเตเดเตเดฐเดฟเดชเตเดฑเตเดฑเต เดเดชเดฏเตเดเดฟเดเตเดเต เดเดเตเดเตพเดเตเดเต เด เดชเดฐเดฟเดฎเดฟเดคเดฟ เดฎเดฑเดฟเดเดเดเตเดเตเดฃเตเดเดฟ เดตเดจเตเดจเต:
#!/bin/sh
$(dirname $0)/git.bin "$@"
ec=$?
[ "$1" = fetch ] && [ -d .git-crypt ] || exit $ec
GNUPGHOME=/app/config/gpg/keys git-crypt unlock 2>/dev/null
exit $ecเดเตผเดเต เดธเดฟเดกเดฟ เดจเดฟเตผเดตเดนเดฟเดเตเดเตเดจเตเดจเต git fetch เดตเดฟเดจเตเดฏเดพเดธ เดชเตเดฐเดตเตผเดคเตเดคเดจเดคเตเดคเดฟเดจเต เดฎเตเดฎเตเดชเต เดเดฐเต เดคเดตเดฃเดฏเตเด. เด เดเดฎเดพเตปเดกเดพเดฃเต เดเดเตเดเตพ เดเดเตเดธเดฟเดเตเดฏเตเดทเตป เดจเตฝเดเตเดจเตเดจเดคเต git-crypt unlock เดถเตเดเดฐเด เด
เตบเดฒเตเดเตเดเต เดเตเดฏเตเดฏเดพเตป.
เดเตเดธเตเดฑเตเดฑเตเดเตพเดเตเดเดพเดฏเดฟ เดจเดฟเดเตเดเตพเดเตเดเต เดเดชเดฏเตเดเดฟเดเตเดเดพเด เดจเดฟเดเตเดเตพเดเตเดเต เดเดตเดถเตเดฏเดฎเตเดณเตเดณเดคเตเดฒเตเดฒเดพเด เดเดคเดฟเดจเดเด เดเดฃเตเดเต:
$ kubectl -n argocd set image deploy/argocd-repo-server argocd-repo-server=docker.io/kvaps/argocd-git-crypt:v1.7.3เดเตผเดเต เดจเดฎเตเดฎเตเดเต เดถเตเดเดฐเดฃเดเตเดเดณเต เดเดเตเดเดจเต เดกเตเดเตเดฐเดฟเดชเตเดฑเตเดฑเต เดเตเดฏเตเดฏเตเดฎเตเดจเตเดจเต เดเดชเตเดชเตเตพ เดจเดฎเตเดฎเตพ เดเดฟเดจเตเดคเดฟเดเตเดเตเดฃเตเดเดคเตเดฃเตเดเต. เด เดคเดพเดฏเดคเต, เด เดคเดฟเดจเดพเดฏเดฟ เดเดฐเต เดเดฟเดชเดฟเดเดฟ เดเต เดธเตเดทเตเดเดฟเดเตเดเตเด:
$ kubectl exec -ti deploy/argocd-repo-server -- bash
$ printf "%sn"
"%no-protection"
"Key-Type: default"
"Subkey-Type: default"
"Name-Real: YOUR NAME"
"Name-Email: YOUR EMAIL@example.com"
"Expire-Date: 0"
> genkey-batch
$ gpg --batch --gen-key genkey-batch
gpg: WARNING: unsafe ownership on homedir '/home/argocd/.gnupg'
gpg: keybox '/home/argocd/.gnupg/pubring.kbx' created
gpg: /home/argocd/.gnupg/trustdb.gpg: trustdb created
gpg: key 8CB8B24F50B4797D marked as ultimately trusted
gpg: directory '/home/argocd/.gnupg/openpgp-revocs.d' created
gpg: revocation certificate stored as '/home/argocd/.gnupg/openpgp-revocs.d/9A1FF8CAA917CE876E2562FC8CB8B24F50B4797D.rev'เดจเดฎเตเดเตเดเต เดเต เดจเดพเดฎเด เดธเดเดฐเดเตเดทเดฟเดเตเดเดพเด 8CB8B24F50B4797D เดคเตเดเตผ เดจเดเดชเดเดฟเดเตพเดเตเดเดพเดฏเดฟ. เดเต เดคเดจเตเดจเต เดเดฏเดฑเตเดฑเตเดฎเดคเดฟ เดเตเดฏเตเดฏเตเด:
$ gpg --list-keys
gpg: WARNING: unsafe ownership on homedir '/home/argocd/.gnupg'
/home/argocd/.gnupg/pubring.kbx
-------------------------------
pub rsa3072 2020-09-04 [SC]
9A1FF8CAA917CE876E2562FC8CB8B24F50B4797D
uid [ultimate] YOUR NAME <YOUR EMAIL@example.com>
sub rsa3072 2020-09-04 [E]
$ gpg --armor --export-secret-keys 8CB8B24F50B4797Dเดเตเดเดพเดคเต เดเดคเต เดเดฐเต เดชเตเดฐเดคเตเดฏเตเด เดฐเดนเดธเตเดฏเดฎเดพเดฏเดฟ เดเตเตผเดเตเดเตเด:
# argocd-gpg-keys-secret.yaml
apiVersion: v1
kind: Secret
metadata:
name: argocd-gpg-keys-secret
namespace: argocd
stringData:
8CB8B24F50B4797D: |-
-----BEGIN PGP PRIVATE KEY BLOCK-----
lQVYBF9Q8KUBDACuS4p0ctXoakPLqE99YLmdixfF/QIvXVIG5uBXClWhWMuo+D0c
ZfeyC5GvH7XPUKz1cLMqL6o/u9oHJVUmrvN/g2Mnm365nTGw1M56AfATS9IBp0HH
O/fbfiH6aMWmPrW8XIA0icoOAdP+bPcBqM4HRo4ssbRS9y/i
=yj11
-----END PGP PRIVATE KEY BLOCK-----$ kubectl apply -f argocd-gpg-keys-secret.yamlเด เดคเต เดเดฃเตเดเตเดฏเตเดจเดฑเดฟเดฒเตเดเตเดเต เดเดฑเดฟเดฏเตเด เดฎเดพเดคเตเดฐเดฎเดพเดฃเต เดเดเตเดเตพเดเตเดเต เด เดตเดถเตเดทเดฟเดเตเดเตเดจเตเดจเดคเต เดเตผเดเตเดธเดฟเดกเดฟ-เดฑเดฟเดชเตเดชเต-เดธเตเตผเดตเตผ, เดเดคเต เดเตเดฏเตเดฏเตเดจเตเดจเดคเดฟเดจเต, เดตเดฟเดจเตเดฏเดพเดธเด เดเดกเดฟเดฑเตเดฑเต เดเตเดฏเตเดฏเตเด:
$ kubectl -n argocd edit deploy/argocd-repo-serverเดเดเตเดเตพ เดจเดฟเดฒเดตเดฟเดฒเตเดณเตเดณเดคเต เดฎเดพเดฑเตเดฑเดฟเดธเตเดฅเดพเดชเดฟเดเตเดเตเด gpg-เดเตเดเตพ เดตเตเดณเดฟเดฏเด เดเตบ projected, เด
เดตเดฟเดเต เดเดเตเดเตพ เดเดเตเดเดณเตเดเต เดฐเดนเดธเตเดฏเด เดธเตเดเดฟเดชเตเดชเดฟเดเตเดเตเดจเตเดจเต:
spec:
template:
spec:
volumes:
- name: gpg-keys
projected:
defaultMode: 420
sources:
- secret:
name: argocd-gpg-keys-secret
- configMap:
name: argocd-gpg-keys-cmเดเดฃเตเดเตเดฏเตโเดจเตผ เดเดฐเดเดญเดฟเดเตเดเตเดฎเตเดชเตเตพ Argo CD เด เดกเดฏเดฑเดเตโเดเดฑเดฟเดฏเดฟเตฝ เดจเดฟเดจเตเดจเต gpg เดเตเดเตพ เดธเตเดตเดฏเดฎเตเดต เดฒเตเดกเต เดเตเดฏเตเดฏเตเดจเตเดจเต, เด เดคเดฟเดจเดพเตฝ เดเดคเต เดเดเตเดเดณเตเดเต เดธเตเดตเดเดพเดฐเตเดฏ เดเตเดฏเตเด เดฒเตเดกเต เดเตเดฏเตเดฏเตเด.
เดจเดฎเตเดเตเดเต เดชเดฐเดฟเดถเตเดงเดฟเดเตเดเดพเด:
$ kubectl -n argocd exec -ti deploy/argocd-repo-server -- bash
$ GNUPGHOME=/app/config/gpg/keys gpg --list-secret-keys
gpg: WARNING: unsafe ownership on homedir '/app/config/gpg/keys'
/app/config/gpg/keys/pubring.kbx
--------------------------------
sec rsa2048 2020-09-05 [SC] [expires: 2021-03-04]
ED6285A3B1A50B6F1D9C955E5E8B1B16D47FFC28
uid [ultimate] Anon Ymous (ArgoCD key signing key) <noreply@argoproj.io>
sec rsa3072 2020-09-03 [SC]
9A1FF8CAA917CE876E2562FC8CB8B24F50B4797D
uid [ultimate] YOUR NAME <YOUR EMAIL@example.com>
ssb rsa3072 2020-09-03 [E]เดเตเดณเตเดณเดพเด, เดเต เดฒเตเดกเต เดเตเดฏเตเดคเต! เดเดชเตเดชเตเตพ เดเดฐเต เดธเดนเดเดพเดฐเดฟ เดเดจเตเดจ เดจเดฟเดฒเดฏเดฟเตฝ เดเตผเดเต เดธเดฟเดกเดฟ เดเดเตเดเดณเตเดเต เดถเตเดเดฐเดคเตเดคเดฟเดฒเตเดเตเดเต เดเตเตผเดเตเดเตเดฃเตเดเดคเตเดฃเตเดเต, เด เดคเต เดเดเตเดเดฏเดฟเตฝ เดธเตเดตเดฏเดฎเตเดต เดกเตเดเตเดฐเดฟเดชเตเดฑเตเดฑเต เดเตเดฏเตเดฏเดพเตป เดเดดเดฟเดฏเตเด.
เดฒเตเดเตเดเตฝ เดเดฎเตเดชเตเดฏเตเดเตเดเดฑเดฟเดฒเตเดเตเดเต เดเต เดเดฎเตเดชเตเตผเดเตเดเตเดเตเดฏเตเดฏเตเด:
$ gpg --armor --export-secret 8CB8B24F50B4797D > 8CB8B24F50B4797D.pem
$ gpg --import 8CB8B24F50B4797D.pemเดจเดฎเตเดเตเดเต เดเตเดฐเดธเตเดฑเตเดฑเต เดฒเตเดตเตฝ เดธเดเตเดเดฎเดพเดเตเดเดพเด:
$ gpg --edit-key 8CB8B24F50B4797D
trust
5เดเดเตเดเดณเตเดเต เดชเตเดฐเตเดเดเตเดฑเตเดฑเดฟเดฒเตเดเตเดเต เดเดฐเต เดธเดนเดเดพเดฐเดฟเดฏเดพเดฏเดฟ เดเตผเดเตเดฏเต เดเตเตผเดเตเดเดพเด:
$ git-crypt add-gpg-user 8CB8B24F50B4797Dเดฌเดจเตเดงเดชเตเดชเตเดเตเด เดฒเดฟเดเตเดเตเดเตพ:
เด เดตเดฒเดเดฌเด: www.habr.com
