零基础5分钟上手亚马逊云科技-搭建CDN加速应用访问

news2024/11/7 5:07:00

简介:

欢迎来到小李哥全新亚马逊云科技AWS云计算知识学习系列,适用于任何无云计算或者亚马逊云科技技术背景的开发者,通过这篇文章大家零基础5分钟就能完全学会亚马逊云科技一个经典的服务开发架构方案。

我会每天介绍一个基于亚马逊云科技AWS云计算平台的全球前沿云开发/架构技术解决方案,帮助大家快速了解国际上最热门的云计算平台亚马逊云科技AWS最佳实践,并应用到自己的日常工作里。本次介绍的是如何利用亚马逊云科技上CDN服务CloudFront,挂载到网页服务器前,加速静态网页资源的访问。本方案架构图如下:

方案所需基础知识  

什么是亚马逊云科技CloudFront服务

Amazon CloudFront 是一项全球内容分发网络 (CDN) 服务,旨在加速分发网站、API、视频内容和其他 Web 资产。通过将内容缓存到遍布全球的边缘位置,CloudFront 能够显著降低用户访问的延迟,提高内容的加载速度,提供更快、更可靠的用户体验。

Amazon S3作为CloudFront CDN源站的优势

将 CloudFront 与 Amazon S3 相结合,可以实现高效的静态网站托管。S3 提供安全、可扩展的存储解决方案,而 CloudFront 则负责快速分发这些静态资源,如 HTML、CSS、JavaScript 文件和图片等。通过将 S3 上的网页资源挂载到 CloudFront,企业可以确保用户无论身处何地,都能以最快的速度访问网站内容。

这种组合的优势在于,它不仅提升了网站的加载速度,还通过 CloudFront 的安全功能,如 HTTPS 支持、DDoS 保护和内容访问控制,为网站提供了更强的安全性。此外,CloudFront 的按需扩展能力和全球覆盖范围,确保了网站在流量高峰期依然能够稳定、快速地响应用户请求。

通过利用 CloudFront 分发 S3 上的网页资源,企业可以轻松构建高性能、低延迟的全球化网站,提升用户体验的同时,确保内容的安全和可用性。这种架构非常适合希望优化网站性能、提高安全性,并简化内容交付流程的企业。

本方案包括的内容

1. 创建一个亚马逊云科技CloudFront服务

2. 利用CloudFront服务加速S3中的网页资源访问

项目搭建具体步骤 

1. 首先我们进入亚马逊云科技控制台,点击S3服务

2. 按照默认配置创建一个S3存储桶“cf-bucket-123444”,并点击进入。

3. 进入“Permission”页面,在“Block public access (bucket settings) ”界面点击Edit。

4. 取消勾选“Block all public access”,并点击Save保存。

5. 点击Upload上传一张图片/静态Html网页。

6. 同时将以下S3桶文件访问策略Policy,复制到“Permission”->"Bucket policy"页面中。

{
    "Version": "2012-10-17",
    "Statement": [
        {
            "Sid": "PublicReadGetObject",
            "Effect": "Allow",
            "Principal": "*",
            "Action": [
                "s3:GetObject"
            ],
            "Resource": [
                "arn:aws:s3:::cf-bucket-123444/*"
            ]
        }
    ]
}

7. 点击我们刚上传的图片文件

8. 点击Permissions页面,确认“Everyone (public access)”一行对应的Object、Object ACL的值都是“Read”

9. 接下来进入CloudFront服务主页。

10. 点击Create创建一个新的CloudFront CDN

11. 首先在“Origin Domain”源站处选择我们刚创建的S3桶

12. 在WAF配置中选择“Do not enable security protections”不添加WAF防护,最后点击Create创建CDN

13. 创建完成后,我们可以获取该CDN节点的URL,用于访问S3中的静态网页资源。

13. 我们在这个url后面加上我们上传网页资源的名字,如“d2daitzdl10m97.cloudfront.net/test.png”就可以访问到利用CDN加速的网页资源了。

如何通过Python代码创建Amazon CloudFront加速S3静态文件访问?

以下是一个利用AWS Boto3创建一个CloudFront分配并挂载到S3存储桶上以访问网页资源的Python代码示例

import boto3

# 创建S3客户端
s3 = boto3.client('s3')
bucket_name = 'your-s3-bucket-name'

# 创建CloudFront客户端
cloudfront = boto3.client('cloudfront')

# 创建一个新的CloudFront分配
response = cloudfront.create_distribution(
    DistributionConfig={
        'CallerReference': 'unique-string',  # 使用唯一字符串防止请求重复
        'Origins': {
            'Quantity': 1,
            'Items': [
                {
                    'Id': bucket_name,
                    'DomainName': f'{bucket_name}.s3.amazonaws.com',
                    'S3OriginConfig': {
                        'OriginAccessIdentity': ''
                    }
                }
            ]
        },
        'DefaultCacheBehavior': {
            'TargetOriginId': bucket_name,
            'ViewerProtocolPolicy': 'redirect-to-https',
            'TrustedSigners': {
                'Enabled': False,
                'Quantity': 0
            },
            'ForwardedValues': {
                'QueryString': False,
                'Cookies': {
                    'Forward': 'none'
                }
            },
            'MinTTL': 0
        },
        'Comment': 'CloudFront distribution for S3 website',
        'Enabled': True
    }
)

# 输出CloudFront分配的域名
distribution_domain_name = response['Distribution']['DomainName']
print(f'CloudFront Distribution Domain Name: {distribution_domain_name}')

代码说明:

创建S3和CloudFront客户端:

使用Boto3库创建S3和CloudFront客户端,用于与AWS服务进行交互。

配置CloudFront分配:

Origins 定义了CloudFront分配的源,这里指定了一个S3存储桶作为源。
DefaultCacheBehavior 配置了默认的缓存行为,包括指定的目标源ID和访问策略(例如强制使用HTTPS)。
Enabled 设置为 True 表示CDN一旦创建就立即启用。

输出CloudFront分配的域名:

当CloudFront分配创建成功,代码会打印出该分配的域名。这个域名是用于访问S3存储桶内容的CloudFront分配的公开URL。

以上就是在亚马逊云科技上利用CloudFront为S3托管的静态网页资源加速、提高访问性能的全部步骤。欢迎大家关注0基础5分钟上手AWS系列,未来获取更多国际前沿的AWS云开发/云架构方案。

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

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

相关文章

标准版v5.4安卓手机小程序扫码核销读取不到核销码的问题

修改这个文件,红色的那块代码替换成绿色的这段代码,然后重新打包上传。 文件地址:template/uni-app/pages/admin/order_cancellation/index.vue let path decodeURIComponent(res.path); self.verify_code path.split(‘code’)[1]; h5…

MTK的ATA工厂PCBA贴片验证测试

1.ATA测试就是PCBA硬件测试,目的如下 在工厂生产过程中,在PCB SMT贴装器件并烧录软件后,需要验证DUT(device under test)板上各个功能模块单元的driver基本功能是否正常,通过测试筛查出贴片异常或元器件物料异常等不良PCBA主板。 2.要进行此测试,MTK官方所要求的条件如下…

【C++】函数模板特化:深度解析与应用场景

📢博客主页:https://blog.csdn.net/2301_779549673 📢欢迎点赞 👍 收藏 ⭐留言 📝 如有错误敬请指正! 📢本文由 JohnKi 原创,首发于 CSDN🙉 📢未来很长&#…

【25届秋招】Shopee 0825算法岗笔试

目录 1. 第一题2. 第二题3. 第三题 ⏰ 时间:2024/08/25 🔄 输入输出:LeetCode格式 ⏳ 时长:2h 本试卷有10道单选,5道多选,3道编程。 整体难度非常简单,博主20min成功AK,这里只给出编…

Self-attention反向传播和梯度消失计算

文章目录 1、前言2、Self-attention的特点3、为什么是(Q, K, V)三元组4、归一化和放缩4.1、Normalization4.2、Scaled4.3、总结 5、Softmax的梯度变化5.1、Softmax函数的输入分布是如何影响输出的5.2、反向传播的过程中的梯度求导5.3、出现梯度消失现象的原因 6、维度与点积大小…

如何使用ssm实现固定资产管理系统

TOC ssm167固定资产管理系统jsp 绪论 1.1 选题背景 网络技术和计算机技术发展至今,已经拥有了深厚的理论基础,并在现实中进行了充分运用,尤其是基于计算机运行的软件更是受到各界的关注。计算机软件可以针对不同行业的营业特点以及管理需…

Golang测试func TestXX(t *testing.T)的使用

一般Golang中的测试代码都以xxx_test.go的样式,在命名测试函数的时候以Testxx开头。 以下是我写的一个单元: package testsimport "strings"func Split(s, sep string) (res []string) {i : strings.Index(s, sep)for i > -1 {res append…

常见虚拟现实硬件设备及特点

一、常见的虚拟现实设备介绍 (1)VR设备 (2)AR设备 (3)MR设备 二、各种虚拟现实设备的特点 序号种类设备沉浸感价格比较(元)占用场地等特点1VRPC主机普通显示器不是全沉浸6000就是办…

嵌入式UI开发-lvgl+wsl2+vscode系列:12、GUI Guider安装使用及在ssd202开发板上测试

一、前言 接下来我们根据开发板官方的指南安装lvgl的ui工具GUI Guider进行开发和测试。理论上还有SquareLine Studio,但是由于一些收费等因素暂时不做过多介绍,gui工具只是辅助,加快开发效率,很多时候还是得直接用代码写界面。&a…

睿考网:2024年中级经济师考试时间

报名时间:2024年8.12-9.11日 考试时间:2024年11.16-11.17日 成绩查询:2024年12月 报考条件: 1.高中毕业并取得初级经济专业技术资格,从事相关专业工作满10年; 2.具备大学专科学历,从事相关专业工作满6…

集团数字化转型方案(十三)

为了推动集团的数字化转型,我们将通过整合先进的信息技术、优化业务流程和提升数据分析能力,致力于实现全面的业务数字化,提升运营效率和市场竞争力。具体方案包括:引入人工智能和大数据分析工具,以精准数据驱动决策&a…

[C++] 异常详解

标题:[C] 异常详解 水墨不写bug 目录 一、错误处理方式 C语言 Java语言 二、异常的概念 三、异常的使用 1.异常的抛出和捕获(基本用法) 2.异常的重新抛出(特殊情况) 3.异常的规范和常见坑点 四、标准库的异常…

嵌入式UI开发-lvgl+wsl2+vscode系列:11、SSD202移植运行评估demo程序

一、前言 接下来我们根据开发板的LVGL指南移植lvgl的demo程序到开发板上,以及将一个评估的项目移植到开发板上,你将会发现移植lvgl到ssd2xx的板子上似乎很简单,但通过评估程序你将更加方便了解lvgl是否可以满足你的开发需求,除了…

JS 遍历请求数据,实现分页

JS 遍历请求分页 文章目录 JS 遍历请求分页效果图递归方式for循环 效果图 递归方式 const pageSize 10; // 假设每页10项/*** 接收页码和每页项数,返回Promise对象*/ function paginateData(page, pageSize) {return new Promise((resolve, reject) > {setTime…

用甜羊浏览器一键登录30个微店店铺的便捷之道

导语:微店是目前越来越受欢迎的电商平台,对于经营者来说,登录管理多个店铺可能是一项繁琐的任务。而甜羊浏览器的强大功能和智能体验,能够帮助用户轻松实现一键登录30个微店店铺,极大地提高了效率。本文将为大家介绍如…

3D打印随形透气钢:模具排气创新解决方案

在飞速发展的制造业中,技术的每一次飞跃都深刻影响着行业的进步。其中,3D打印随形透气钢技术的诞生,如同一股清新的风,为模具制造中的困气问题带来了革命性的解决方案。 简单来说,3D打印随形透气钢就是一项能够根据模具…

【Vue3教程】组件通信

组件通信 一、props二、自定义事件三、mitt四、v-model五、$attrs六、$refs 和 $parent七、provide&#xff0c;inject八、pinia九、插槽默认插槽具名插槽作用域插槽 总结 一、props 概述&#xff1a;props是使用频率最高的一种通信方式&#xff0c;常用与&#xff1a;父<—…

vue3 element-plus el-table 多层级表头动态渲染。

效果图: html: <el-table :data"arrlist" border style"width: 100%"><template v-for"(i, index) in currentFieldData" :key"index"><el-table-column :label"i.label" :header-D"i.headerAlign&q…

北京理工大学“源源不断”团队在全国大学生物联网竞赛中获得一等奖

在2024年8月24日结束的全国大学生物联网设计竞赛&#xff08;华为杯&#xff09;全国总决赛中的&#xff0c;北京理工大学的“源源不断”团队获得一等奖。 该团队的两名创始成员&#xff0c;张卓玉和杜智聪同学&#xff0c;曾在信息与电子学院李海老师的《智能物联网应用设计》…

vTable实现多维表格

介绍 vTable是字节开发的一款能用来渲染表格的库&#xff0c;是用canvas渲染&#xff0c;避免了传统用dom组件表格的一些问题&#xff0c;能很快的渲染出上万格子的表格。 接下来我将使用vTable构建类似下面的多维表格&#xff0c;其中quantity、sales等是指标。 使用 官网地址…