aws codepipeline创建跨账户的cicd

news2025/1/11 4:17:14

参考资料

  • Building a Cross-account CI/CD Pipeline

  • Create a pipeline in CodePipeline that uses resources from another AWS account

通常来说,我们会将代码和pipeline配置不同的账户中,在codepipeline的source阶段指定为另一个账号的codecommit仓库。但codepipeline通常由三个阶段组成,本次模拟极端情况,将三个阶段分别放置在两个账号进行测试。

本次测试的逻辑图示图下

在这里插入图片描述

先决条件

a账户

  • pipeline的s3桶(授权b账号访问)

  • 用户管理kms(授权pipeline,codebuild和codedeploy)

    {
        "Sid": "Allow use of the key",
        "Effect": "Allow",
        "Principal": {
            "AWS": [
                "arn:aws-cn:iam::<account-A>:role/AWSCodePipelineServiceRole",
                "arn:aws-cn:iam::<account-B>:root"
            ]
        },
        "Action": [
            "kms:Encrypt",
            "kms:Decrypt",
            "kms:ReEncrypt*",
            "kms:GenerateDataKey*",
            "kms:DescribeKey"
        ],
        "Resource": "*"
    }
    
  • 创建管道(使用用户管理kms)

  • piprline服务角色,允许codepipeline角色的assume行为

b账号

  • 创建codecommit存储库
  • 创建codebuild项目,codepipeline会直接覆盖build的source,codebuild角色允许使用kms权限
  • 创建codedeploy应用,部署组(如ec2实例),codedeploy角色允许使用kms权限
  • 创建crossaccount角色允许a账户assume
  • 创建ec2角色允许访问a账号s3桶,获取revision

在b账号配置项目

创建codecommit仓库,这里创建一个简单的javaweb项目,包括完整buildspec.ymlappspec.yml

$ tree -L 2
├── appspec.yml
├── buildspec.yml
├── scripts
│   ├── install_dependencies.sh
│   ├── start_server.sh
│   └── stop_server.sh
├── src
│   └── main
└── pom.xml

创建codebuild项目,一直下一步即可,构建平台需要选择aws/codebuild/amazonlinux2-x86_64-standard:3.0

创建codedeploy项目,简单部署到ec2实例即可

创建cross角色,信任策略如下,允许a账号assume

{
    "Version": "2012-10-17",
    "Statement": [
        {
            "Effect": "Allow",
            "Principal": {
                "AWS": "arn:aws-cn:iam::037047667284:root"
            },
            "Action": "sts:AssumeRole",
            "Condition": {}
        }
    ]
}

在a账号创建pipeline

source,build和deploy阶段先写a账号下的

配置a账号下对应的pipeline存储桶策略

{
      "Sid": "allowputobject",
      "Effect": "Allow",
      "Principal": {
          "AWS": "arn:aws-cn:iam::442337510176:root"
      },
      "Action": [
          "s3:Get*",
          "s3:Put*"
      ],
      "Resource": "arn:aws-cn:s3:::codepipeline-cn-north-1-482183469511/*"
  },
  {
      "Sid": "allowlistbuckets",
      "Effect": "Allow",
      "Principal": {
          "AWS": "arn:aws-cn:iam::442337510176:root"
      },
      "Action": "s3:ListBucket",
      "Resource": "arn:aws-cn:s3:::codepipeline-cn-north-1-482183469511"
  }

通过awscli获取pipeline完整配置

pipeline:
  artifactStore:
    encryptionKey:
      id: arn:aws-cn:kms:cn-north-1:<account-A>:key/19841203-6504-4918-b5d8-d7ff47195135 # 指定用户管理kms
      type: KMS
    location: codepipeline-cn-north-1-xxxxxxxxx
    type: S3
  name: test-crossaccount
  roleArn: arn:aws-cn:iam::<account-A>:role/AWSCodePipelineServiceRole # pipeline角色
  stages:
  - actions:
    - actionTypeId:
        category: Source
        owner: AWS
        provider: CodeCommit
        version: '1'
      configuration:
        BranchName: master
        OutputArtifactFormat: CODE_ZIP
        PollForSourceChanges: 'false'
        RepositoryName: zhaojiew-test
      inputArtifacts: []
      name: Source
      namespace: SourceVariables
      outputArtifacts:
      - name: SourceArtifact
      region: cn-north-1
      roleArn: arn:aws-cn:iam::<account-B>:role/zhaojiew-cross #添加soruce阶段需要assume的角色
      runOrder: 1
    name: Source
  - actions:
    - actionTypeId:
        category: Build
        owner: AWS
        provider: CodeBuild
        version: '1'
      configuration:
        ProjectName: zhaojiew-test
      inputArtifacts:
      - name: SourceArtifact
      name: Build
      namespace: BuildVariables
      outputArtifacts:
      - name: BuildArtifact
      region: cn-north-1
      roleArn: arn:aws-cn:iam::<account-B>:role/zhaojiew-cross #添加build阶段需要assume的角色
      runOrder: 1
    name: Build
  - actions:
    - actionTypeId:
        category: Deploy
        owner: AWS
        provider: CodeDeploy
        version: '1'
      configuration:
        ApplicationName: zhaojiew-test
        DeploymentGroupName: ec2-instance
      inputArtifacts:
      - name: BuildArtifact
      name: Deploy
      namespace: DeployVariables
      outputArtifacts: []
      region: cn-north-1
      roleArn: arn:aws-cn:iam::<account-B>:role/zhaojiew-cross #添加deploy阶段需要assume的角色
      runOrder: 1
    name: Deploy
  version: 1

更新pipeline

aws codepipeline update-pipeline --cli-input-yaml file://pipeline.yaml

之后手动触发pipeline进行构建即可

最后总结

最终的运行逻辑仍旧是这张图的内容,跨账号的pipeline配置只需要注意几个要点即可

涉及到的关键点总结

  • codepipeline默认使用pipeline角色进行各项操作
  • 无法在控制台对codepipeline进行跨账号配置,必须要通过api调用(如awscli)对codepipeline进行配置
  • codepipeline将所有中间步骤存储到固定的s3桶中(pipeline所在的账号),强制使用默认kms加密,但是跨账号必须使用用户托管kms密钥加密解密
  • source阶段pipeline角色assume到crossrole上获取codecommit,并将artifact回写到s3桶
  • build阶段pipeline角色assume到crossrole触发build项目,build阶段由codebuild角色执行build操作,并由crossrole将build的结果回写到s3桶
  • deploy阶段pipeline角色assume到crossrole触发deploy项目,build阶段由codedeploy角色执行deploy操作
  • 3个阶段的具体项目信息无法在codepipeline中直接看到,需要登录到b账号中查看

在这里插入图片描述

本次测试的完成能够对piepleine的权限和阶段之间的关系了解更加深入

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/112855.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

将扩散模型应用到文本领域

前言 扩散模型在文生图领域可谓是大显身手&#xff0c;效果棒棒&#xff5e; 每当一个idea有效之时&#xff0c;便会有更多相关的研究跟进尝试&#xff0c;今天就给大家介绍一篇将扩散模型应用到文本生成领域的工作&#xff0c;这也是一篇比较新的paper&#xff0c;其中还用到了…

LCS+LIS最长公共上升子序列

LIS LCS AcWing 272. 最长公共上升子序列 没优化的代码 优化解释在代码注释中优化解释在代码注释中优化解释在代码注释中 #include<iostream> #include<cstring> #include<algorithm>using namespace std;const int N 3e3 10;int a[N], b[N], f[N][N];i…

开启浏览器sourcemap调试生产环境代码

开启浏览器sourcemap调试生产环境代码 Source Map介绍 在做网站性能优化的时候&#xff0c;我们经常会做js和css代码压缩。但是压缩之 后的代码在调试的时候就会异常困难。source map就是解决问题的一种解决方案 浏览器Source Map 浏览器可以设置开启或者关闭SourceMap&…

78. 子集

78. 子集 给你一个整数数组 nums &#xff0c;数组中的元素 互不相同 。返回该数组所有可能的子集&#xff08;幂集&#xff09;。 解集 不能 包含重复的子集。你可以按 任意顺序 返回解集。 示例 1&#xff1a; 输入&#xff1a;nums [1,2,3] 输出&#xff1a;[[],[1],[2]…

14【SpringMVC的拦截器】

文章目录一、拦截器1.1 拦截器与过滤器1.2 拦截器的应用1.2.1 HandlerInterceptor接口1.2.2 拦截器的拦截规则1.3 搭建工程测试拦截器1.3.1 测试SpringMVC拦截器1.3.2 SprinMVC拦截器注意事项1.4 HandlerMethod类1.5 多个拦截器的执行顺序一、拦截器 1.1 拦截器与过滤器 过滤…

第6章 el-menu刷新保持当前菜单选项与角色页面

1重构&#xff1a;src\components\AdminLayoutComponen.vue(el-menu刷新保持当前菜单选项) <template> <el-container> <!-- 侧边栏 &#xff0c;"<div class"aside">标签可被删除&#xff0c;为了下拉条控件样式保存了该标签"-->…

maven的插件(命令)install介绍

maven的插件&#xff08;命令&#xff09;install介绍背景关于构建时使用的maven命令installmaven其他插件/命令的使用背景 今天在引入SpringCloudAlibaba时&#xff0c;pom.xml中的dependency报错了 到本地仓库去验证 验证无误&#xff0c;找原因 现象&#xff1a; 在maven…

Flink-状态编程(按键分区状态、算子状态、广播状态、持久化与状态后端)

9 状态编程 9.1 概述 9.1.1 状态 所谓的状态&#xff0c;最常见的就是之前到达的数据&#xff0c;或者由之前数据计算出的某个结果 继承富函数类的函数类就可以获取运行时上下文&#xff0c;也就可以自定义状态&#xff0c;例如process中的ProcessFunction&#xff0c;CoPr…

HTML+CSS+svg绘制精美彩色闪灯圣诞树,HTML+CSS+Js实时新年时间倒数倒计时(附源代码)

HTMLCSSsvg绘制精美彩色闪灯圣诞树&#xff0c; HTMLCSSJs实时新年时间倒数倒计时(附源代码) 本篇目录 一、前言 二、主要功能 三、效果展示 四、编码实现步骤 五、资源下载 六、完整源代码&#xff0c;也可下载打包代码&#xff08;我设的是免费&#xff09; 一、前言…

【Vue】三、Vue.js的常用选项

后端程序员的vue学习之路一、选项 / 数据1、data2、computed3、 methods4、computed 与 methods的区别5、watch二、选项 / DOMeltemplate三、选项 / 生命周期钩子1、生命周期钩子有如下这些&#xff1a;2、流程图2、练习代码四、选项 / 资源1、filters2、directives3、componen…

大半夜睡不着,聊一下在小外包公司工作一年后的感想吧

我不知道当年怎么想的&#xff0c;能在一个外包公司一干就是6年&#xff0c;后来终于跳出来了&#xff0c;现在的公司虽然不是什么大厂吧&#xff0c;但至少是个正经的互联网企业&#xff0c;待遇也不错。 其实很多地方的朋友都有提到外包公司的一些弊端&#xff1a; 1.工期短…

自己动手实现一个轮播图组件

1. 轮播图原理 轮播图的原理可以总结为两点&#xff1a; 定位的运用定时器的运用 轮播图的每一张图横向依次排列。在最外层还有一个父级盒子&#xff0c;它的宽度刚好是一张图片的宽度&#xff0c;第一张图没有设置隐藏超出部分&#xff0c;第二张图隐藏了超出部分。 当我们…

河道非法采砂识别系统 yolov5

河道非法采砂识别系统通过yolov5网络架构深度学习技术对河道非法采砂行为进行实时分析检测&#xff0c;如yolov5架构模型发现现场违规采砂&#xff0c;则立即抓拍回传后台。YOLO算法- YOLO算法是一种基于回归的算法&#xff0c;它不是选择图像中有趣的部分&#xff0c;而是预测…

世界杯已开赛,哪些看球设备让你觉得身临其境?

笔者在父亲的影响下&#xff0c;从1994年美国世界杯开始接触足球&#xff0c;因为当时 CCTV5 对拥有着小世界杯之称的意甲转播&#xff0c;成为了一名意大利足球队的忠实拥趸&#xff0c;一直到现在。 四年一次的世界杯也成了我从不错过的足球盛宴。2002年日韩世界杯和2006年德…

Unity使用飞书在线表格做配置表

团队使用飞书进行项目管理&#xff0c;使用在线表格进行配置表的编写&#xff0c;而飞书也提供了在线表格操作的Api&#xff0c;这样我们可以直接在Unity中同步云端表格数据 飞书配置 首先需要进入飞书开发者后台创建应用https://open.feishu.cn/app 创建应用后记录AppId和Ap…

CAJ转pdf在线网址

知网下载论文格式为CAJ&#xff0c;不想下载它的阅读器&#xff0c;网上找了一下转pdf的网站&#xff0c;记录一下&#xff1a; 1.Caj2Pdf在线 https://caj.bookcodes.cn/ 2.speedpdf-CAJ转PDF https://speedpdf.cn/zh-cn/convert/caj-to-pdf?chbaiducp

Android---ViewPager

目录 一、ViewPager 缓存页面与预加载 缓存页面 预加载 预加载带来的问题 解决(性能优化) 二、ViewPager 懒加载机制 ViewPager源码 ViewPager 是怎么展示出来的 Populate FragmentPagerAdapter 三、ViewPager 与 ViewPager2 的差异 一、ViewPager 缓存页面与预加载 …

为什么企业要注重数据安全?六大优势分析

数据加密是将数据从可读格式转换为编码格式。两种最常见的加密方法是对称加密和非对称加密。这些名称是指是否使用相同的密钥进行加密和解密&#xff1a; ●对称加密密钥&#xff1a;这也称为私钥加密。用于编码的密钥与用于解码的密钥相同&#xff0c;使其最适合个人用户和封…

java jar 的修改

java jar 的修改目录概述需求&#xff1a;设计思路实现思路分析1.编译生成class文件2.生产src文件3.单独将对应的java 类编译成class文件4.替换原来的class文件参考资料和推荐阅读Survive by day and develop by night. talk for import biz , show your perfect code,full bus…

prettytable辅助打印表格的Python库

这个库的主要作用是&#xff1a;当我们想要结构话的打印一些表格类的数据时会让我们的视觉体验变好 一、安装 一行命令&#xff1a;python -m pip install -U prettytable 搞定 二、使用 1、添加数据 首先来看一个打印的效果 要想实现上边的效果使用下边的代码&#xff1a…