AWS – Serverless解决方案
- 使用cognito 做身份验证,然后得到授权使用API,然后trigger lambda往dynamoDB进行数据调用
data:image/s3,"s3://crabby-images/c991c/c991c169e98630f90831bd0ea2c01b73faa32b08" alt=""
2. 使用cognito生成一个暂时的STS Token以便暂时访问S3的文件
data:image/s3,"s3://crabby-images/6df5a/6df5a3b8f9818d6eda69fd26f573ad6aa8b10f5e" alt=""
3. 结合以上两种架构,以下的图片就添加了DAX为DynamoDB减轻了读取的压力,而且也能够在API Gateway当中做response的缓存(能够自定义TTL)
data:image/s3,"s3://crabby-images/c8bed/c8bed3bf91330911b3a4b339cfb0d06983b18969" alt=""
【需求1】
data:image/s3,"s3://crabby-images/36122/36122cd50ecb40a8dfe8e33e725e050e1608fbff" alt=""
解答:根据以下的两张结构图当中,为了达到这个需求
- S3 设置了bucket policy 只能允许CloudFront 访问 (OAC)
- CloudFront能够全球缓存静态文件 (CDN)
- 对于dynamic的REST API就访问API Gateway,然后触发DynamoDB的读写
- 在DynamoDB前面添加DAX缓存层,以减缓DynamoDB的负载
- 当new user的数据写入DynamoDB当中就触发了DynamoDB Stream
- DynamoDB Stream就会调用lambda使用SES向用户发送welcome email
- 为了让上传的图片生成thumbnail,可以开启S3 Transfer Accelerator以便全球加速上传到某个region的bucket当中
- 当S3收到上传的图片之后就会触发lambda去生成thumbnail,然后把新生成的thumbnail再出入S3内,接着可以触发SQS或SNS
- 如果是非常需要全球架构的话,DynamoDB可以开启GlobalTable, 和Lambda可以使用Lambda@Edge
data:image/s3,"s3://crabby-images/06c95/06c95bacb494aedd3f90c891d2dc61876c74e874" alt=""
data:image/s3,"s3://crabby-images/8d145/8d145ca8523b3d1d6cdb4d73d8278cc15a0dd75d" alt=""
【需求2】微服务架构
- 可以自定义弹性使用想要的架构
- 每个服务可以互相访问获取数据,都是decoupling的结构
- Service1是典型的serverless 容器服务的架构
- Service2是典型的serverless代码的服务架构
- Service3是典型的EC2弹性扩张的服务架构
data:image/s3,"s3://crabby-images/16c1d/16c1d46e3d6b13ebad2ae7c30410fb238e1584ee" alt=""
Facebook评论