ACME 프로토콜 업데이트

마지막 업데이트: | 모든 문서를 참조

참고: 번역 이후 영어 버전이 업데이트되었습니다 () 영어로 보기

ACME 프로토콜은 Let’s Encrypt가 작동하는 방식의 기초입니다. 현재 표준 초안이며 아직 최종 RFC는 아닙니다. 시간이 지나면서 프로토콜 사양이 발전함에 따라 Let’s Encrypt는 업데이트가 된 ACME를 구현할 것입니다. 그렇게 할 때, 하위 호환성과 밀접하게 연관지으면서 보안은 저희의 주요 관심사가 됩니다.

현재 구현된 ACME 버전

저희는 다음과 같은 API 엔드포인트를 가지고 있습니다. 이들은 프로토콜 문서 초안과 함께 발전하면서 하나로 고정된 ACME 사양의 초안을 구현하는 것은 아닙니다. 현재 구현된 ACME 초안과 비교하기 위해 각기 다른 문서를 참조하십시오.

ACME v1

ACME v2

https://letsencrypt.org/2017/06/14/acme-v2-api.html

새로운 하위 호환 ACME 기능

Let’s Encrypt는 기존 API 엔드포인트에 대해 새로운 하위 호환 기능을 구현할 수 있습니다. 저희가 이전에 구현하지 않은 ACME 사양의 일부를 구현하기로 결정했기 때문에 새로운 하위 호환 기능이 도입되었습니다.

새로운 기능이 기존 API 엔드포인트에 도입되면서 해당 기능은 공용 ACME 사양에 명확히 지정될 것이며, 제대로 구현된 클라이언트 호환성을 깨뜨리지 않습니다.

ACME 보안 수정사항

ACME 프로토콜에 대한 심각한 보안 문제가 있다는 것을 알게되면 (단순한 구현보다는) API 엔드포인트에 대한 호환성을 변경하거나, 기존 엔드포인트의 작동을 중단하고 새로운 엔드포인트를 도입해야 할 수도 있습니다.

ACME는 여러 기관에 의해 검토되었고 생산에 성공적으로 사용되었지만, 아직 발견되지 않은 취약점이 존재할 가능성이 있습니다. 시스템 관리자는 이러한 취약점에 대한 대응으로 ACME 클라이언트에게 적시에 업데이트를 배포 할 수 있는 능력을 유지해야 합니다.

변경사항이 있는 ACME의 새로운 버전

새로운 변경사항이 포함된 ACME의 새 버전을 구현하는 것이 중요하다고 판단되면, 저희는 새로운 API 엔드포인트를 도입하고 이전 버전의 엔드포인트와 병행하여 유지 관리합니다. 새 버전을 사용할 수 있게 만들고 나서 중단할 버전 일정을 모든 사용자에게 미리 전달합니다.

이 작업은 전환할 시간이 충분할지라도 호환성을 깨는 것은 너무 부담스럽기 때문에 자주 일어나지 않을 것입니다. 그러나 IETF가 ACME를 표준화하면 해당 작업을 수행하게 됩니다. 저희는 현재 사전 IETF 표준화 버전의 ACME를 구현하고 있고, 가능하면 공식 표준을 사용하는 것이 중요하다고 생각합니다.