

本文属于机器翻译版本。若本译文内容与英语原文存在差异，则一律以英文原文为准。

# AWS 云前端媒体存储
<a name="aws-cloudfront-mediastore"></a>

![](http://docs.aws.amazon.com/zh_cn/solutions/latest/constructs/images/experimental.png)


 所有类都处于积极开发之中，并且在任何未来版本中都会受到非向后兼容的更改或删除。这些不受[语义版本控制](https://semver.org/)模型。这意味着，虽然您可以使用它们，但在升级到此软件包的较新版本时，您可能需要更新源代码。

**注意：** 为确保正确的功能，您项目中的 AWS 解决方案构造软件包和 AWS CDK 包必须是相同的版本。


|  **语言**  |  **程序包**  | 
| --- | --- | 
|  ![](http://docs.aws.amazon.com/zh_cn/solutions/latest/constructs/images/python.png) Python  |  aws\_solutions\_constructs.aws\_cloudfront\_mediastore  | 
|  ![](http://docs.aws.amazon.com/zh_cn/solutions/latest/constructs/images/typescript.png) TypeScript  |  @aws-solutions-constructs/aws-cloudfront-mediastore  | 
|  ![](http://docs.aws.amazon.com/zh_cn/solutions/latest/constructs/images/java.png) Java  |  software.amazon.awsconstructs.services.cloudfrontmediastore  | 

## Overview
<a name="overview-38"></a>

 此 AWS 解决方案构造实现了连接到 AWS Elemental MediaStore 容器的 Amazon CloudFront 分配。

 以下是 TypeScript 中的最小可部署模式定义：

```
import { CloudFrontToMediaStore } from '@aws-solutions-constructs/aws-cloudfront-mediastore';

new CloudFrontToMediaStore(this, 'test-cloudfront-mediastore-default', {});
```

## Initializer
<a name="initializer-38"></a>

```
new CloudFrontToMediaStore(scope: Construct, id: string, props: CloudFrontToMediaStoreProps);
```

 *参数* 
+  scope[https://docs.aws.amazon.com/cdk/api/latest/docs/@aws-cdk_core.Construct.html](https://docs.aws.amazon.com/cdk/api/latest/docs/@aws-cdk_core.Construct.html) 
+  id`string` 
+  props[`CloudFrontToMediaStoreProps`](#pattern-construct-props-38) 

## 模式构建道具
<a name="pattern-construct-props-38"></a>


|  **名称**  |  **类型**  |  **描述**  | 
| --- | --- | --- | 
|  现有的媒体存储集装箱外壳？  |  [https://docs.aws.amazon.com/cdk/api/latest/docs/@aws-cdk_aws-mediastore.CfnContainer.html](https://docs.aws.amazon.com/cdk/api/latest/docs/@aws-cdk_aws-mediastore.CfnContainer.html)  |  可选的用户提供的 MediaStore 容器，用于覆盖默认的媒体存储容器。 | 
|  媒体商店集装箱道具？  |  [https://docs.aws.amazon.com/cdk/api/latest/docs/@aws-cdk_aws-mediastore.CfnContainerProps.html](https://docs.aws.amazon.com/cdk/api/latest/docs/@aws-cdk_aws-mediastore.CfnContainerProps.html)  |  用户提供的可选道具来覆盖 MediaStore 容器的默认道具。 | 
|  云前端分发道具？  |  [https://docs.aws.amazon.com/cdk/api/latest/docs/@aws-cdk_aws-cloudfront.DistributionProps.html](https://docs.aws.amazon.com/cdk/api/latest/docs/@aws-cdk_aws-cloudfront.DistributionProps.html) \| any  |  用户提供的可选道具来覆盖 CloudFront 分发的默认道具。 | 
|  是否插入安全标头？  |  boolean  |  可选的用户提供的道具，用于在 CloudFront 的所有响应中打开/关闭最佳实践 HTTP 安全标头的自动注入。 | 

## 模式属性
<a name="pattern-properties-38"></a>


|  **名称**  |  **类型**  |  **描述**  | 
| --- | --- | --- | 
|  云端网络分发  |  [https://docs.aws.amazon.com/cdk/api/latest/docs/@aws-cdk_aws-cloudfront.CloudFrontWebDistribution.html](https://docs.aws.amazon.com/cdk/api/latest/docs/@aws-cdk_aws-cloudfront.CloudFrontWebDistribution.html)  |  返回由模式创建的 CloudFront Web 分发的实例。 | 
|  媒体存储容器  |  [https://docs.aws.amazon.com/cdk/api/latest/docs/@aws-cdk_aws-mediastore.CfnContainer.html](https://docs.aws.amazon.com/cdk/api/latest/docs/@aws-cdk_aws-mediastore.CfnContainer.html)  |  返回由模式创建的 MediaStore 容器的实例。 | 
|  云前端记录存储桶  |  [https://docs.aws.amazon.com/cdk/api/latest/docs/@aws-cdk_aws-s3.Bucket.html](https://docs.aws.amazon.com/cdk/api/latest/docs/@aws-cdk_aws-s3.Bucket.html)  |  返回由 CloudFront Web 分发模式创建的日志记录存储桶的实例。 | 
|  云前端来源请求策略  |  [https://docs.aws.amazon.com/cdk/api/latest/docs/@aws-cdk_aws-cloudfront.OriginRequestPolicy.html](https://docs.aws.amazon.com/cdk/api/latest/docs/@aws-cdk_aws-cloudfront.OriginRequestPolicy.html)  |  返回由 CloudFront Web 分发模式创建的 CloudFront 源请求策略的实例。 | 
|  CloudFront 源访问性？  |  [https://docs.aws.amazon.com/cdk/api/latest/docs/@aws-cdk_aws-cloudfront.OriginAccessIdentity.html](https://docs.aws.amazon.com/cdk/api/latest/docs/@aws-cdk_aws-cloudfront.OriginAccessIdentity.html)  |  返回由 CloudFront Web 分发模式创建的 CloudFront 源访问身份的实例。 | 
|  封边功能版本  |  [https://docs.aws.amazon.com/cdk/api/latest/docs/@aws-cdk_aws-lambda.Version.html](https://docs.aws.amazon.com/cdk/api/latest/docs/@aws-cdk_aws-lambda.Version.html)  |  返回由模式创建的 Lambda 边函数版本的实例。 | 

## 默认设置
<a name="default-settings-38"></a>

 没有任何覆盖的此模式的开箱即用实现将设置以下默认值：

### Amazon CloudFront
<a name="amazon-cloudfront-2"></a>
+  为 CloudFront 网络分发配置访问日志记录 
+  为 AWS Elemental MediaStore 容器启用 CloudFront 源请求策略 
+  Set`User-Agent`CloudFront 源访问身份的自定义标头 
+  支持在来自 CloudFront Web 分发的所有响应中自动注入最佳实践 HTTP 安全标头 

### AWS Elemental MediaStore
<a name="amazon-elemental-mediastore"></a>
+  设置删除策略以保留资源 
+  使用 CloudFormation 堆栈名称设置容器名称 
+  设置默认[容器跨源资源共享 (CORS) 策略](https://docs.aws.amazon.com/mediastore/latest/ug/cors-policy.html) 
+  设置默认[对象生命周期策略](https://docs.aws.amazon.com/mediastore/latest/ug/policies-object-lifecycle.html) 
+  设置默认[容器策略](https://docs.aws.amazon.com/mediastore/latest/ug/policies.html)仅允许`aws:UserAgent`CloudFront 源访问身份 
+  设置默认[指标策略](https://docs.aws.amazon.com/mediastore/latest/ug/policies-metric.html) 
+  启用访问日志记录

## Architecture
<a name="architecture-38"></a>

![](http://docs.aws.amazon.com/zh_cn/solutions/latest/constructs/images/aws-cloudfront-mediastore.png)


## GitHub
<a name="github-38"></a>


<table>
<thead>
  <tr><th colspan="2"> 要查看此模式的代码、创建/查看问题和拉取请求等，请执行以下操作： </th></tr>
</thead>
<tbody>
  <tr><td> ![](http://docs.aws.amazon.com/zh_cn/solutions/latest/constructs/images/GitHub-Mark-32px.png) </td><td> [@aws-解决方案结构/aw-云前媒体存储](https://github.com/awslabs/aws-solutions-constructs/tree/master/source/patterns/%40aws-solutions-constructs/aws-cloudfront-mediastore) </td></tr>
</tbody>
</table>
