零基础5分钟上手亚马逊云科技-代码创建云原生基础设施

本文主要是介绍零基础5分钟上手亚马逊云科技-代码创建云原生基础设施,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

简介:

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

我会每天介绍一个基于亚马逊云科技AWS云计算平台的全球前沿云开发/架构技术解决方案,帮助大家快速了解国际上最热门的云计算平台亚马逊云科技AWS最佳实践,并应用到自己的日常工作里。本次介绍的是如何利在亚马逊云科技上利用AWS Serverless Application Model开发框架创建云原生基础设施,如”Amazon API Gateway, AWS Lambda, AWS CodePipeline“等,提升基础设施创建效率,简化管理。下面就是亚马逊云科技上最基础的云原生架构图:

方案所需基础知识

什么是亚马逊云科技 AWS SAM 框架?

亚马逊云科技 AWS Serverless Application Model(AWS SAM)是一种开源框架,专门用于构建无服务器应用程序。AWS SAM 提供了简化的语法,帮助开发者在 AWS 云上定义和部署无服务器资源,如 AWS Lambda 函数、API Gateway、DynamoDB 表等。通过 SAM,开发者可以使用一种类似于基础设施即代码服务 AWS CloudFormation 的方式来描述和管理整个无服务器应用程序的架构。

使用 AWS SAM 创建云原生基础设施的优势

简化无服务器应用开发

AWS SAM 提供了一种简洁的语法,可以显著减少编写基础设施代码的复杂性。开发者只需在代码中进行较少的配置,即可定义和部署复杂的无服务器架构,简化了开发过程,提高了生产效率。

通过本地环境开发和测试

AWS SAM 在本地环境即可代码调试和测试,允许开发者在本地环境中模拟 AWS Lambda、API Gateway 等服务的运行。这使得开发者能够在部署到云端前就进行调试和测试,从而减少错误和提升应用质量。

无缝集成 CI/CD

AWS SAM 与亚马逊云科技上的 DevOps 工具链紧密集成,支持自动化的持续集成和持续部署(CI/CD)。通过 SAM框架,开发者们可以轻松将无服务器应用程序集成到现有的 CI/CD 管道中,实现快速迭代和高效部署。

本方案包括的内容

1. 通过亚马逊云科技云端开发环境(IDE)Cloud9服务开发代码和AWS SAM脚本

2. 通过命令行一键部署云端应用和基础设施

3. 通过部署的云原生API访问云端应用服务获取API响应

项目搭建具体步骤

1. 打开亚马逊云科技控制台,进入到cloud9服务

2. 点击Open打开云端IDE

3. 我们创建一个空白Python文件”app.y“,复制以下内容,用于通过API获取S3桶内的网页资源

import boto3
s3 = boto3.client('s3')def lambda_handler(event, context):obj = s3.get_object(Bucket='sourcefiles-us-west-2-444987022', Key='object1')contents = "These are not the contents you are looking for."return {"result": contents}

同时我们需要安装必要依赖”boto3“ SDK

pip install boto3

4. 接下来我们创建空白的SAM脚本文件"template.yaml",复制以下内容,用于创建云端基础设施云原生计算服务Lambda,以及API管理服务API Gateway。

AWSTemplateFormatVersion: '2010-09-09'
Transform: AWS::Serverless-2016-10-31Resources:LabFunction:Type: AWS::Serverless::FunctionProperties:Role: !Sub arn:aws:iam::${AWS::AccountId}:role/sam-lab-GetObject1FunctionRoleCodeUri: LabFunction/Handler: app.lambda_handlerRuntime: python3.9Architectures:- x86_64Policies:- S3ReadPolicy:BucketName: sourcefiles-us-west-2-444987022Events:Sum:Type: HttpApiProperties:Path: /labfunctionMethod: getApiId: !Ref HttpApiHttpApi:Type: AWS::Serverless::HttpApiProperties:StageName: "$default"Outputs:HttpApiUrl:Description: URL of your API endpointValue:Fn::Sub: 'https://${HttpApi}.execute-api.${AWS::Region}.${AWS::URLSuffix}/labfunction'

5. 接下来我们运行以下命令开始构建该AWS SAM脚本,用于下载必要依赖,编译代码和封装部署资源包

sam build

构建成功后会出现以下响应

******************************
**** This is OUTPUT ONLY. ****
******************************Building codeuri: /home/ec2-user/environment/LabFunction runtime: python3.9 metadata: {} architecture: x86_64 functions: LabFunction
Running PythonPipBuilder:ResolveDependencies
Running PythonPipBuilder:CopySourceBuild Succeeded

6. 接下来按照以下命令开始部署构建好的AWS SAM脚本

sam deploy --guided

部署成功后会收到如下响应:

******************************
**** This is OUTPUT ONLY. ****
******************************Configuring SAM deploy
======================Looking for config file [samconfig.toml] :  Not foundSetting default arguments for 'sam deploy'=========================================Stack Name [sam-app]: AWS Region [us-west-2]: #Shows you resources changes to be deployed and require a 'Y' to initiate deployConfirm changes before deploy [y/N]: #SAM needs permission to be able to create roles to connect to the resources in your templateAllow SAM CLI IAM role creation [Y/n]: #Preserves the state of previously provisioned resources when an operation failsDisable rollback [y/N]: LabFunction may not have authorization defined, Is this okay? [y/N]: ySave arguments to configuration file [Y/n]: SAM configuration file [samconfig.toml]: SAM configuration environment [default]:  Looking for resources needed for deployment:Managed S3 bucket: aws-sam-cli-managed-default-samclisourcebucket-1u3fu7o3gelcqA different default S3 bucket can be set in samconfig.tomlSaved arguments to config fileRunning 'sam deploy' for future deployments will use the parameters saved above.The above parameters can be changed by modifying samconfig.tomlLearn more about samconfig.toml syntax at https://docs.aws.amazon.com/serverless-application-model/latest/developerguide/serverless-sam-cli-config.htmlUploading to sam-app/6ef47c0da3e463d20af67dde5dfed4ef  11580021 / 11580021  (100.00%)Deploying with following values===============================Stack name                   : sam-appRegion                       : us-west-2Confirm changeset            : FalseDisable rollback             : FalseDeployment s3 bucket         : aws-sam-cli-managed-default-samclisourcebucket-1u3fu7o3gelcqCapabilities                 : ["CAPABILITY_IAM"]Parameter overrides          : {}Signing Profiles             : {}CloudFormation outputs from deployed stack
--------------------------------------------------------
Outputs                                                                                                                                                                                                                      
--------------------------------------------------------
Key                 HttpApiUrl                                                                                                                                                                                               
Description         URL of your API endpoint                                                                                                                                                                                 
Value               https://8874ni1cuc.execute-api.us-west-2.amazonaws.com/labfunction                                                                                                                                       
--------------------------------------------------------Successfully created/updated stack - sam-app in us-west-2

 部署成功后我们可以看到该脚本返回了一个我们云原生服务的API URL(末尾HttpApiUrl的键值),该URL是亚马逊云科技上的API管理服务API Gateway暴露的公开URL,复制该URL。

7. 共有两种方法访问该API URL并进行测试

1)命令行形式:

在命令行中我们运行curl访问API获取格式化相应

echo; curl https://onw4cvuz5k.execute-api.us-west-2.amazonaws.com/labfunction; echo; echo

 我们可以得到API调用的回复如下,该API从S3中提取了网页文件对象并通过API返回。

******************************
**** This is OUTPUT ONLY. ****
******************************{"result": "Welcome to AWS Lambda!"}

2)直接在浏览器中打开,也可以得到通过调用云原生API返回的S3中的文字网页资源。

以上就是在亚马逊云科技上利用AWS SAM框架开发代码,创建云资源基础设施的全部步骤。欢迎大家关注0基础5分钟上手AWS系列,未来获取更多国际前沿的AWS云开发/云架构方案。

这篇关于零基础5分钟上手亚马逊云科技-代码创建云原生基础设施的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1120933

相关文章

Django开发时如何避免频繁发送短信验证码(python图文代码)

《Django开发时如何避免频繁发送短信验证码(python图文代码)》Django开发时,为防止频繁发送验证码,后端需用Redis限制请求频率,结合管道技术提升效率,通过生产者消费者模式解耦业务逻辑... 目录避免频繁发送 验证码1. www.chinasem.cn避免频繁发送 验证码逻辑分析2. 避免频繁

精选20个好玩又实用的的Python实战项目(有图文代码)

《精选20个好玩又实用的的Python实战项目(有图文代码)》文章介绍了20个实用Python项目,涵盖游戏开发、工具应用、图像处理、机器学习等,使用Tkinter、PIL、OpenCV、Kivy等库... 目录① 猜字游戏② 闹钟③ 骰子模拟器④ 二维码⑤ 语言检测⑥ 加密和解密⑦ URL缩短⑧ 音乐播放

python panda库从基础到高级操作分析

《pythonpanda库从基础到高级操作分析》本文介绍了Pandas库的核心功能,包括处理结构化数据的Series和DataFrame数据结构,数据读取、清洗、分组聚合、合并、时间序列分析及大数据... 目录1. Pandas 概述2. 基本操作:数据读取与查看3. 索引操作:精准定位数据4. Group

Python使用Tenacity一行代码实现自动重试详解

《Python使用Tenacity一行代码实现自动重试详解》tenacity是一个专为Python设计的通用重试库,它的核心理念就是用简单、清晰的方式,为任何可能失败的操作添加重试能力,下面我们就来看... 目录一切始于一个简单的 API 调用Tenacity 入门:一行代码实现优雅重试精细控制:让重试按我

一文解密Python进行监控进程的黑科技

《一文解密Python进行监控进程的黑科技》在计算机系统管理和应用性能优化中,监控进程的CPU、内存和IO使用率是非常重要的任务,下面我们就来讲讲如何Python写一个简单使用的监控进程的工具吧... 目录准备工作监控CPU使用率监控内存使用率监控IO使用率小工具代码整合在计算机系统管理和应用性能优化中,监

Python实现MQTT通信的示例代码

《Python实现MQTT通信的示例代码》本文主要介绍了Python实现MQTT通信的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录1. 安装paho-mqtt库‌2. 搭建MQTT代理服务器(Broker)‌‌3. pytho

MySQL进行数据库审计的详细步骤和示例代码

《MySQL进行数据库审计的详细步骤和示例代码》数据库审计通过触发器、内置功能及第三方工具记录和监控数据库活动,确保安全、完整与合规,Java代码实现自动化日志记录,整合分析系统提升监控效率,本文给大... 目录一、数据库审计的基本概念二、使用触发器进行数据库审计1. 创建审计表2. 创建触发器三、Java

IntelliJ IDEA2025创建SpringBoot项目的实现步骤

《IntelliJIDEA2025创建SpringBoot项目的实现步骤》本文主要介绍了IntelliJIDEA2025创建SpringBoot项目的实现步骤,文中通过示例代码介绍的非常详细,对大家... 目录一、创建 Spring Boot 项目1. 新建项目2. 基础配置3. 选择依赖4. 生成项目5.

Linux线程之线程的创建、属性、回收、退出、取消方式

《Linux线程之线程的创建、属性、回收、退出、取消方式》文章总结了线程管理核心知识:线程号唯一、创建方式、属性设置(如分离状态与栈大小)、回收机制(join/detach)、退出方法(返回/pthr... 目录1. 线程号2. 线程的创建3. 线程属性4. 线程的回收5. 线程的退出6. 线程的取消7.

创建Java keystore文件的完整指南及详细步骤

《创建Javakeystore文件的完整指南及详细步骤》本文详解Java中keystore的创建与配置,涵盖私钥管理、自签名与CA证书生成、SSL/TLS应用,强调安全存储及验证机制,确保通信加密和... 目录1. 秘密键(私钥)的理解与管理私钥的定义与重要性私钥的管理策略私钥的生成与存储2. 证书的创建与