다음을 통해 공유


Docker 콘텐츠 신뢰에서 Notary Project로의 전환

Azure Container Registry는 2028년 3월 31일에 Docker 콘텐츠 신뢰를 사용 중지합니다. 이러한 전환을 돕기 위해 Docker 콘텐츠 신뢰를 사용하지 않도록 설정하고 Notary Project를 채택하여 컨테이너 이미지에 서명하고 확인하는 방법에 대한 지침을 제공합니다.

Docker 콘텐츠 신뢰 사용 중단

Docker 콘텐츠 신뢰를 사용하면 이미지 게시자가 이미지에 서명하고 이미지 소비자는 자신이 끌어온 이미지가 서명되었는지 확인할 수 있습니다. 기술의 발전으로 인해 Docker 콘텐츠 신뢰는 더 이상 컨테이너에 대한 최신 공급망 보안 요구 사항을 충족하지 못합니다. 결과적으로 Docker 콘텐츠 신뢰는 2025년 3월 31일부터 더 이상 사용되지 않으며 2028년 3월 31일에 ACR(Azure Container Registry)에서 완전히 제거됩니다.

Docker 콘텐츠 신뢰를 사용하는 대신 Microsoft는 Notary Project를 기반으로 하는 서명 및 검증 솔루션을 제공합니다. Notary Project는 정품 컨테이너 이미지와 기타 OCI 아티팩트를 사용하여 소프트웨어 공급망을 보호하기 위한 업계 간 표준을 제공하기 위해 고안된 사양 및 도구 집합입니다. Notary Project의 도구인 Notation은 Notary Project 사양을 구현하고 컨테이너 이미지와 아티팩트를 서명하고 검증하기 위한 CLI와 라이브러리를 포함합니다. 컨테이너 이미지의 무결성과 신뢰성성을 보장하기 위해 Notary Project 솔루션을 사용하면 다음과 같은 이점이 있습니다.

  • 이식성 및 상호 운용성: Notary Project 서명OCI(Open Container Initiative) 표준을 준수하며 ACR과 같은 OCI 호환 레지스트리에 저장할 수 있어 다양한 클라우드 환경에서 서명의 이식성과 interop이 용이해집니다.
  • 안전한 키 관리: AKV(Azure Key Vault)를 사용하여 서명 키와 인증서를 안전하게 관리합니다. 더 많은 KMS(키 관리 시스템) 옵션이 출시 예정될 예정입니다.
  • CI/CD 파이프라인 통합: ADO(Azure DevOps) 및 GitHub 워크플로를 포함한 CI/CD 파이프라인에 서명을 구현합니다. 더 많은 CI/CD 통합 옵션이 출시 예정될 예정입니다.
  • 종합적 검증: ADO 및 GitHub 워크플로와 같은 CI/CD 파이프라인과 AKS(Azure Kubernetes Service)에서 컨테이너 이미지를 검증하여 신뢰할 수 없는 이미지의 사용 및 배포를 방지합니다.

Docker 콘텐츠 신뢰 사용하지 않도록 설정

Notation Project 솔루션으로 전환하기 전에 Docker 콘텐츠 신뢰를 사용하지 않도록 설정해야 합니다. Docker 콘텐츠 신뢰를 사용하지 않도록 설정하려면 다음 방법을 사용합니다.

  • DOCKER_CONTENT_TRUST 환경 변수를 0으로 설정하여 셸에서 Docker 콘텐츠 신뢰를 사용하지 않도록 설정합니다. Bash 셸을 예로 들면 다음과 같습니다.

    export DOCKER_CONTENT_TRUST=0
    

    또는 환경 변수를 설정 해제할 수 있습니다.

    unset DOCKER_CONTENT_TRUST
    
  • Azure Portal에서 Docker 콘텐츠 신뢰를 사용하지 않도록 설정합니다. Azure Portal에서 레지스트리로 이동합니다. 정책에서 콘텐츠 신뢰를 선택한 다음 사용 안 함을 선택하고 저장을 선택합니다.

  • Azure CLI를 사용하여 Docker 콘텐츠 신뢰를 사용하지 않도록 설정합니다.

    az acr config content-trust update -r myregistry --status disabled
    

Notary Project를 사용하여 컨테이너 이미지에 서명하고 확인합니다.

Docker 콘텐츠 신뢰를 사용하지 않도록 설정한 후에는 Notary Project를 사용하여 컨테이너 이미지에 서명하고 확인할 수 있습니다. 시작하려면 다음 참고자료를 활용합니다.

컨테이너 이미지 서명:

컨테이너 이미지 확인: