零基础5分钟上手亚马逊云科技-基础设施即代码开发

2024-08-29 11:52

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

简介:

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

我会每天介绍一个基于亚马逊云科技AWS云计算平台的全球前沿云开发/架构技术解决方案,帮助大家快速了解国际上最热门的云计算平台亚马逊云科技AWS最佳实践,并应用到自己的日常工作里。本次介绍的是如何利在亚马逊云科技上利用CloudFormation Infrastructure as Code (IaC)服务开发基础设施,提升版本更新部署效率,简化基础设施管理。

 

方案所需基础知识

什么是亚马逊云科技 CloudFormation 服务?

亚马逊云科技 CloudFormation 是一项基础设施即代码(Infrastructure as Code, IaC)服务,允许用户通过编写模板文件来自动化创建和管理 AWS 资源。CloudFormation 提供了一种简便的方法,使用户能够定义 AWS 资源的全部配置,包括计算、存储、数据库、以及网络资源,并将其部署为一个可重复使用的模板,从而简化复杂环境的设置和管理。

使用 CloudFormation 创建基础设施的优势

自动化与一致性

通过 CloudFormation,用户可以自动化创建和配置 AWS 资源,确保在不同环境中使用相同的模板部署基础设施。这样避免了手动配置可能导致的不一致性,提升了部署的可靠性和可重复性。

简化管理与更新

CloudFormation 允许用户以代码的形式定义基础设施,并可以在需要时轻松更新或扩展资源配置。通过模板,用户可以快速地对基础设施进行变更管理,而不必手动调整每个资源。

可视化与审计

CloudFormation 提供对资源创建和配置过程的完全可视化,使用户能够清晰地了解每个资源的状态。此外,由于模板文件记录了所有资源配置,审计和合规性检查也变得更加简单。

支持基础设施的版本控制

由于 CloudFormation 模板是代码文件,用户可以将其与代码库一起进行版本控制。这使得团队能够追踪基础设施配置的变更历史,轻松回滚到之前的版本,进一步提升了管理的灵活性和安全性。

本方案包括的内容

1. 开发亚马逊云科技基础设施及代码(IaC)资源脚本

2. 利用CloudFormation服务运行IaC脚本部署EC2服务器

3. 利用服务器启动脚本启动NGINX服务器

项目搭建具体步骤

1. 打开亚马逊云科技控制台,打开Cloud9云端IDE开发环境。

2. 点击Open进入到IDE中

 3. 创建一个空白文件”cloudformation.template“,这个就是CloudFormation的代码脚本格式,复制以下内容到脚本中,大家需要根据自己的服务器具体配置更新脚本中的???的值。该脚本定义了一个EC2服务器的配置信息,配置了NGINX的自启动Bash脚本,并输出创建的EC2 IP。

AWSTemplateFormatVersion: 2010-09-09
Description: >This template creates an Amazon EC2 instance. It installs and configuresthe Nginx web server via user data.Parameters:AmazonLinuxAMIID:Type: AWS::SSM::Parameter::Value<AWS::EC2::Image::Id>Default: /aws/service/ami-amazon-linux-latest/al2023-ami-kernel-6.1-x86_64Resources:WebServer:Type: AWS::EC2::InstanceProperties:ImageId: ???InstanceType: t3.microSecurityGroupIds:- ???SubnetId: ???UserData:Fn::Base64: !Sub |#!/bin/bashyum install -y nginxsystemctl enable nginxsystemctl start nginxOutputs:Website:Description: URL to siteValue: !Sub 'http://${WebServer.PublicIp}'

4. 接下来我们在IDE的命令行中运行以下命令,开始创建一个CloudFormation Stack用于创建EC2服务器。

aws cloudformation create-stack --stack-name nginx-Web-Server --template-body file://~/environment/cloudformation.template

得到输出如下,返回了该CloudFormation的Stack ARN ID:

******************************
**** This is OUTPUT ONLY. ****
******************************{"StackId": "arn:aws:cloudformation:us-west-2:111111111111:stack/nginx-Web-Server/bab88ad0-388b-11ee-aa2c-02f2933b4349"
}

5. 继续运行以下命令,可以查看该Stack的创建进度

aws cloudformation describe-stacks --stack-name "nginx-Web-Server" --query "Stacks[0].StackStatus"

如果得到以下回复"CREATE_COMPLETE",则表示该Stack创建成功。

******************************
**** This is OUTPUT ONLY. ****
******************************"CREATE_IN_PROGRESS"
"CREATE_IN_PROGRESS"
"CREATE_IN_PROGRESS"
"CREATE_COMPLETE"

6. 我们运行以下命令,可以返回创建的EC2服务器的Public IP:

aws cloudformation describe-stacks --stack-name "nginx-Web-Server" --query "Stacks[0].Outputs"

得到如下回复:

**************************************
**** This is EXAMPLE OUTPUT ONLY. ****
**************************************[{"OutputKey": "Website","OutputValue": "http://54.218.70.234","Description": "URL to site"}
]

7. 我们进入到CloudFormation服务主页

8. 可以查看到我们刚通过命令行创建的Stack资源,里面包含了一台EC2服务器

9.我们找到CloudFormation返回的EC2 IP,复制到浏览器中打开

10. 即可看到我们成功创建了一台运行NGINX的EC2服务器

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

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



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

相关文章

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

Spring Boot集成/输出/日志级别控制/持久化开发实践

《SpringBoot集成/输出/日志级别控制/持久化开发实践》SpringBoot默认集成Logback,支持灵活日志级别配置(INFO/DEBUG等),输出包含时间戳、级别、类名等信息,并可通过... 目录一、日志概述1.1、Spring Boot日志简介1.2、日志框架与默认配置1.3、日志的核心作用

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

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

PyQt5 GUI 开发的基础知识

《PyQt5GUI开发的基础知识》Qt是一个跨平台的C++图形用户界面开发框架,支持GUI和非GUI程序开发,本文介绍了使用PyQt5进行界面开发的基础知识,包括创建简单窗口、常用控件、窗口属性设... 目录简介第一个PyQt程序最常用的三个功能模块控件QPushButton(按钮)控件QLable(纯文本

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

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

Python实现MQTT通信的示例代码

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

基于Python开发一个图像水印批量添加工具

《基于Python开发一个图像水印批量添加工具》在当今数字化内容爆炸式增长的时代,图像版权保护已成为创作者和企业的核心需求,本方案将详细介绍一个基于PythonPIL库的工业级图像水印解决方案,有需要... 目录一、系统架构设计1.1 整体处理流程1.2 类结构设计(扩展版本)二、核心算法深入解析2.1 自

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

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