aws(学习笔记第二十课) codecommit以及codedeploy进行开发
aws(学习笔记第二十课)
- 使用
codecommit
以及codedeploy
进行开发
学习内容:
codecommit
,codebuild
以及codedeploy
的整体概念- 使用
codecommit
- 使用
codedeploy
1. 使用codecommit
codecommit
,codebuild
以及codedeploy
的整体概念-
CICD
的概念
CI/CD 是指持续集成(Continuous Integration)和持续部署(Continuous Deployment)或持续交付(Continuous Delivery)。- 团队协同在
github
上共同维护代码,之后发布到Test Server
上进行测试。 - 如果通过了测试,那么就会发布到
Prod Server
,即生产环境。
- 团队协同在
-
分支架构
- 全体项目以
master
为核心分支进行开发。 - 如果
enhancement
或者feature
对应,那么就会从master
分支checkout
出来dev
用的branch
。 - 团队在特定的
dev
分支上进行开发,发布到Test
环境进行测试。如果没有问题了,那么就会merge
进入master分支
,之后发布到Production
生产环境。 - 如果有紧急的需求,那么
Dev Lead will commit an urgent customer disruptive change into master branch
。
- 全体项目以
-
code pipeline
- 非
AWS
的环境code
管理使用Github
或者Bitbucket
。build
使用jenkins
。test
使用jenkins
。deploy
使用jenkins
或者other tooling
AWS
的环境 这里AWS
都采用自己的服务code
管理使用CodeCommit
build
使用CodeBuild
。test
使用CodeBuild
。deploy
使用CodeDeploy
- 非
-
开始构建
codecommit
- 进入
codecommit
在这里构建第一个codecommit repository
- 来到
IAM
作成用户,设置codecommit
的权限- 首先,定义策略,对于
codecommit
权限全部打开。
- 之后,限定访问的
repo
为刚刚创建的demo-repo
- 首先,定义策略,对于
- 作成用户,赋予刚才定义的
codecommit
策略
这里的用户名为demo-code-commit-user
- 取得作成好的用户的
AWS CodeCommit 的 HTTPS Git 凭证
选择下载https git
凭证
- 进入
-
启动
windows
的ec2
,尝试push
代码- 在
windows ec2
中安装git bash
- 在
-
输入上面建立用户的
credential
凭证
输入凭证,执行git clone
。
-
创建代码文件,执行
git
命令
-
在
codecommit
上确认代码文件
-
2. 使用codedeploy
-
全体架构
这里,按照如下步骤启动
codedeploy
- 作成一个
deploy destination ec2
- 作成
codecommit
,push
整个wordpress
的repository
,配置codedeploy
- 启动
codedeploy
,配置wordpress
到ec2
- 作成一个
-
启动
EC2
作为deploy destination
-
接下来的
user data
要执行codedeploy agent
的安装,所以在这里要赋予ec2
权限的role
注意,这里不赋予足够的权限的话,就没有在接下来的步骤执行./install auto
,进而不能按照codedeploy agent
,导致codepipeline
执行失败。
-
用户数据设定
#!/bin/bash yum install ruby -y aws s3 cp s3://aws-codedeploy-ap-northeast-2/latest/install . --region ap-northeast-1 chmod +x install ./install auto
-
-
启动另外一个
EC2
,作为模拟的开发主机
-
对于开发主机,进行代码的初期化。
wget https://s3-us-west-2.amazonaws.com/us-west-2-aws-training/courses/spl-82/v1.4.5.prod-2bbeba30/scripts/WordPress-master.zip
下载到
/home/ec2-user/wordpress
路径。
-
进行解压缩unzip
unzip WordPress-master.zip -d /home/ec2-user/wordpress_codecommit cd /home/ec2-user/wordpress_codecommit mv WordPress-master/ wordpress
-
为了
wordpress
工程的deploy
,创建deploy
用的scripts
目录mkdir -p /home/ec2-user/wordpress_codecommit/wordpress/scripts
-
创建
install_dependencies.sh
vi /home/ec2-user/wordpress_codecommit/wordpress/scripts/install_dependencies.sh #!/bin/bash yum install -y httpd wget php-fpm php-mysqli php-json php php-devel mariadb105-server
-
创建
start_serer.sh
vi /home/ec2-user/wordpress_codecommit/wordpress/scripts/start_server.sh #!/bin/bash systemctl start httpd systemctl enable httpd systemctl start mariadb systemctl enable mariadb
-
创建
stop_server.sh
vi /home/ec2-user/wordpress_codecommit/wordpress/scripts/stop_server.sh #!/bin/bash isExistApp=`pgrep httpd` if [[ -n $isExistApp ]]; then systemctl stop httpd fi isExistApp=`pgrep sql` if [[ -n $isExistApp ]]; then systemctl stop mariadb fi
-
创建数据库脚本
vi /home/ec2-user/wordpress_codecommit/wordpress/scripts/create_test_db.sh #!/bin/bash mysql -uroot <<CREATE_TEST_DB CREATE DATABASE IF NOT EXISTS test; CREATE_TEST_DB
-
创建
change_permissions.sh
脚本vi /home/ec2-user/wordpress_codecommit/wordpress/scripts/change_permissions.sh #!/bin/bash chmod -R 777 /var/www/html/WordPress
-
这些
shell
文件的统一入口,就是codedeploy
的/appspec.yml
vi /home/ec2-user/wordpress_codecommit/wordpress/appspec.yml version: 0.0 os: linux files: - source: / destination: /var/www/html/WordPress hooks: BeforeInstall: - location: scripts/install_dependencies.sh timeout: 300 runas: root AfterInstall: - location: scripts/change_permissions.sh timeout: 300 runas: root ApplicationStart: - location: scripts/start_server.sh - location: scripts/create_test_db.sh timeout: 300 runas: root ApplicationStop: - location: scripts/stop_server.sh timeout: 300 runas: root
-
扩大权限给
iam
策略
因为需要创建另外一个codecommit repository
,所以以前指定权限要扩大到所有的repo
-
创建
wordpress
的codecommit repository
-
提前安装
git
注意,使用sudo -i
,之后切换到ec2-user
yum install git
-
将
wordpress
代码,appspec.yml
和script
文件夹都git push
到仓库中git init git add . git commit -m "first version of wordpress
-
这是本地
repo
已经commit
完毕,执行git push
到远端git push https://git-codecommit.ap-northeast-1.amazonaws.com/v1/repos/wordpress
-
这时候会提示错误
-
按照提示执行即可
这里会提示输入密码和用户名,使用上面取得的凭证输入。git push --set-upstream https://git-codecommit.ap-northeast-1.amazonaws.com/v1/repos/wordpress master
检查远端repo
-
-
创建
codedeploy
的应用程序-
这里需要一个
codedeploy
的role
,提前创建,名字指定为codedeploy-role
-
接着创建
codedeploy
的应用程序
-
创建部署组
deploy group
这里,部署role
指定成上面创建的role
。
-
-
创建
codepipeline
进行真正的部署-
开始创建
codepipeline
-
创建一个新的
role
-
设定
codecommit
的源
-
跳过
codebuild
设定
-
最后创建
codepipeline
-
等待
codepipeline
的执行结果
-
执行成功
-
参照网上的
wordpress
的数据库步骤构建初始化DB
wordpress的DB初始化
这里省略接下来的步骤说明。
-