当前位置: 首页 > news >正文

一文讲透亚马逊云三层架构

关于三层架构,我们有很多想说的话:
(以下内容以下都在VPC中)

  1. cloudfront做CDN加速
  2. 网关规划
  3. S3做静态网站托管
  4. APIGateway作为统一网关入口+认证/限流
  5. Lambda 作为传统后端,并发,底层架构
  6. Redis缓存
  7. DDB作为持久化存储
    在这里插入图片描述

网络规划

出于HA的目的,我们用三个可用去来部署应用,由于VPC甚至子网的CIDR是不可变的,那么我们要前期规划好这个划分。

一般来讲我们是前后端分离的模式,所以在每个可用区会把前端,后端,数据库放在独立的子网里面,当然也需要预留一些IP地址的空间来应对后面的新需求,所以对于三个可用区而言要划分12个子网,当然如果再想预留一个AZ的空间也没关系,那就是一个VPC划分16个子网,现在用到9个,剩下7个用来应对以后不确定的业务需要。当然这个只是一个比较推荐的做法,可以根据业务需要做对应的调整。
在这里插入图片描述

认证以及流控

然后到后端,APIGateway提供了一系列的认证方式,包括Cognito集成Cognito用户池进行登录,也支持集成OIDC IDP使用JWT的认证,甚至也可以使用Lambda来做自定义的身份认证,访问需要授权的路由的时候会先进入到授权方的模块,然后再根据结果区访问目标的路由。
可以使用APIKEY做流量的的控制(header 中带api-key)。

在这里插入图片描述

后端应用

然后是后端,对于无服务而言我们后端一般都是Lambda,当然我们现在讨论的都在VPC的情况,这样lambda会在所在子网内生成一张网卡,所以效果是,公有的访问流量通过APIGateway转发到lambda,然后lambda使用VPC内的网卡来访问内网的数据库,比如redis,RDS,dynamoDB。
在这里插入图片描述

如果是传统后端上云,由于放在lambda上会更改项目代码,也可以选择部署到EC2上,然后使用NLB做负载均衡以及水平的弹性。这样的架构也可以使用VPC Link来集成到APIGatey中。
在这里插入图片描述

关于缓存:

  1. 延迟加载:查询时候没有命中缓存,在DB中查到数据,再把这条写到缓存中。
  2. 直写:写DB的时候直接更新缓存。
  3. TTL: 空间有限,设置缓存过期时间,防止大量缓存过期,TTL尽可能的打散。

【1】https://docs.aws.amazon.com/zh_cn/whitepapers/latest/serverless-multi-tier-architectures-api-gateway-lambda/single-page-application.html
【2】https://aws.amazon.com/cn/blogs/compute/understanding-vpc-links-in-amazon-api-gateway-private-integrations/
【3】https://aws.amazon.com/cn/caching/best-practices/

http://www.lryc.cn/news/345993.html

相关文章:

  • 只需3步,使用Stable Diffusion无限生成AI数字人视频(附安装包)
  • RustGUI学习(iced)之小部件(七):如何使用图像image部件来显示图片?
  • Substrate 入门课第 14 期圆满结束,岗位内推直达知名 Web3 项目!
  • android进阶-AIDL
  • 贪心算法-活动选择问题背包问题
  • Web3工具集合 - 00
  • 分布式与集群的区别
  • 学习心得:如何开始学习一款MCU
  • 顺序表的实现(迈入数据结构的大门)(1)
  • RERCS系统-WDA+BOPF框架实战例子 PART 1-新建List UIBB(列表组件)并分配Feeder Class和Node Element
  • 如何从 iPhone 恢复已删除或丢失的联系人?
  • RISCV 外部GCC 工具链安装@FreeBSD15
  • 全栈开发之路——前端篇(9)插槽、常用api和全局api
  • 减瘦误区、雷点、陷阱和挑战怎么应对
  • Leetcode—946. 验证栈序列【中等】
  • Selenium定位方法及代码
  • GitHub搭建免费博客
  • 开源代码分享(28)-含分布式光伏的配电网集群划分和集群电压协调控制
  • idea-自我快捷键-2
  • 深入学习指针3
  • 礼赞劳动节,致敬劳动者。节日随想:疾笔耕耘也是一种劳动方式。
  • 学习Java的日子 Day45 HTML常用的标签
  • 兔子与狮子
  • GNU/Linux - 系统启动流程及rcS脚本介绍
  • 对象,字符串的解构赋值
  • Django 静态文件管理与部署指南
  • ORACLE ODAX9-2的一个误告警Affects: /SYS/MB的分析处理
  • Spring AOP浅谈
  • 数据结构——图的基础知识与其表示
  • 数据库管理-第187期 23ai:怎么用SQL创建图(20240510)