Azure ID 공급자를 AKS(Azure Kubernetes Service)의 Azure Key Vault 비밀 저장소 CSI 드라이버에 연결
AKS(Azure Kubernetes Service)용 비밀 저장소 CSI(Container Storage Interface) 드라이버는 Azure Key Vault에 대한 다양한 ID 기반 액세스 방법을 제공합니다. 이 문서에서는 RBAC(역할 기반 액세스 제어) 또는 OIDC(OpenID Connect) 보안 모델을 사용하여 키 자격 증명 모음과 AKS 클러스터에 액세스하는 경우에 대한 이러한 방법과 모범 사례를 간략하게 설명합니다.
다음 액세스 방법 중 하나를 사용할 수 있습니다.
- 워크로드 ID 있는 서비스 커넥터
- 워크로드 ID
- 사용자 할당 관리 ID
서비스 커넥터를 사용하여 AKS(Azure Kubernetes Service) 클러스터에서 비밀 저장소 CSI 드라이버를 사용하여 Azure Key Vault에 연결하는 방법을 알아봅니다. 이 문서에서는 다음 작업을 완료합니다.
- AKS 클러스터 및 Azure Key Vault를 만듭니다.
- 서비스 커넥터를 사용하여 AKS 클러스터와 Azure Key Vault 간의 연결을 만듭니다.
SecretProviderClass
연결을 테스트하기 위해 CSI 공급자를 사용하는 CRD 및Pod
A를 만듭니다.- 리소스를 정리합니다.
Important
AKS 미리 보기 기능은 셀프 서비스에서 사용할 수 있습니다(옵트인 방식). 미리 보기는 "있는 그대로" 및 "사용 가능한 상태로" 제공되며 서비스 수준 계약 및 제한적 보증에서 제외됩니다. AKS 미리 보기의 일부는 고객 지원팀에서 최선을 다해 지원합니다. 따라서 이러한 기능은 프로덕션 용도로 사용할 수 없습니다. 자세한 내용은 다음 지원 문서를 참조하세요.
필수 조건
- 활성 구독이 있는 Azure 계정. 체험 계정을 만듭니다.
- Azure CLI
az login
명령을 사용하여 로그인합니다. - Docker 및 kubectl. kubectl을 로컬로 설치하려면 명령을 사용합니다
az aks install-cli
. - 컨테이너 및 AKS에 대한 기본적인 이해입니다. AKS용 애플리케이션을 준비하여 시작 합니다.
- 시작하기 전에 AKS(Azure Kubernetes Service) 클러스터에서 비밀 저장소 CSI 드라이버용 Azure Key Vault 공급자 사용의 단계를 완료하여 AKS 클러스터에서 Azure Key Vault 비밀 저장소 CSI 드라이버를 사용하도록 설정했는지 확인합니다.
초기 설정
Service Connector를 처음 사용하는 경우 먼저 az provider register 명령을 실행하여 Service Connector 및 Kubernetes Configuration 리소스 공급자를 등록합니다.
az provider register -n Microsoft.ServiceLinker
az provider register -n Microsoft.KubernetesConfiguration
팁
az provider show -n "Microsoft.ServiceLinker" --query registrationState
및az provider show -n "Microsoft.KubernetesConfiguration" --query registrationState
명령을 실행하여 이러한 리소스 공급자가 이미 등록되었는지 확인할 수 있습니다.필요에 따라 Azure CLI 명령을 사용하여 AKS 클러스터에 대해 지원되는 대상 서비스 목록을 가져옵니다.
az aks connection list-support-types --output table
Azure 리소스 만들기
az group create
명령을 사용하여 리소스 그룹을 만듭니다.az group create \ --name <resource-group-name> \ --location <location>
az aks create
명령을 사용하여 AKS 클러스터를 만듭니다. 다음 예제에서는 관리 ID를 사용하도록 설정된 단일 노드 AKS 클러스터를 만듭니다.az aks create \ --resource-group <resource-group-name> \ --name <cluster-name> \ --enable-managed-identity \ --node-count 1
az aks get-credentials
명령을 사용하여 클러스터에 연결합니다.az aks get-credentials \ --resource-group <resource-group-name> \ --name <cluster-name>
명령을 사용하여 Azure Key Vault를 만듭니다
az keyvault create
.az keyvault create \ --resource-group <resource-group-name> \ --name <key-vault-name> \ --location <location>
명령을 사용하여 키 자격 증명 모음에 비밀을 만듭니다
az keyvault secret set
.az keyvault secret set \ --vault-name <key-vault-name> \ --name <secret-name> \ --value <secret-value>
서비스 커넥터(미리 보기)를 사용하여 AKS에서 서비스 연결 만들기
Azure Portal 또는 Azure CLI를 사용하여 Azure Key Vault에 대한 서비스 연결을 만들 수 있습니다.
Azure Portal에서 AKS 클러스터 리소스로 이동합니다.
서비스 메뉴의 설정에서 서비스 커넥터(미리 보기)>만들기를 선택합니다.
연결 만들기 페이지의 기본 사항 탭에서 다음 설정을 구성합니다.
- Kubernetes 네임스페이스: 기본값을 선택합니다.
- 서비스 유형: Key Vault를 선택하고 확인란을 선택하여 Azure Key Vault CSI 공급자를 사용하도록 설정합니다.
- 연결 이름: 연결의 이름을 입력합니다.
- 구독: 키 자격 증명 모음이 포함된 구독을 선택합니다.
- 키 자격 증명 모음: 만든 키 자격 증명 모음을 선택합니다.
- 클라이언트 유형: 없음을 선택합니다.
검토 + 만들기를 선택한 다음 만들기를 선택하여 연결을 만듭니다.
연결 테스트
샘플 리포지토리 복제 및 매니페스트 파일 배포
명령을 사용하여 샘플 리포지토리를 복제합니다
git clone
.git clone https://github.com/Azure-Samples/serviceconnector-aks-samples.git
디렉터리를 Azure Key Vault CSI 공급자 샘플로 변경합니다.
cd serviceconnector-aks-samples/azure-keyvault-csi-provider
secret_provider_class.yaml
파일에서 다음 자리 표시자를 Azure Key Vault 정보로 바꿉니다.- 만들고 연결한 키 자격 증명 모음의 이름으로 바꿉
<AZURE_KEYVAULT_NAME>
니다. <AZURE_KEYVAULT_TENANTID>
를 키 자격 증명 모음의 테넌트 ID로 바꿉니다.<AZURE_KEYVAULT_CLIENTID>
를azureKeyvaultSecretsProvider
추가 기능의 ID 클라이언트 ID로 바꿉니다.- 만든 키 자격 증명 모음 비밀로 바꿉
<KEYVAULT_SECRET_NAME>
니다. 예들 들어ExampleSecret
입니다.
- 만들고 연결한 키 자격 증명 모음의 이름으로 바꿉
SecretProviderClass
명령을 사용하여 CRD를 배포합니다kubectl apply
.kubectl apply -f secret_provider_class.yaml
Pod
명령을 사용하여 매니페스트 파일을 배포합니다kubectl apply
.이 명령은 AKS 클러스터의 기본 네임스페이스에
sc-demo-keyvault-csi
라는 Pod를 만듭니다.kubectl apply -f pod.yaml
연결 확인
명령을 사용하여 Pod가 성공적으로 만들어졌는지 확인합니다
kubectl get
.kubectl get pod/sc-demo-keyvault-csi
Pod가 시작된 후에는 배포 YAML에 지정된 볼륨 경로에 탑재된 콘텐츠를 사용할 수 있습니다.
명령을 사용하여 비밀 저장소에 보관된 비밀을 표시합니다
kubectl exec
.kubectl exec sc-demo-keyvault-csi -- ls /mnt/secrets-store/
명령을 사용하여 비밀을 표시합니다
kubectl exec
.이 예제 명령은 이름이 인
ExampleSecret
테스트 비밀을 보여줍니다.kubectl exec sc-demo-keyvault-csi -- cat /mnt/secrets-store/ExampleSecret
CSI 드라이버 사전 요구 사항
- 시작하기 전에 AKS(Azure Kubernetes Service) 클러스터에서 비밀 저장소 CSI 드라이버용 Azure Key Vault 공급자 사용의 단계를 완료하여 AKS 클러스터에서 Azure Key Vault 비밀 저장소 CSI 드라이버를 사용하도록 설정했는지 확인합니다.
- Microsoft Entra 워크로드 ID Windows 및 Linux 클러스터를 모두 지원합니다.
Microsoft Entra 워크로드 ID를 사용하여 액세스
Microsoft Entra 워크로드 ID는 Pod에서 실행되는 애플리케이션에서 소프트웨어의 워크로드와 같은 다른 Azure 서비스에 대해 자신을 인증하는 데 사용하는 ID입니다. 비밀 저장소 CSI 드라이버는 네이티브 Kubernetes 기능과 통합하여 외부 ID 공급자와 페더레이션됩니다.
이 보안 모델에서 AKS 클러스터는 토큰 발급자 역할을 합니다. 그런 다음, Microsoft Entra ID는 OIDC를 사용하여 공용 서명 키를 검색하고 서비스 계정 토큰을 Microsoft Entra 토큰으로 교환하기 전에 해당 토큰의 신뢰성을 확인합니다. Microsoft Entra 토큰 볼륨에 프로젝션된 서비스 계정 토큰을 교환하는 워크로드의 경우 Azure SDK 또는 MSAL(Microsoft 인증 라이브러리)의 Azure ID 클라이언트 라이브러리가 필요합니다.
참고 항목
- 이 인증 방법은 Microsoft Entra Pod 관리 ID(미리 보기)를 대체합니다. Azure Kubernetes Service의 오픈 소스 Microsoft Entra Pod 관리 ID(미리 보기)는 2022년 10월 24일부터 더 이상 사용되지 않습니다.
- Microsoft Entra 워크로드 ID는 Windows 및 Linux 클러스터를 모두 지원합니다.
워크로드 ID 구성
az account set
명령을 사용하여 구독을 설정합니다.export SUBSCRIPTION_ID=<subscription id> export RESOURCE_GROUP=<resource group name> export UAMI=<name for user assigned identity> export KEYVAULT_NAME=<existing keyvault name> export CLUSTER_NAME=<aks cluster name> az account set --subscription $SUBSCRIPTION_ID
az identity create
명령을 사용하여 관리 ID를 만듭니다.참고 항목
이 단계에서는 워크로드 ID를 사용하도록 설정된 기존 AKS 클러스터가 있다고 가정합니다. 사용하도록 설정 하지 않은 경우 기존 AKS 클러스터 에서 워크로드 ID를 사용하도록 설정하여 사용하도록 설정하세요.
az identity create --name $UAMI --resource-group $RESOURCE_GROUP export USER_ASSIGNED_CLIENT_ID="$(az identity show --resource-group $RESOURCE_GROUP --name $UAMI --query 'clientId' -o tsv)" export IDENTITY_TENANT=$(az aks show --name $CLUSTER_NAME --resource-group $RESOURCE_GROUP --query identity.tenantId -o tsv)
az role assignment create
명령을 사용하여 키 자격 증명 모음 비밀, 액세스 키 및 인증서에 액세스할 수 있는 워크로드 ID 권한을 부여하는 역할 할당을 만듭니다.Important
- 키 자격 증명 모음이
--enable-rbac-authorization
으로 설정되어 있고key
또는certificate
형식을 사용하는 경우Key Vault Certificate User
역할을 할당하여 권한을 부여합니다. - 키 자격 증명 모음이
--enable-rbac-authorization
으로 설정되어 있고secret
형식을 사용하는 경우Key Vault Secrets User
역할을 할당합니다. - 키 자격 증명 모음이
--enable-rbac-authorization
으로 설정되지 않은 경우--key-permissions get
,--certificate-permissions get
또는--secret-permissions get
매개 변수와 함께az keyvault set-policy
명령을 사용하여 키, 인증서 또는 비밀에 대한 액세스 권한을 부여하는 키 자격 증명 모음 정책을 만들 수 있습니다. 예시:
az keyvault set-policy --name $KEYVAULT_NAME --key-permissions get --object-id $IDENTITY_OBJECT_ID
export KEYVAULT_SCOPE=$(az keyvault show --name $KEYVAULT_NAME --query id -o tsv) # Example command for key vault with RBAC enabled using `key` type az role assignment create --role "Key Vault Certificate User" --assignee $USER_ASSIGNED_CLIENT_ID --scope $KEYVAULT_SCOPE
- 키 자격 증명 모음이
az aks show
명령을 사용하여 AKS 클러스터 OIDC 발급자 URL을 가져옵니다.참고 항목
이 단계에서는 OIDC 발급자 URL을 사용하도록 설정된 기존 AKS 클러스터가 있다고 가정합니다. 사용하도록 설정하지 않은 경우 OIDC 발급자를 사용하여 AKS 클러스터 업데이트를 참조하여 사용하도록 설정합니다.
export AKS_OIDC_ISSUER="$(az aks show --resource-group $RESOURCE_GROUP --name $CLUSTER_NAME --query "oidcIssuerProfile.issuerUrl" -o tsv)" echo $AKS_OIDC_ISSUER
Microsoft Entra 애플리케이션, 서비스 계정 발급자 및 주체 간에 페더레이션 ID 자격 증명을 설정합니다. 다음 명령을 사용하여 Microsoft Entra 애플리케이션의 개체 ID를 가져옵니다. Kubernetes 서비스 계정 이름과 해당 네임스페이스로
serviceAccountName
및serviceAccountNamespace
의 값을 업데이트해야 합니다.export SERVICE_ACCOUNT_NAME="workload-identity-sa" # sample name; can be changed export SERVICE_ACCOUNT_NAMESPACE="default" # can be changed to namespace of your workload cat <<EOF | kubectl apply -f - apiVersion: v1 kind: ServiceAccount metadata: annotations: azure.workload.identity/client-id: ${USER_ASSIGNED_CLIENT_ID} name: ${SERVICE_ACCOUNT_NAME} namespace: ${SERVICE_ACCOUNT_NAMESPACE} EOF
az identity federated-credential create
명령을 사용하여 관리 ID, 서비스 계정 발급자 및 주체 간의 페더레이션된 ID 자격 증명을 만듭니다.export FEDERATED_IDENTITY_NAME="aksfederatedidentity" # can be changed as needed az identity federated-credential create --name $FEDERATED_IDENTITY_NAME --identity-name $UAMI --resource-group $RESOURCE_GROUP --issuer ${AKS_OIDC_ISSUER} --subject system:serviceaccount:${SERVICE_ACCOUNT_NAMESPACE}:${SERVICE_ACCOUNT_NAME}
kubectl apply
명령과 다음 YAML 스크립트를 사용하여SecretProviderClass
를 배포합니다.cat <<EOF | kubectl apply -f - # This is a SecretProviderClass example using workload identity to access your key vault apiVersion: secrets-store.csi.x-k8s.io/v1 kind: SecretProviderClass metadata: name: azure-kvname-wi # needs to be unique per namespace spec: provider: azure parameters: usePodIdentity: "false" clientID: "${USER_ASSIGNED_CLIENT_ID}" # Setting this to use workload identity keyvaultName: ${KEYVAULT_NAME} # Set to the name of your key vault cloudName: "" # [OPTIONAL for Azure] if not provided, the Azure environment defaults to AzurePublicCloud objects: | array: - | objectName: secret1 # Set to the name of your secret objectType: secret # object types: secret, key, or cert objectVersion: "" # [OPTIONAL] object versions, default to latest if empty - | objectName: key1 # Set to the name of your key objectType: key objectVersion: "" tenantId: "${IDENTITY_TENANT}" # The tenant ID of the key vault EOF
참고 항목
objectName
대신objectAlias
를 사용하는 경우 YAML 스크립트를 업데이트해야 합니다.참고 항목
SecretProviderClass
가 제대로 작동하려면objects
섹션에서 참조하기 전에 Azure Key Vault에 비밀, 키 또는 인증서를 채워야 합니다.kubectl apply
명령과 다음 YAML 스크립트를 사용하여 샘플 Pod를 배포합니다.cat <<EOF | kubectl apply -f - # This is a sample pod definition for using SecretProviderClass and workload identity to access your key vault kind: Pod apiVersion: v1 metadata: name: busybox-secrets-store-inline-wi labels: azure.workload.identity/use: "true" spec: serviceAccountName: "workload-identity-sa" containers: - name: busybox image: registry.k8s.io/e2e-test-images/busybox:1.29-4 command: - "/bin/sleep" - "10000" volumeMounts: - name: secrets-store01-inline mountPath: "/mnt/secrets-store" readOnly: true volumes: - name: secrets-store01-inline csi: driver: secrets-store.csi.k8s.io readOnly: true volumeAttributes: secretProviderClass: "azure-kvname-wi" EOF
CSI 드라이버 사전 요구 사항
- 시작하기 전에 AKS(Azure Kubernetes Service) 클러스터에서 비밀 저장소 CSI 드라이버용 Azure Key Vault 공급자 사용의 단계를 완료하여 AKS 클러스터에서 Azure Key Vault 비밀 저장소 CSI 드라이버를 사용하도록 설정했는지 확인합니다.
관리 ID를 사용하여 액세스
Microsoft Entra 관리 ID는 관리자가 다른 Azure 서비스에 대해 자신을 인증하는 데 사용하는 ID입니다. 관리 ID는 RBAC를 사용하여 외부 ID 공급자와 페더레이션합니다.
이 보안 모델에서는 관리되는 역할을 공유하는 팀 구성원이나 테넌트에 클러스터 리소스에 대한 액세스 권한을 부여할 수 있습니다. 역할은 keyvault 및 기타 자격 증명에 액세스하는 범위에 대해 확인됩니다. AKS 클러스터에서 비밀 저장소 CSI 드라이버용 Azure Key Vault 공급자를 사용하도록 설정하면 사용자 ID가 생성됩니다.
관리 ID 구성
az aks show
명령과 추가 항목에서 만든 사용자가 할당한 관리 ID를 사용하여 키 자격 증명 모음에 액세스합니다. 또한 이후 단계에서SecretProviderClass
를 만들 때 사용할 ID의clientId
도 검색해야 합니다.az aks show --resource-group <resource-group> --name <cluster-name> --query addonProfiles.azureKeyvaultSecretsProvider.identity.objectId -o tsv az aks show --resource-group <resource-group> --name <cluster-name> --query addonProfiles.azureKeyvaultSecretsProvider.identity.clientId -o tsv
또는 다음 명령을 사용하여 새 관리 ID를 만들고 VM(가상 머신) 확장 집합에 할당하거나 가용성 집합의 각 VM 인스턴스에 할당할 수 있습니다.
az identity create --resource-group <resource-group> --name <identity-name> az vmss identity assign --resource-group <resource-group> --name <agent-pool-vmss> --identities <identity-resource-id> az vm identity assign --resource-group <resource-group> --name <agent-pool-vm> --identities <identity-resource-id> az identity show --resource-group <resource-group> --name <identity-name> --query 'clientId' -o tsv
az role assignment create
명령을 사용하여 키 자격 증명 모음 비밀, 액세스 키 및 인증서에 액세스할 수 있는 ID 권한을 부여하는 역할 할당을 만듭니다.Important
- 키 자격 증명 모음이
--enable-rbac-authorization
으로 설정되어 있고key
또는certificate
형식을 사용하는 경우Key Vault Certificate User
역할을 할당합니다. - 키 자격 증명 모음이
--enable-rbac-authorization
으로 설정되어 있고secret
형식을 사용하는 경우Key Vault Secrets User
역할을 할당합니다. - 키 자격 증명 모음이
--enable-rbac-authorization
으로 설정되지 않은 경우--key-permissions get
,--certificate-permissions get
또는--secret-permissions get
매개 변수와 함께az keyvault set-policy
명령을 사용하여 키, 인증서 또는 비밀에 대한 액세스 권한을 부여하는 키 자격 증명 모음 정책을 만들 수 있습니다. 예시:
az keyvault set-policy --name $KEYVAULT_NAME --key-permissions get --object-id $IDENTITY_OBJECT_ID
export IDENTITY_OBJECT_ID="$(az identity show --resource-group <resource-group> --name <identity-name> --query 'principalId' -o tsv)" export KEYVAULT_SCOPE=$(az keyvault show --name <key-vault-name> --query id -o tsv) # Example command for key vault with RBAC enabled using `key` type az role assignment create --role "Key Vault Certificate User" --assignee $USER_ASSIGNED_CLIENT_ID --scope $KEYVAULT_SCOPE
- 키 자격 증명 모음이
다음 YAML을 사용하여
SecretProviderClass
를 만듭니다.userAssignedIdentityID
,keyvaultName
,tenantId
및 키 자격 증명 모음에서 검색할 개체에 대해 사용자 고유의 값을 사용해야 합니다.# This is a SecretProviderClass example using user-assigned identity to access your key vault apiVersion: secrets-store.csi.x-k8s.io/v1 kind: SecretProviderClass metadata: name: azure-kvname-user-msi spec: provider: azure parameters: usePodIdentity: "false" useVMManagedIdentity: "true" # Set to true for using managed identity userAssignedIdentityID: <client-id> # Set the clientID of the user-assigned managed identity to use keyvaultName: <key-vault-name> # Set to the name of your key vault cloudName: "" # [OPTIONAL for Azure] if not provided, the Azure environment defaults to AzurePublicCloud objects: | array: - | objectName: secret1 objectType: secret # object types: secret, key, or cert objectVersion: "" # [OPTIONAL] object versions, default to latest if empty - | objectName: key1 objectType: key objectVersion: "" tenantId: <tenant-id> # The tenant ID of the key vault
참고 항목
objectName
대신objectAlias
를 사용하는 경우 YAML 스크립트를 업데이트해야 합니다.참고 항목
SecretProviderClass
가 제대로 작동하려면objects
섹션에서 참조하기 전에 Azure Key Vault에 비밀, 키 또는 인증서를 채워야 합니다.kubectl apply
명령을 사용하여 클러스터에SecretProviderClass
를 적용합니다.kubectl apply -f secretproviderclass.yaml
다음 YAML을 사용하여 Pod를 만듭니다.
# This is a sample pod definition for using SecretProviderClass and the user-assigned identity to access your key vault kind: Pod apiVersion: v1 metadata: name: busybox-secrets-store-inline-user-msi spec: containers: - name: busybox image: registry.k8s.io/e2e-test-images/busybox:1.29-4 command: - "/bin/sleep" - "10000" volumeMounts: - name: secrets-store01-inline mountPath: "/mnt/secrets-store" readOnly: true volumes: - name: secrets-store01-inline csi: driver: secrets-store.csi.k8s.io readOnly: true volumeAttributes: secretProviderClass: "azure-kvname-user-msi"
kubectl apply
명령을 사용하여 클러스터에 Pod를 적용합니다.kubectl apply -f pod.yaml
Key Vault 비밀 유효성 검사
Pod가 시작된 후에는 배포 YAML에 지정된 볼륨 경로에 탑재된 콘텐츠를 사용할 수 있습니다. 다음 명령을 사용하여 비밀의 유효성을 검사하고 테스트 비밀을 인쇄합니다.
다음 명령을 사용하여 비밀 저장소에 보관된 비밀을 표시합니다.
kubectl exec busybox-secrets-store-inline-user-msi -- ls /mnt/secrets-store/
다음 명령을 사용하여 저장소에 비밀을 표시합니다. 다음 예제 명령에서는 테스트 비밀
ExampleSecret
을 보여줍니다.kubectl exec busybox-secrets-store-inline-user-msi -- cat /mnt/secrets-store/ExampleSecret
인증서 및 키 가져오기
Azure Key Vault 디자인은 키, 비밀 및 인증서를 뚜렷하게 구분합니다. Key Vault 서비스의 인증서 기능은 키 및 비밀 기능을 사용하도록 설계되었습니다. 키 자격 증명 모음 인증서를 만들 때 주소 지정 가능한 키와 비밀을 같은 이름으로 만듭니다. 키는 키 작업을 허용하고 비밀은 인증서 값을 비밀로 검색할 수 있게 합니다.
키 자격 증명 모음 인증서에는 공용 x509 인증서 메타데이터도 포함됩니다. 키 자격 증명 모음은 인증서의 퍼블릭 및 프라이빗 구성 요소를 모두 비밀에 저장합니다. SecretProviderClass
에 objectType
을(를) 지정하여 각 개별 구성 요소를 가져올 수 있습니다. 다음 표에서는 인증서와 연결된 다양한 리소스에 매핑되는 개체를 보여 줍니다.
Object | 반환 값 | 전체 인증서 체인을 반환합니다. |
---|---|---|
key |
PEM(Privacy Enhanced Mail) 형식의 공개 키 | 해당 없음 |
cert |
PEM 형식의 인증서 | 아니요 |
secret |
PEM 형식의 프라이빗 키 및 인증서 | 예 |
기존 클러스터에서 추가 항목 사용 안 함
참고 항목
추가 항목을 사용하지 않도록 설정하기 전에 사용 중인 SecretProviderClass
이(가) 없는지 확인합니다. SecretProviderClass
가 존재하는 동안 추가 항목을 사용하지 않도록 설정하면 오류가 발생합니다.
azure-keyvault-secrets-provider
추가 항목과 함께az aks disable-addons
명령을 사용하여 기존 클러스터에서 비밀 저장소 CSI 드라이버용 Azure Key Vault 공급자를 사용하지 않도록 설정합니다.az aks disable-addons --addons azure-keyvault-secrets-provider --resource-group myResourceGroup --name myAKSCluster
참고 항목
추가 항목을 사용하지 않도록 설정하면 기존 워크로드에 이슈가 없거나 탑재된 비밀에 업데이트가 표시되어야 합니다. Pod가 다시 시작되거나 새 Pod가 스케일 업 이벤트의 일환으로 생성되면 드라이버가 더 이상 실행되지 않으므로 Pod가 시작되지 않습니다.
다음 단계
이 문서에서는 ID를 만들고 제공하여 Azure Key Vault에 액세스하는 방법을 알아보았습니다. 서비스 커넥터 통합은 AKS 워크로드와 Azure 지원 서비스에 대한 연결 구성을 간소화하는 데 도움이 됩니다. 또한 인증 및 네트워크 구성을 안전하게 처리하고 Azure 서비스에 연결하기 위한 모범 사례를 따릅니다. 자세한 내용은 AKS 클러스터의 비밀 저장소 CSI 드라이버용 Azure Key Vault 공급자 사용 및 서비스 커넥터 소개를 참조하세요.
추가 구성 옵션을 구성하거나 문제 해결을 수행하려면 AKS 비밀 저장소의 CSI 드라이버를 사용하여 Azure Key Vault 공급자에 대한 구성 옵션 및 문제 해결 리소스를 참조하세요.
Azure Kubernetes Service