Skip to content

Latest commit

 

History

History
61 lines (42 loc) · 3.15 KB

README.md

File metadata and controls

61 lines (42 loc) · 3.15 KB

AWS CodeCommit based devops model

简体中文版本

Now this best practice model works on both AWS Global and AWS China regions.

The complete walkthrough can refer to this blog post.

AWS CodeCommit is a managed, secure and git based source code management service. AWS CodeCommit helps enterprise users to set up secure and managed SCM. Though it does not provide the social related features(such as forking and liking) in Github or Gitlab. It can easily work like Gerrit Code Review for team collobration in any size, which is thoroughly used by Android and the projects under Eclipse Foundation.

This best practice model consists of below guidelines and workflows,

  • The Collaborator role of AWS CodeCommit repos who only has permissions for pulling repo, pushing/merging code to specific branches(the branch name with prefix pr/, features/ and bugs/), and creating/closing/commenting pull requests.
  • The Master/Owner role of AWS CodeCommit repos who has some additional administrative privilleges of repo, such as updating repo info, approving/merging pull requests.
  • Nobody can directly push code to mainline branch including master/owner of repos.
  • Any newly created pull request and updating of source branch of pull request will trigger automatically CodeBuild to verify the pull request. The CodeBuild will update the PR build status back to pull request and vote code review apporval +1 if the build is successful.
  • The approval rule template is created and assoicated with the repo. The approval rule requires at least two +1 approvals from master/owner of repo and the automated PR build.
  • The CodePipeline is created on watching the mainline branch of repo. When new changes are merged into mainline branch, the continuous delivery pipeline will be triggered to deploy the artifacts of repo.

See entire architecture below,

The arch of AWS CodeCommit based devops model

This model also leverages the Infra as Code capability of AWS via AWS CDK/CloudFormation, hundreds or more code repositories and their collaboration workflow can be easily managed in a batch.

How to deploy demo app

Prerequisites

  • Install Node LTS(such as 12.x)
  • Install Docker
  • Configure your AWS account for awscli

Deploy it

# install dependencies of lambda functions, init cdk toolkit
npm run init

# deploy
npm run deploy

Cleanup

npm run cleanup

License

This sample code is made available under the MIT-0 license. See the LICENSE file.