aws(学习笔记第四十六课) codepipeline-build-deploy
文章目录
- aws(学习笔记第四十六课) codepipeline-build-deploy
- 学习内容:
- 1. 代码链接及整体架构
- 1.1 代码链接
- 1.2 整体架构
- 1.2.1 初始化阶段的`codecommit repo`以及`codebuild project`设定
- 1.2.2 创建`vpc`,`public alb`,`alb listener`以及`fargate service`等
- 1.2.3 创建`source`,`build`以及`deploy`等`stage`以及`deplyment group`,将部署和`alb listener`进行关联
- 2. 代码详细分析
- 2.1 初始化阶段代码,创建`codecommit repo`以及`codebuild project`
- 2.1.1 创建`codecommit repo`
- 2.1.2 创建`Elastic Container Registry (ECR) image repository`
- 2.1.3 创建`fargate task definition`
- 2.1.4 创建`code build project`
- 2.1.5 对`build project`赋予权限,对`imaga repo`能够`push image`
- 2.1.6 初始化阶段使用`lambda`进行`code build project`触发
- 2.1.7 在初始化阶段创建`custom resource`触发上面`lambda`
- 2.2 创建`vpc`,`public alb`,`alb listener`以及`fargate service`等
- 2.2.1 创建`vpc`
- 2.2.1 创建`target group green`以及`target group blue`
- 2.2.2 创建`application loader balancer`的`security group`以及入站规则
- 2.2.3 创建`application loader balancer`以及`listener`
- 2.2.4 创建`fargate service`
- 2.3 创建`source`,`build`以及`deploy`等`stage`以及`deplyment group`,将部署和`alb listener`进行关联
- 2.3.1 创建`source stage`
- 2.3.2 创建`build stage`
- 2.3.3 创建`deployment group`
- 2.3.4 创建`deploy stage`,并将`deployment_group`指向上面创建的`deployment group`
- 2.3.5 将`source`,`build`,`deploy`组合成`pipeline`
- 3. 执行`cdk`
- 3.1 执行命令
- 3.2 访问`endpoint`
- 3.3 修改代码进行改修和自动部署
- 3.3.1 检查`codecommit`
- 3.3.2 创建`IAM user`进行代码`commit`
- 3.3.3 为`IAM user finlay`指定公钥(public key)
- 3.3.4 设定用户的`config`文件
- 3.3.5 对代码进行clone
- 3.3.6 对`codecommit`进行改修,并`push`
- 3.3.7 检验修改后的页面
- 4. cleanup
aws(学习笔记第四十六课) codepipeline-build-deploy
- 使用
codebuild
- 尝试
codedeploy
学习内容:
- 定义
codebuild
- 使用
codedeploy
1. 代码链接及整体架构
1.1 代码链接
代码连接(codepipeline-build-deploy)
1.2 整体架构
整体架构分为三个部分:
- 初始化阶段,创建
codecommit repo
以及codebuild project
- 创建
vpc
,public alb
,alb listener
以及fargate service
等 - 创建
source
,build
以及deploy
等stage
以及deplyment group
,将部署和alb listener
进行关联
1.2.1 初始化阶段的codecommit repo
以及codebuild project
设定
这里,trigger code build
分为两个阶段:
- 初期阶段,通过
custom resource
创建 ==>trigger lambda
执行 ==>trigger code build project
- 平时运用阶段,通过
code commit
的push
==>trigger code build project
1.2.2 创建vpc
,public alb
,alb listener
以及fargate service
等
这些组件都是真正运行服务的部分。
- 首先生成一个
Application Loader Balancer
- 对这个
Application Loader Balancer
设定listener
- 之后生成
Target Group Green
和Target Group Blue
这里实现蓝绿部署 - 对
Application Loader Balancer Listener
设定default
的target group
,这里设定为Target Group Green
1.2.3 创建source
,build
以及deploy
等stage
以及deplyment group
,将部署和alb listener
进行关联
- 创建
source stage
,input
为code repo
source stage
将整个code repo
生成source artifact
- 创建
build stage
,input
为source artifact
build stage
对整个source artifact
进行build
,主要是使用buildspec.yaml
build stage
进行完docker build
之后,将生成的docker image
上传到ecr
build stage
进行完docker build
之后,生成出deploy stage
需要的appspec.yaml && cat taskdef.json
deploy stage
使用appspec.yaml && cat taskdef.json
对整个deployment group
进行部署
2. 代码详细分析
2.1 初始化阶段代码,创建codecommit repo
以及codebuild project
2.1.1 创建codecommit repo
# Creates an AWS CodeCommit repositorycode_repo = codecommit.Repository(self, "CodeRepo",repository_name="simple-app-code-repo",# Copies files from app directory to the repo as the initial commitcode=codecommit.Code.from_directory("app", "main"))
2.1.2 创建Elastic Container Registry (ECR) image repository
# Creates an Elastic Container Registry (ECR) image repositoryimage_repo = ecr.Repository(self, "ImageRepo")
2.1.3 创建fargate task definition
# Creates a Task Definition for the ECS Fargate servicefargate_task_def = ecs.FargateTaskDefinition(self, "FargateTaskDef")fargate_task_def.add_container("Container",container_name="web",image=ecs.ContainerImage.from_ecr_repository(image_repo),port_mappings=[{"containerPort": 80}])
这里,创建一个container(docker)
,并将端口映射出80
。
2.1.4 创建code build project
# CodeBuild project that builds the Docker imagebuild_image = codebuild.Project(self, "BuildImage",build_spec=codebuild.BuildSpec.from_source_filename("buildspec.yaml"),source=codebuild.Source.code_commit(repository=code_repo,branch_or_ref="main"),environment=codebuild.BuildEnvironment(privileged=True),environment_variables={"AWS_ACCOUNT_ID": codebuild.BuildEnvironmentVariable(value=os.getenv('CDK_DEFAULT_ACCOUNT') or ""),"REGION": codebuild.BuildEnvironmentVariable(value=os.getenv('CDK_DEFAULT_REGION') or ""),"IMAGE_TAG": codebuild.BuildEnvironmentVariable(value="latest"),"IMAGE_REPO_NAME": codebuild.BuildEnvironmentVariable(value=image_repo.repository_name),"REPOSITORY_URI": codebuild.BuildEnvironmentVariable(value=image_repo.repository_uri),"TASK_DEFINITION_ARN": codebuild.BuildEnvironmentVariable(value=fargate_task_def.task_definition_arn),"TASK_ROLE_ARN": codebuild.BuildEnvironmentVariable(value=fargate_task_def.