Skip to content

tyorikan/kcc-config-sync

Repository files navigation

kcc-config-sync

PROJECT_ID=anthosday

  1. Google Cloud Console を開く
  2. Config Connector を適用したクラスタの作成
gcloud container clusters create infra-admin-cluster \
    --release-channel stable \
    --addons ConfigConnector \
    --workload-pool=anthosday.svc.id.goog \
    --enable-stackdriver-kubernetes \
    --enable-autoscaling \
    --num-nodes 2 \
    --min-nodes 1 \
    --max-nodes 5 \
    --region asia-northeast1

cnrm-system namespaces にインストールされていることを確認

kubectl get all -n cnrm-system
  1. Config Connector Service Account 設定
gcloud iam service-accounts create config-connector
gcloud projects add-iam-policy-binding anthosday \
--member="serviceAccount:[email protected]" \
--role="roles/owner"
gcloud iam service-accounts add-iam-policy-binding \
[email protected] \
--member="serviceAccount:anthosday.svc.id.goog[cnrm-system/cnrm-controller-manager]" \
--role="roles/iam.workloadIdentityUser"
  1. configconnector.yaml の作成
    Config Connector Operator は、Google Cloud Resource CRD と Config Connector コンポーネントをクラスタにインストールする
apiVersion: core.cnrm.cloud.google.com/v1beta1
kind: ConfigConnector
metadata:
  # the name is restricted to ensure that there is only one
  # ConfigConnector resource installed in your cluster
  name: configconnector.core.cnrm.cloud.google.com
spec:
  mode: cluster
  googleServiceAccount: "[email protected]"
kubectl apply -f configconnector.yaml
  1. Namespace の作成、設定
kubectl create namespace kcc-project-anthosday
kubectl annotate namespace \
kcc-project-anthosday cnrm.cloud.google.com/project-id=anthosday
  1. nomos init してディレクトリ作成し、Google Cloud リソースを namespaces 以下に作成
    https://github.com/tyorikan/kcc-config-sync/tree/main/sync-root

  2. Config Sync Operator の CRD 適用

gsutil cp gs://config-management-release/released/latest/config-sync-operator.yaml config-sync-operator.yaml
kubectl apply -f config-sync-operator.yaml
  1. SSH 認証鍵ペアの作成
kubectl create secret generic git-creds \
--namespace=config-management-system \
--from-file=ssh=.ssh/git-creds
  1. config-management.yaml の作成
    Config Sync の動作を構成するために、ConfigManagement CustomResource の構成ファイルを作成
apiVersion: configmanagement.gke.io/v1
kind: ConfigManagement
metadata:
  name: config-management
spec:
  # clusterName is required and must be unique among all managed clusters
  clusterName: infra-admin-cluster
  # Enable multi-repo mode to use additional features
  enableMultiRepo: true
kubectl apply -f config-management.yaml
  1. root-sync.yaml の作成
apiVersion: configsync.gke.io/v1beta1
kind: RootSync
metadata:
  name: root-sync
  namespace: config-management-system
spec:
  sourceFormat: hierarchy
  git:
    repo: [email protected]:tyorikan/kcc-config-sync.git
    branch: main
    dir: "sync-root"
    auth: ssh
    secretRef:
      name: git-creds
kubectl apply -f root-sync.yaml

Watch sync status

nomos status --contexts gke_anthosday_asia-northeast1_infra-admin-cluster

About

Config Connector with Config Sync demo

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published