快速提供内容对于任何网站或应用程序具有更好的客户体验至关重要。 如果您将网站或应用程序托管在AWS Cloud中,那么无论从何处访问应用程序,都可以以较低的延迟快速提供内容。 AWS提供了CloudFront服务,用于将内容缓存在每个用户地理位置本地的边缘位置。

在此示例中,我们将向您展示如何使用AWS Lambda函数检索和转换图像,如何在CloudFront边缘位置本地缓存以及如何在原始服务器中更新缓存的图像时使这些缓存无效。 该方法可以应用于任何其他类型的内容。

1.什么是Amazon CloudFront?

Amazon CloudFront是AWS(Amazon Web Services)提供的内容交付网络(CDN)Web服务,它允许通过全球范围内的多个边缘位置访问内容。 Amazon CloudFront当前提供149个边缘位置和11个区域边缘缓存 。

2.什么是AWS Lambda?

AWS Lambda是一个事件驱动的无服务器计算平台,该平台运行代码而无需置备或管理服务器。 AWS Lambda根据事件触发器执行代码(功能)。 例如,一个简单的用例是,每次将图像上传到S3存储桶时,都可以触发Lambda函数来转换和调整图像大小。 AWS Lambda函数也可以通过AWS API Gateway内置的API执行。

3.什么是Amazon S3?

AWS S3(简单存储服务)是一种低成本,安全,耐用,高可用性和水平可扩展的对象存储服务,可以在其中存储,访问和轻松备份数据。 您可以从任何地方存储任何数量的信息。

4.从Origin Server获取图像并将其存储在S3中

假设您有一个媒体服务器,该服务器托管您的网站所需的所有图像,并假定该服务器能够在更新现有图像或添加新图像时触发通知。 使用AWS Lambda,可以对这些图像进行检索,转换,调整大小并将其存储到S3存储桶中。

图1:使用Lambda从Origin Server获取图像

上图图1显示了AWS Lambda函数,该函数从Media服务器检索原始图像,进行转换并将其发布到S3存储桶。 它还会侦听Message Queue以获取Media Server发布的图像更新,并在S3中刷新图像。

5.使用Amazon CloudFront缓存内容

Amazon CloudFront可以通过边缘缓存加快内容的交付速度。 当用户访问您的网站或应用程序并请求内容时,请求将被路由到最近的CloudFront边缘位置。 仅对于第一个用户,在检索内容时会有延迟,并且相同内容的所有后续用户将能够快速检索内容,因为内容将被缓存在边缘位置。

以下是用户对内容的请求发生的过程:

  • CloudFront会在其缓存中检查所请求的对象。 如果在缓存中找到了所请求的对象,则将其返回。
  • 如果在CloudFront缓存中找不到请求的对象,
    • 该请求将被重定向到配置的原始服务器
    • CloudFront将从Origin Server返回的对象缓存在最近的边缘位置,然后返回给用户。

可以将CloudFront中的对象缓存为已配置的TTL(生存时间),并且TTL过期后,该对象将不再可用于从缓存中提供服务,如图2所示。

图2:使用CloudFront缓存图像内容

6.如何在AWS控制台上配置CloudFront

要配置CloudFront,必须先创建CloudFront分配。 选择“ Web分发”进行内容分发,并选择“ RMTP”分发进行流媒体文件。 对于这种情况,让我们选择Web分发。

6.1创建CloudFront分配

登录到AWS控制台->选择CloudFront服务->创建分配->选择Web分配->入门

要将S3用作原始服务器,请为原始域名选择已创建的S3存储桶。 对于“ 原始路径”,输入存储对象的目录路径。 要将自定义HTTP Server用作原始服务器,请为“ 原始域名”输入自定义原始服务器的DNS名称,为“ 原始路径 ”输入上下文路径。

要将S3用作原始服务器,请为原始域名选择已创建的S3存储桶。 对于“ 原始路径”,输入存储对象的目录路径。 要将自定义HTTP Server用作原始服务器,请为Origin Domain Name输入自定义原始服务器的DNS名称,并为Origin Path输入上下文路径,如图3所示。

图3:从AWS控制台创建CloudFront分配

6.2缓存行为设置

如果只允许HTTPS访问,则启用将HTTP重定向到HTTPS。对象缓存中,如果选择了“使用原始缓存标头”,则CloudFront将使用原始服务器响应中的缓存控制标头( max-age ),除非还返回了“ s-max-age ”,在这种情况下为s-max-使用年龄

如果选择Customize (针对Object Caching ),则可以配置Minimum TTL,Maximum TTL和Default TTL,如图4所示。

  • 最小TTL是对象在CloudFront将请求转发到Origin Server之前对象保留在缓存中的时间(以秒为单位)。 即使Origin Server的Cache-Control标头的值较低,对象也会被缓存最少的时间。
  • 最大TTL是在CloudFront将请求转发到Origin Server之前,对象停留在缓存中的时间(以秒为单位)。 最大TTL仅在原始服务器返回缓存控制标头时才有效。 即使Origin Server的Cache-Control标头具有更高的值,对象的缓存时间也不会超过此时间。
  • 仅当Origin Server不返回任何缓存控制标头时,默认TTL才有效。

图4: CloudFront分发上的缓存行为设置

6.3查询参数白名单

当您不想按“ 所有”查询参数缓存图像或内容,而仅按几个查询参数缓存时,可以将CloudFront配置为仅通过“ 查询字符串白名单”按选定的查询参数缓存,如图5所示,因此只有那些查询参数会包含在缓存键中。 仍然将所有查询参数转发到原始服务器。

图5 :CloudFront中的白名单查询参数

创建一个Alias记录以使用CloudFront分布Url映射Route53 CNAME记录,因此对Alias的请求将映射到CloudFront分布,然后再映射到原点。

7.使CloudFront中的缓存对象无效

一旦将对象缓存在CloudFront中,它们将保留在缓存中,直到缓存TTL过期为止。 如果在原始服务器中更新了一个对象,CloudFront不会知道这一点,但是会继续从其缓存中为过时的对象提供服务。 为了避免提供过时的数据对象,CloudFront允许通过不同方式使对象缓存无效。

在AWS文档中 ,您一次可以对每个分发进行最多3,000个文件的失效请求,每个失效请求可以包括多达3000个URL。 请注意,启动CloudFront缓存失效后,CloudFront需要花费几分钟的时间从所有边缘位置删除对象。 即可能需要一些时间才能获得无效的结果。 失效所需的时间取决于失效请求中包含的对象URL的数量。

7.1通过AWS控制台使对象无效

以下是使来自AWS Console的缓存对象无效的步骤。

  • 登录到AWS管理控制台并打开CloudFront控制台
  • 选择您要使文件无效的分发。
  • 选择分发设置,然后选择无效选项卡。
  • 选择创建无效并输入无效路径,例如“ originserver / image / IMG54330080 *”。 此通配符路径将删除为imageId“ IMG54330080

7.2使用CLI(命令行界面)使对象无效

以下命令为给定分发ID的CloudFront分发创建无效。 命令语法:

aws cloudfront create-invalidation --DistributionId --paths

例:

aws cloudfront create-invalidation --distribution-id K14EK9G5DZUEWO  --paths /originserver/image/IMG54330080*
{"Location": "https://cloudfront.amazonaws.com/2019-01-25/distribution/K14EK9G5DZUEWO/invalidation/IUNZX941WYQR8","Invalidation": {"Id": "IUNZX941WYQR8","Status": "InProgress","CreateTime": "2019-01-17T17:07:57.636Z","InvalidationBatch": {"Paths": {"Quantity": 1,"Items": ["/originserver/image/IMG54330080*"]},"CallerReference": "cli-324234242-463845"}}}

7.3通过AWS开发工具包使对象无效

以下Java代码段用于通过Amazon SDK使对象无效。

AWSCredentials awsCredentials = new DefaultAWSCredentialsProviderChain().getCredentials();AmazonCloudFrontClient client = new AmazonCloudFrontClient(awsCredentials);Paths invalidation_paths = new Paths().withItems("/originserver/image/IMG54330080*", "/image/path/imageA.jpg").withQuantity(1);InvalidationBatch invalidation_batch = new InvalidationBatch(invalidation_paths, "Asset_Image_Cache");CreateInvalidationRequest invalidation = new CreateInvalidationRequest("distributionID", invalidation_batch);CreateInvalidationResult ret = client.createInvalidation(invalidation);System.out.println("Invalidation result: " + ret.toString());

如果您将CloudFront配置为将查询参数转发到Origin Server,则在使文件无效时必须包括查询参数,因为CacheKey是使用创建缓存时包含的查询参数创建的。 例如

http://cdn.originserver.com/image/IMG54330080?category=headshot&type=high-resolution&width=220&height=330&aspectRatio=3.5

另外,您可以在无效网址中使用通配符*。 请注意,在这种情况下,所有具有与URL(带有通配符)匹配的CacheKeys的缓存条目都将失效。 例如

http://cdn.originserver.com/image/IMG54330080*

当新对象/更新对象上载到S3时,AWS Lambda函数还可用于使CloudFront对象无效。

如图6所示,当将更新的对象上传到S3时,它将触发Lambda函数,该函数会使CloudFront缓存中的对象无效。

图6 :通过Lambda函数使CloudFront对象无效

8.总结

AWS CloudFront是一项功能强大的内容缓存服务,可将内容快速提供给您的网站或应用程序的用户,而无需担心网站或应用程序的托管位置以及用户从何处访问您的应用程序。 将此服务与Lambda,S3等其他AWS服务一起使用可帮助创建动态缓存,因此可以将近实时数据快速提供给用户。 如果需要,还可以使CloudFront对象缓存无效。

翻译自: https://www.javacodegeeks.com/2019/02/dynamic-content-caching-with-aws-lambda-s3-and-aws-cloudfront.html

使用AWS Lambda,S3和AWS CloudFront进行动态内容缓存相关推荐

  1. aws lambda使用_使用AWS Lambda,S3和AWS CloudFront进行动态内容缓存

    aws lambda使用 快速提供内容对于任何网站或应用程序具有更好的客户体验都是必不可少的. 如果您将网站或应用程序托管在AWS Cloud中,那么无论从何处访问应用程序,都可以以较低的延迟快速提供 ...

  2. python的lambda函数错误的是_Python 中的 AWS Lambda 函数错误 - AWS Lambda

    Python 中的 AWS Lambda 函数错误 当您的代码引发错误时,Lambda 将生成错误的 JSON 表示形式.此错误文档会出现在调用日志中,对于同步调用,它出现在输出中. 例 lambda ...

  3. aws lambda使用, aws无服务器部署应用。 aws ecr凭证获取和使用。

    这里演示的是使用docker镜像进行服务创建 使用镜像进行创建服务 镜像上传 1. 先申请access key 和secret 登录aws控制台,右上角个人那里点击security credentia ...

  4. aws s3仅允许cloudfront访问_初创公司如何用AWS搭建高扩展性架构

    ‍‍‍‍ 亚信云天的理解 • 初创公司需要快.多.好.省的技术架构 o 快:针对业务需要可以快速获得资源与服务 o 多:拥有丰富的云服务可供选择,能不自己做就不自己做 o 好:强调扩展性和高可用,既不 ...

  5. aws lambda_AWS API Gateway和AWS Lambda示例

    aws lambda The purpose of this article is to present the most relevant details and not-so-straight s ...

  6. 什么是AWS Lambda?

    什么是AWS Lambda? 计算服务的演进 EC2------Container-------Lambda 虚拟机---容器--------------serverless无服务器架构 EC2(El ...

  7. 如何使用Node.js和CloudFormation在AWS Lambda中构建和部署GraphQL服务器

    介绍 (Introduction) I have been building GraphQL APIs in a Serverless environment for over 3 years now ...

  8. aws rds监控慢sql_使用AWS Lambda函数自动启动/停止AWS RDS SQL Server

    aws rds监控慢sql This article gives you an overview of the AWS Lambda function to automatically start a ...

  9. aws lambda_在AWS Lambda上运行“ Hello World”

    aws lambda Let's run the "Hello World" example on AWS Lambda. I would recommend reading ab ...

最新文章

  1. 脑机交互可提高行动能力
  2. 机器学习面试中常考的知识点,附代码实现(二)
  3. 我在河南安阳拍摄的一个山村小孩儿
  4. 苹果台式机_苹果史上最强台式机来了:顶配售价45万
  5. 程序猿的爱情--2011-12-27
  6. bootbox.js文档中文版
  7. 冲突域和广播域的理解
  8. 大创笔记——硬切法实现基于单片机的人机交互系统
  9. AngularJS总结
  10. 2021年煤矿瓦斯检查证考试及煤矿瓦斯检查模拟考试题
  11. 使用swagger api 下载excel,excel打不开
  12. 苹果手机密码设置在哪里_手机SIM卡怎么设置密码
  13. python爬取携程网旅游_爬取携程网(ajax动态加载)
  14. contains用法
  15. 云服务器虚拟ip绑定主机,如何在云平台上给云主机中的Keepalived的虚拟IP绑定弹性IP?...
  16. 会话验证调度器_用视力调度建立会话式预订机器人
  17. 《童梦奇缘-梦幻般的羁绊》第六章-残月
  18. HeadFirst:设计模式-观察者模式
  19. 《提问的艺术》读书笔记
  20. 全代码编写的iPhone界面源码1 UIView UILabel UIButton

热门文章

  1. Stack(nowcoder 11253-K)
  2. HDU5120 - Intersection
  3. 深度学习中反向传播算法简单推导笔记
  4. 25、sql分析命令explain和desc
  5. 禁用Cookie后,Session怎么样使用
  6. 汇编语言(二十六)之自然数求和
  7. 如何使用MAT进行JVM内存泄露分析
  8. 这些代码优化的方法,你都用过吗
  9. 同学们,看看这里吧!!!
  10. 154. 寻找旋转排序数组中的最小值 II(有手就行)