在 CloudFront 中,您可以为不同分发配置相同的备用域名 (CNAME)。这样,当一个分发不可用时,请求将转发到备用域名上。
以下是使用 AWS SDK for Python (Boto3) 配置 CloudFront 分发的代码示例:
import boto3
def create_cloudfront_distribution():
cloudfront_client = boto3.client('cloudfront')
origin_domain = 'example-origin-domain.com'
alternate_domains = ['example-cname1.com', 'example-cname2.com']
distribution_comment = 'Example CloudFront Distribution'
try:
response = cloudfront_client.create_distribution(
DistributionConfig={
'CallerReference': 'example-caller-reference',
'Comment': distribution_comment,
'DefaultRootObject': 'index.html',
'Enabled': True,
'Origins': {
'Quantity': 1,
'Items': [
{
'DomainName': origin_domain,
'Id': 'example-origin',
'CustomOriginConfig': {
'HTTPPort': 80,
'HTTPSPort': 443,
'OriginProtocolPolicy': 'http-only',
'OriginSslProtocols': {
'Quantity': 3,
'Items': ['TLSv1', 'TLSv1.1', 'TLSv1.2']
}
}
}
]
},
'Aliases': {
'Quantity': len(alternate_domains),
'Items': alternate_domains
},
'DefaultCacheBehavior': {
'TargetOriginId': 'example-origin',
'ForwardedValues': {
'QueryString': False,
'Cookies': {'Forward': 'none'},
'Headers': {'Quantity': 0},
'QueryStringCacheKeys': {'Quantity': 0}
},
'TrustedSigners': {'Enabled': False, 'Quantity': 0},
'ViewerProtocolPolicy': 'allow-all',
'MinTTL': 0
},
'PriceClass': 'PriceClass_100',
'ViewerCertificate': {
'CloudFrontDefaultCertificate': True,
'MinimumProtocolVersion': 'TLSv1',
'CertificateSource': 'cloudfront'
},
}
)
print('CloudFront Distribution created successfully.')
print('Distribution Id:', response['Distribution']['Id'])
print('Distribution Domain Name:', response['Distribution']['DomainName'])
except Exception as e:
print('Error:', str(e))
create_cloudfront_distribution()
在上面的代码示例中,origin_domain
是主要的源域名,alternate_domains
是备用的 CNAME 域名列表。通过在 Aliases
字段中提供这些备用域名,您可以为 CloudFront 分发配置重复的备用域名。请确保在 DNS 上正确配置了这些备用域名的 CNAME 记录。
此示例代码使用 AWS SDK for Python (Boto3) 创建了一个 CloudFront 分发,并指定了主要的源域名和备用的 CNAME 域名。如果创建成功,它会打印出分发的 ID 和域名。
请确保已正确安装 AWS SDK for Python (Boto3) 并正确配置 AWS 认证凭据,以便能够成功运行此代码示例。
下一篇:不同 div 中的重复字段