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

快速提供内容对于任何网站或应用程序具有更好的客户体验至关重要。 如果您将网站或应用程序托管在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所示。

动态内容缓存-创建CloudFront分发
图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缓存中的对象无效。

动态内容缓存-使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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/343861.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

数据光端机设备性能指标介绍

作为安防监控工程,设备的可靠性应该是第一考虑要素。而数据光端机设备的可靠性是设备厂商在产品设计时就必需考虑的,但是,有些厂商可能会因为某些原因而不愿做或不知道怎么做这方面的工作,在这里着重从工程的角度简单地讨论以下问…

光电转换器有什么作用?光纤收发器如何保养?

光电转换器可以使原来的快速以太网平滑升级,并能充分保护用户原来的网络资源,它也可以称为光纤收发器。光电转换器可以实现交换机和计算机之间的互联,也可以作为传输中继,还可以进行单多模转换。光纤收发器在应用过程中&#xff0…

html中输出PHP的下拉列表,html中关于下拉列表select的图文代码详解

HTML中的下拉列表:Html代码VolvoSaabOpelAudi其中select是显示一个下拉列表(drop down list)出来,option是下拉列表中的项目(item),而option的文本内容(text content)是下拉列表项目中显示到页面上的值,value是真正需要提交到服务…

光纤收发器tx和rx的区别?

光纤收发器,是一种将短距离的双绞线电信号和长距离的光信号进行互换的以太网传输媒体转换单元,在很多地方也被称之为光电转换器(Fiber Converter)。产品一般应用在以太网电缆无法覆盖、必须使用光纤来延长传输距离的实际网络环境中…

光纤收发器元件级和整机测试内容介绍

对光纤收发器的测试可分为元件级和整机测试,元件级测试主要包括对光纤收发器内部关键器件在电工作的电性能测试。整机测试主要指将光纤收发器接入到以太局域网中,测试整机的功能、性能和特性。那么,具体要怎样测试光纤收发器才是一次完整的测…

如何判断光纤收发器是否有问题?

一般情况下,光纤收发器或光模块的发光功率如下:多模在10db--18db之间;单模20公里在-8db--15db之间;而单模60公里则在-5db--12db之间。但如是光纤收发器的发光功率出现在-30db--45db之间,那么,很有可能这个光…

activemq 实例_在一台计算机上运行多个ActiveMQ实例

activemq 实例几周前,我再次通过Mule ESB解决方案将Apache ActiveMQ用作JMS提供程序。 由于使用ActiveMQ已经有几年了,所以我认为最好检查一些(新)功能,例如故障转移传输和其他群集功能 。 为了能够测试这些最后的东西…

什么是光纤收发器?光纤收发器作用是什么?

许多朋友一听到光纤收发器这五个大字总会有困惑,比如说什么是光纤收发器,光纤收发器又有什么作用等等疑问。那么,什么是光纤收发器呢?光纤收发器又有什么作用呢?接下来我们就跟随飞畅科技的小编一起来详细了解下吧&…

在15分钟内使用Spring Boot和Spring Security构建一个Web应用程序

“我喜欢编写身份验证和授权代码。” 〜从来没有Java开发人员。 厌倦了一次又一次地建立相同的登录屏幕? 尝试使用Okta API进行托管身份验证,授权和多因素身份验证。 开发人员知道保护Web应用程序安全可能会很麻烦。 正确地做是很难的。 最糟糕的是&…

音频光端机的必备要素有哪些?

音频光端机就是发射端把传统的音频模拟信号转换成光信号,通过光纤传输到接收端,在接收端再转换成模拟信号的一种音频设备。那么,音频光端机有哪些必备要素呢?音频光端机的原理是什么呢?接下来我们就一起来详细了解下吧…

16路开关量光端机产品功能及接线图

飞畅科技生产的16路开关量光端机,可以使开关量信号通过光缆在光纤上传输双向控制。全数字光传输通道,确保高质量的信号传输。面板上有电源指示灯、光信号指示灯数据信号指示灯,可以直观的检测电源、光信号、数据信号状态。单向系列开关量光端…

matlab查找替换指令,使用matlab GUI在.txt文件中编辑特定数字使用搜索/替换

使用matlab GUI在.txt文件中编辑特定数字使用搜索/替换 我有一堆不同的模板.txt文件,我想由Matlab中的用户访问。这些模板看起来像这样,但是有一些主要的区别,我将解释:LOAD BOX 1 SUBJ M1_299633_D295158_JUN191910_Aut_ERROR2 E…

电话光端机安装步骤详解

光端机是光信号传输的终端设备,其主要作用是把传统的电话信号转换成光信号并在光纤上传输的设备,是随着光线技术的发展而出现的光端机产品。那么,电话光端机是怎么安装的呢?今天就由飞畅科技的小编来为大家介绍下电话光端机的详细…

php 站内搜索引擎,淘特站内搜索引擎For PhoCmsV9.4

一、产品特点:该产品是淘特站内搜索引擎For PhpCmsV9特别定制版,系统安装后,就可以索引、模糊查询PhpCmsV9的文章数据了(无需连接数据库哦)二、产品下载:三、使用说明:提示:本系统已和tomcat7打包&#xff…

交换机组网常见九大故障问题

交换机是一种用于电信号转发的网络设备。它可以为接入交换机的任意两个网络节点提供独享的电信号通路。最常见的交换机是以太网交换机。其他常见的还有电话语音交换机、光纤交换机等。那么,交换机组网常见九大故障问题有哪些呢?接下来我们就跟随飞畅科技…

python qtdesigner安装,PyCharm+Qt Designer+PyUIC安装配置教程详解

Qt Designer用于像VC的MFC一样拖放、设计控件PyUIC用于将Qt Designer生成的.ui文件转换成.py文件Qt Designer和PyUIC都包含在PyQt5中,所以我们只需要安装PyQt5塻块然后再指定Qt Designer和PyUIC即可为了避免篇幅过长,本文只讲安装配置,使用可…

可网管交换机的三种管理方式介绍

交换机的按是否可网管,分为可网管交换机和不可网管交换机,可网管交换机可以通过以下几种途径进行管理:通过RS-232串行口(或并行口)管理、通过网络浏览器管理和通过网络管理软件管理。接下来就由杭州飞畅科技来为大家详…

ping cat.flag.php,关于2020年强网杯-强网先锋-主动的赛题解析

原标题:关于2020年强网杯-强网先锋-主动的赛题解析一、基本信息(总概述)本题涉及知识点:命令执行正则匹配linux命令绕过二、基本环境和工具Linux系统PHPApacheFirefoxIndex.phpFlag.php三、Writeup1、根据题目要求还原实验环境首先在Linux虚拟机上安装Ap…

使用Prometheus发现在Kubernetes上运行的应用程序

Prometheus支持抓取应用程序的多个实例。 由于其IP地址会发生变化,因此需要动态发现在协调环境中运行的应用程序。 可以将Prometheus配置为使用Kubernetes API动态地发现正在运行的实例列表中的更改。 下面显示了一个简单的Prometheus示例,该示例对具有…

可网管交换机与非网管交换机的区别

交换机的种类按是否可网管,交换机分为可网管交换机和不可网管交换机。那么,可网管交换机与非网管交换机的区别主要体现在哪里呢?接下来我们就跟随飞畅科技的小编一起来详细了解下吧! 一、可网管交换机与非网管交换机的区别 不可网…