Apigee Edge 문서를 보고 있습니다.
Apigee X 문서로 이동하세요. 정보
유료 계정이 있는 클라우드 고객은 조직에 가상 호스트를 만들 수 있습니다.
자세히 알아보기:
클라우드에서 가상 호스트를 만들고 수정할 수 있는 사용자
가상 호스트 생성 및 수정은 Edge Cloud의 유료 계정에서만 사용할 수 있습니다. 가상 호스트를 만드는 사용자는 조직 관리자 역할이거나 가상 호스트를 수정할 수 있는 권한이 있는 커스텀 역할을 보유해야 합니다. 다른 역할의 사용자는 가상 호스트를 만들 수 있는 권한이 없습니다.
예를 들어 유료 고객은 다음과 같은 작업을 할 수 있습니다.
- 단방향 및 양방향 TLS 사용 설정
- 가상 호스트에서 사용하는 키 저장소/신뢰 저장소 지정
무료 및 체험판 계정은 가상 호스트를 만들거나 수정할 수 없으며 Edge 등록 시 생성된 가상 호스트로 제한됩니다. Edge 요금제에 대한 자세한 내용은 https://apigee.com/api-management/#/pricing을 참조하세요.
클라우드의 가상 호스트 구성을 위한 요구사항
다음 표에는 가상 호스트를 만들기 위한 요구사항이 요약되어 있습니다.
카테고리 | 요구사항 | 설명 |
---|---|---|
계정 유형 | 유료 | 무료 및 체험판 계정은 가상 호스트를 만들거나 수정할 수 없습니다. |
사용자 역할 | 조직 관리자 | 조직 관리자만 가상 호스트를 만들거나 가상 호스트를 수정할 권한이 있는 커스텀 역할의 사용자를 만들 수 있습니다. |
가상 호스트 수 | 최대 20자 |
클라우드의 조직/환경당 가상 호스트는 최대 20개로 제한됩니다. 참고: Private Cloud의 가상 호스트 수에는 제한이 없습니다. 대부분의 조직/환경은 HTTP용과 HTTPS 액세스용 등 두 개의 가상 호스트를 사용합니다. 조직/환경에서 다른 도메인 이름을 사용한 액세스를 허용하는 경우 추가 가상 호스트가 필요할 수 있습니다. |
기본 URL | 프로토콜을 포함합니다. | UI나 API를 사용하여 가상 호스트의 기본 URL을 정의할 때는 프로토콜 (예: 'http://' 또는 'https://')을 URL의 일부로 지정해야 합니다. |
포트 | 443 |
포트 443에서만 가상 호스트를 만들 수 있습니다. 고유한 호스트 별칭이 있고 모두 TLS를 지원하는 한 포트 443에 가상 호스트를 여러 개 만들 수 있습니다. |
TLS | 필수 |
HTTPS를 통한 TLS를 지원하는 가상 호스트만 만들 수 있습니다. TLS 인증서와 키가 포함된 키 저장소(선택사항)를 이미 생성했어야 합니다. Symantec 또는 VeriSign과 같은 신뢰할 수 있는 법인에서 서명한 인증서가 있어야 합니다. 자체 서명 인증서를 사용할 수 없습니다. HTTP 액세스가 필요한 경우 Apigee Edge 지원팀에 문의하세요. |
TLS 프로토콜 | TLS 1.2 |
Cloud의 Edge는 TLS 버전 1.2만 지원합니다. |
호스트 별칭 | 조직 및 환경에서 고유함 | 다른 조직/환경 조합에 대한 호스트 별칭이 없습니다. |
도메인 이름 | 고객 소유 |
가상 호스트에 지정된 도메인 이름을 소유하고 있어야 합니다. Edge는 호스트 별칭으로 정의된 도메인 이름이 TLS 인증서의 메타데이터와 일치하는지 확인합니다. 특히 Edge는 인증서에서 다음 정보를 확인합니다.
SAN 또는 CN에서는 와일드 카드를 사용할 수 있습니다(예: 또한 Edge는 인증서가 만료되지 않았는지 확인합니다. |
클라이언트 앱 SNI 지원 | 가상 호스트에 액세스하는 모든 클라이언트 앱은 SNI를 지원해야 합니다. |
모든 앱에는 SNI 지원이 필요합니다. |
브라우저를 사용하여 가상 호스트 만들기
이 섹션의 대부분의 예시에서는 Edge API를 사용하여 가상 호스트를 만들거나 수정하지만 Edge UI에서 가상 호스트를 만들 수 있습니다.
Edge UI를 사용하여 가상 호스트를 만들려면 다음 안내를 따르세요.
- apigee.com/edge에 로그인합니다.
- 관리자 > 가상 호스트를 선택합니다.
- prod 또는 test와 같은 환경을 선택합니다.
- + 가상 호스트를 선택하여 가상 호스트를 만들거나 기존 가상 호스트의 이름을 선택하여 수정합니다.
- 가상 호스트 필드 작성에 대한 자세한 내용은 위의 표를 참고하세요.
단방향 TLS의 가상 호스트 정의
가상 호스트를 정의하는 XML 객체입니다. 예를 들어 다음 XML 객체는 단방향 TLS의 가상 호스트를 정의합니다.
<VirtualHost name="myTLSVHost"> <HostAliases> <HostAlias>api.myCompany.com</HostAlias> </HostAliases> <Port>443</Port> <SSLInfo> <Enabled>true</Enabled> <ClientAuthEnabled>false</ClientAuthEnabled> <KeyStore>ref://myTestKeystoreRef</KeyStore> <KeyAlias>myKeyAlias</KeyAlias> </SSLInfo> </VirtualHost>
이 정의에서는 다음을 수행합니다.
- 이름을 myTLSVHost로 지정합니다. API 프록시 또는 API 호출에서 이 이름을 사용하여 가상 호스트를 참조합니다.
- 호스트 별칭을 api.myCompany.com으로 지정합니다. 이 도메인은 DNS 정의 및 CNAME 레코드에서 정의된 대로 API에 액세스하는 데 사용되는 공개 도메인입니다.
- 포트 번호를 443으로 지정합니다. 생략할 경우 기본적으로 포트는 443으로 설정됩니다.
- 필요에 따라 TLS를 사용 설정합니다.
단방향 TLS를 사용 설정하기 위해<Enable>
요소는 true로 설정되고 및<KeyStore>
요소는 TLS 연결에 사용되는 키 저장소와 키 별칭을 지정합니다.
양방향 TLS를 사용 설정하려면<ClientAuthEnabled>
를 true로 설정하고<TrustStore>
요소를 사용하여 truststore를 지정합니다. 트러스트 저장소는 필요한 클라이언트의 인증서 발급기관과 인증서의 CA 체인을 보유합니다.
참고: Edge는 원래 SSL을 지원했으므로 TLS를 구성하는 데 사용하는 태그의 이름은<SSLInfo>
입니다.
가상 호스트에서 설정할 수 있는 추가 속성이 있습니다. 모든 속성에 대한 참조는 가상 호스트 속성 참조를 확인하세요.
가상 호스트에서 키 저장소 및 truststore 이름을 지정하는 방법 결정
TLS를 지원하도록 가상 호스트를 구성할 때는 참조를 사용하여 키 저장소를 지정합니다. 참조는 아래와 같이 키 저장소 또는 트러스트 저장소 이름을 직접 지정하는 대신 키 저장소 또는 트러스트 저장소의 이름이 포함된 변수입니다.
<SSLInfo> <Enabled>true</Enabled> <ClientAuthEnabled>false</ClientAuthEnabled> <KeyStore>ref://myTestKeystoreRef</KeyStore> <KeyAlias>myKeyAlias</KeyAlias> </SSLInfo>
참조를 사용할 때의 이점은 참조 값을 변경하여 가상 호스트에서 사용하는 키 저장소를 변경할 수 있다는 것입니다. 일반적으로 현재 키 저장소의 인증서가 가까운 미래에 만료되기 때문입니다. 참조 값을 변경해도 Edge Router를 다시 시작할 필요가 없습니다. 참조 만들기 및 수정에 대한 자세한 내용은 참조 작업을 참조하세요.
키 저장소와 트러스트 저장소에 대한 참조만 사용할 수 있습니다. 별칭에 대한 참조를 사용할 수 없습니다. 키 저장소에 대한 참조를 변경하는 경우 인증서의 별칭 이름이 이전 키 저장소 이름과 동일해야 합니다.
키 저장소 및 truststore 참조 사용 시 제한사항
키 저장소 및 트러스트 저장소 참조를 사용할 때는 다음 제한사항을 고려해야 합니다.
- SNI를 지원하고 Apigee 라우터에서 SSL을 종료하는 경우에만 가상 호스트에서 키 저장소 및 truststore 참조를 사용할 수 있습니다.
- Apigee 라우터 앞에 부하 분산기가 있고 부하 분산기에서 TLS를 종료하는 경우 가상 호스트에서 키 저장소 및 truststore 참조를 사용할 수 없습니다.
양방향 TLS용 가상 호스트 정의
양방향 TLS를 사용 설정하려면 <ClientAuthEnabled>
요소를 true
로 설정하고 참조를 <TrustStore>
요소와 함께 사용하여 truststore를 지정합니다. 트러스트 저장소는 필요한 클라이언트의 인증서 발급기관과 인증서의 CA 체인을 보유합니다. 또한 클라이언트는 양방향 TLS에 대해 올바르게 구성되어야 합니다.
양방향 TLS용 가상 호스트를 만들려면 가상 호스트를 정의하는 XML 객체를 만듭니다.
<VirtualHost name="myTLSVHost"> <HostAliases> <HostAlias>api.myCompany.com</HostAlias> </HostAliases> <Port>443</Port> <SSLInfo> <Enabled>true</Enabled> <ClientAuthEnabled>true</ClientAuthEnabled> <KeyStore>ref://myTestKeystoreRef</KeyStore> <KeyAlias>myKeyAlias</KeyAlias> <TrustStore>ref://myTestTruststoreRef</TrustStore> </SSLInfo> </VirtualHost>
이 정의에서는 다음을 수행합니다.
<ClientAuthEnabled>
를 true로 설정하여 양방향 TLS를 사용 설정합니다.<TrustStore>
요소를 사용하여 truststore 참조를 지정합니다. 트러스트 저장소는 필요한 클라이언트의 인증서 발급기관과 인증서의 CA 체인을 보유합니다.
Apigee 무료 체험판 인증서 및 키를 사용하는 가상 호스트 정의
Cloud용 유료 Edge 계정이 있지만 아직 TLS 인증서와 키가 없는 경우 Apigee 무료 체험판 인증서 및 키를 사용하는 가상 호스트를 만들 수 있습니다. 즉, 키 저장소를 먼저 만들지 않고도 가상 호스트를 만들 수 있습니다.
Apigee 무료 체험판 인증서는 *.apigee.net
도메인에 대해 정의됩니다. 따라서 가상 호스트의 <HostAlias>
도 *.apigee.net
형식이어야 합니다.
양방향 TLS를 수행하는 경우에도 여전히 <ClientAuthEnabled>
요소를 true
로 설정해야 하며, 위의 양방향 TLS용 가상 호스트 정의에 설명된 대로 <TrustStore>
요소와 함께 참조를 사용하여 truststore를 지정해야 합니다.
아래와 같이 Apigee 무료 체험판 인증서 및 키를 사용하여 가상 호스트를 정의하는 XML 객체는 <KeyStore>
및 <KeyAlias>
요소를 생략하고 <UseBuiltInFreeTrialCert>
요소로 바꿉니다.
<VirtualHost name="myTLSVHost"> <HostAliases> <HostAlias>myapi.apigee.net</HostAlias> </HostAliases> <Port>443</Port> <SSLInfo> <Enabled>true</Enabled> <ClientAuthEnabled>false</ClientAuthEnabled> </SSLInfo> <UseBuiltInFreeTrialCert>true</UseBuiltInFreeTrialCert> </VirtualHost>
<UseBuiltInFreeTrialCert>
요소의 기본값은 false입니다.
양방향 TLS의 경우 가상 호스트를 다음과 같이 정의합니다.
<VirtualHost name="myTLSVHost"> <HostAliases> <HostAlias>myapi.apigee.net</HostAlias> </HostAliases> <Port>443</Port> <SSLInfo> <Enabled>true</Enabled> <ClientAuthEnabled>true</ClientAuthEnabled> <TrustStore>ref://myTestTruststoreRef</TrustStore> </SSLInfo> <UseBuiltInFreeTrialCert>true</UseBuiltInFreeTrialCert> </VirtualHost>
Edge UI에서 무료 Apigee 인증서 및 키를 사용할 가상 호스트를 만들 때 기본 제공 무료 체험판 인증서 사용 옵션을 선택합니다.
가상 호스트 만들기
다음 절차에 따라 가상 호스트를 만듭니다.
- 공개적으로 표시되는 도메인(이 예시에서는
[org]-[environment].apigee.net
을 가리키는api.myCompany.com
)의 DNS 항목과 CNAME 레코드를 만듭니다. - Edge UI를 사용하여 키 저장소 및 truststore 만들기에 설명된 절차를 사용하여 이 예시에서는 myTestKeystore라는 키 저장소를 만들고 구성합니다. 이 예에서는 키 저장소가 인증서 및 비공개 키에 myKeyAlias라는 별칭 이름을 사용해야 합니다.
- 인증서와 키를 키 저장소에 업로드합니다. 인증서에서 지정한 도메인 이름이 가상 호스트에 사용할 호스트 별칭과 일치하는지 확인합니다.
-
Edge UI 또는 API를 사용하여 키 저장소에 대한 참조를 만듭니다. 참조는 키 저장소의 이름과 참조 유형을
KeyStore
로 지정합니다. 참조 만들기 및 수정에 대한 자세한 내용은 참조 작업을 참조하세요. - Create a Virtual Host API를 사용하여 가상 호스트를 만듭니다. 올바른 키 저장소 참조와 키 별칭을 지정해야 합니다.
API를 사용하려면 다음 POST API 호출을 사용하여 myTLSVHost라는 키 저장소를 만듭니다.
curl -X POST -H "Content-Type:application/xml" \ https://api.enterprise.apigee.com/v1/o/{org_name}/e/{env_name}/virtualhosts \ -d '<VirtualHost name="myTLSVHost"> <HostAliases> <HostAlias>api.myCompany.com</HostAlias> </HostAliases> <Port>443</Port> <SSLInfo> <Enabled>true</Enabled> <ClientAuthEnabled>false</ClientAuthEnabled> <KeyStore>ref://myTestKeystoreRef</KeyStore> <KeyAlias>myKeyAlias</KeyAlias> </SSLInfo> </VirtualHost>' \ -u orgAdminEmail:password
클라이언트로 양방향 TLS를 수행하는 경우
<ClientAuthEnabled>
를 true로 설정하고<TrustStore>
요소를 사용하여 truststore를 지정합니다. 클라이언트가 양방향 TLS에 맞게 올바르게 구성되어야 합니다. 즉, Edge에 클라이언트의 인증서 발급기관과 인증서 체인이 포함된 트러스트 저장소가 있어야 합니다. Edge UI를 사용하여 키 저장소 및 truststore 만들기에 설명된 절차에 따라 truststore를 만듭니다. 기존 API 프록시가 있으면 ProxyEndpoint의
<HTTPConnection>
요소에 가상 호스트를 추가합니다. 가상 호스트가 모든 새 API 프록시에 자동으로 추가됩니다. 가상 호스트를 사용하도록 API 프록시 구성을 참조하세요.
가상 호스트를 사용하도록 API 프록시를 업데이트하고 호스트 별칭의 DNS 항목 및 CNAME 레코드를 만든 후 아래와 같이 API 프록시에 액세스할 수 있습니다.
https://api.myCompany.com/v1/{project-base-path}/{resource-path}
예를 들면 다음과 같습니다.
https://api.myCompany.com/v1/weather/forecastrss?w=12797282
가상 호스트 수정
유료 Cloud 고객이 기존 가상 호스트를 수정하기 위해 수행하는 두 가지 기본 작업은 다음과 같습니다.
- 키 저장소 또는 truststore에 대한 참조 값 수정
참고: 참조를 사용하도록<KeyStore>
또는<TrustStore>
를 설정하면 언제든지 참조 값을 변경할 수 있습니다. 하지만 다른 참조를 사용하도록<KeyStore>
또는<TrustStore>
를 변경하거나, 다른 별칭을 사용하도록<KeyAlias>
를 변경하려면 Apigee Edge 지원팀에 문의해야 합니다. - 가상 호스트의 TLS 속성 수정
참조 값 수정하기
참조 값을 수정하여 가상 호스트에서 사용하는 키 저장소 또는 truststore를 변경할 수 있습니다.
참조 값을 수정하기 전에 다음을 수행하세요.
- Edge UI를 사용하여 키 저장소 및 truststore 만들기에 설명된 대로 새 키 저장소를 만들고 인증서와 키를 업로드합니다. 새 키 저장소에서 키 별칭에 기존 키 저장소에 사용된 것과 동일한 이름을 사용해야 합니다.
- 필요한 경우 Edge UI를 사용하여 키 저장소 및 truststore 만들기에 설명된 대로 새 트러스트 저장소를 만들고 인증서를 업로드합니다.
- 참조 작업에 설명된 대로 참조를 수정합니다.
가상 호스트의 TLS 속성 수정
유료 고객은 Update a Virtual Host API를 사용하여 가상 호스트를 업데이트할 수 있습니다. 이 API를 사용하면 가상 호스트 속성 참조에 설명된 가상 호스트의 모든 속성을 설정할 수 있습니다.
가상 호스트를 수정하면 Edge가 가상 호스트를 만들 때와 비슷한 검증을 수행합니다. 즉 수정 시 Edge는 다음을 확인합니다.
- 호스트 별칭으로 지정된 도메인이 다른 조직 및 환경에서 사용되지 않습니다.
- 해당 도메인 이름을 소유하고 있습니다. 구체적으로 Edge는 인증서의 다음 정보가 호스트 별칭과 일치하는지 확인합니다.
- CN - 일반 이름
- SAN - 주체 대체 이름
- Edge가 인증서가 만료되지 않았는지 확인합니다.
Edge API를 사용하여 가상 호스트를 수정하려면 다음 안내를 따르세요.
Update a Virtual Host API를 사용하여 가상 호스트를 업데이트합니다. API를 사용하는 경우 변경하려는 요소뿐 아니라 요청 본문에 가상 호스트의 전체 정의를 지정해야 합니다. 이 예에서는
proxy_read_timeout
속성의 값을 설정합니다.curl -X PUT -H "Content-Type:application/xml" \ https://api.enterprise.apigee.com/v1/o/{org_name}/e/{env_name}/virtualhosts/{vhost_name} \ -d '<VirtualHost name="myTLSVHost"> <HostAliases> <HostAlias>api.myCompany.com</HostAlias> </HostAliases> <Port>443</Port> <SSLInfo> <Enabled>true</Enabled> <ClientAuthEnabled>false</ClientAuthEnabled> <KeyStore>ref://myTestKeystoreRef</KeyStore> <KeyAlias>myKeyAlias</KeyAlias> </SSLInfo> <Properties> <Property name="proxy_read_timeout">50</Property> </Properties> </VirtualHost>' \ -u orgAdminEmail:password
키 저장소 및 truststore에 대한 참조를 사용하도록 가상 호스트 수정
클라우드의 Edge를 위한 모든 새로운 가상 호스트는 키 저장소와 트러스트 저장소를 참조합니다. 참조를 사용하면 Apigee Edge 지원팀에 문의하지 않고도 키 저장소와 공인 저장소를 변경할 수 있습니다.
Apigee Edge의 이전 가상 호스트는 키 저장소 및 트러스트 저장소에 대한 참조를 사용하도록 구성되지 않았을 수 있습니다. 이 경우 가상 호스트를 업데이트하여 참조를 사용할 수 있습니다.
참조를 사용하도록 가상 호스트 업데이트
다음 절차에 따라 가상 호스트를 업데이트합니다.
- 필요한 경우 Edge UI를 사용하여 키 저장소 및 truststore 만들기에 설명된 대로 새 키 저장소를 만들고 인증서를 업로드합니다. 키 저장소가 이미 있다면 키 저장소를 가리키도록 참조를 구성할 수 있습니다.
- 키 저장소에 대한 새 참조를 생성합니다.
- 필요한 경우 새 트러스트 저장소를 만들고 인증서를 업로드합니다. 트러스트 저장소가 이미 있으면 이 저장소를 가리키도록 참조를 구성할 수 있습니다.
- 트러스트 저장소에 대한 새 참조를 만듭니다.
- 가상 호스트를 업데이트하여 키 저장소, 별칭, truststore 및 기타 TLS 속성을 설정합니다. 호출의 페이로드는
curl -X PUT -H "Content-Type:application/xml" \ https://api.enterprise.apigee.com/v1/o/{org_name}/e/{env_name}/virtualhosts/{vhost_name} \ -d '<VirtualHost name="myTLSVHost"> <HostAliases> <HostAlias>api.myCompany.com</HostAlias> </HostAliases> <Port>443</Port> <OCSPStapling>off</OCSPStapling> <SSLInfo> <Enabled>true</Enabled> <ClientAuthEnabled>true</ClientAuthEnabled> <KeyStore>ref://myKeyStore2Way</KeyStore> <KeyAlias>keyAlias</KeyAlias> <TrustStore>ref://myTrustStore2Way</TrustStore> <IgnoreValidationErrors>false</IgnoreValidationErrors> </SSLInfo> </VirtualHost>' \ -u orgAdminEmail:pWord
입니다. - 에지 라우터를 다시 시작하여 프로세스를 완료하려면 Apigee 지원에 문의하세요.