百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

极狐GitLab CI x Vault,做好企业密钥安全合规管理

liuian 2025-01-16 20:10 65 浏览

“千里之堤,溃于蚁穴”,密钥管理对于软件研发全生命周期来讲犹如蚁穴之于长堤,密钥泄漏已经成为导致企业被勒索攻击的重要因素。安全合规的管理密钥,除了能够有效避免企业遭受重大经济损失,还能够打造良好的企业安全文化,帮助企业在加速软件交付的同时保证安全合规。

密钥管理需要覆盖软件研发全生命周期,比如在编码阶段需要避免密钥硬编码、在构建阶段需要避免密钥被打印到构建日志中、在测试阶段需要去扫描变更代码(或历史中)是否含有密钥信息等。

极狐GitLab 本身具备成熟的密钥管理功能,比如在 CI/CD Pipeline 阶段,可以用 CI 环境变量来存储密钥,还可以将密钥检测的安全扫描手段嵌入到 CI/CD Pipeline 中,及时发现变更代码中的密钥信息,避免外泄。

关于极狐GitLab CI 对于密钥的管理可以查看文章极狐GitLab CI/CD SSHKEY Mask 的几种方式;关于极狐GitLab 密钥安全扫描的文章可以查看1 行代码开启「密钥检测」,给敏感数据加上防护锁。

本文将演示极狐GitLab CI 与 Vault 集成来进行密钥的安全合规管理。

关于 Vault

Vault 是 HashiCorp 公司推出的一款开源的、基于身份识别的密钥和加密管理系统。以 Default deny all 的原则来管理诸如 API key、用户名密码(password)、访问令牌(token)及证书(certificates)等密钥。更多关于 Vault 的内容可以查看 Vault 官网。

参考文档:Vault 官网

https://developer.hashicorp.com/vault

极狐GitLab CI 与 Vault 的集成原理



  1. 在 vault 上配置密钥(UI、CLI、API 均可);
  2. 生成 JWT 以供 CI Job 用;
  3. Runner 和 HashiCorp 连接并用 JWT 做认证;
  4. Vault 对 JWT 进行验证;
  5. Vault 对于 bound claim 和 对应的 Vault policy 进行检查;
  6. Vault 返回访问令牌;
  7. Runner 从 Vault 读取密钥信息进行使用。

极狐GitLab CI 与 Vault 集成的两种方式

可以使用 secrets 关键字或 CLI 的方式来在极狐GitLab CI 中使用 Vault。

secrets:vault 关键字的使用

secrets 是极狐GitLab CI 中用来从外部密钥管理工具读取密钥的关键字。可以使用 secrets:vault 从 vault 服务器读取存储在里面的密钥信息。

比如在 Vault 中使用 kv engine (v2)来存储容器镜像仓库的用户名和密码:


# 写入用户名和密码
$ vault kv put jh/docker-registry/credentials username=jh-gitlab password=passw0rd

# 读取用户名和密码
vault read -format=json jh/data/docker-registry/credentials | jq -r '.data.data'
{
"password": "passw0rd",
"username": "jh-gitlab"
}


将 Vault 相关的环境变量存储在极狐GitLab CI 变量中:



  • VAULT_SERVER_URL:Vault 服务器地址;
  • VAULT_AUTH_ROLE:Vault 上创建的 role,用来和对应的 policy 进行绑定,实现存储密钥的精细化管控;
  • VAULT_AUTH_PATH:认证方法在 Vault auth 中的挂载路径,默认为 jwt


.gitlab-ci.yml 文件内容如下:


stages:
- vault

get_credentials:
stage: vault
tags:
- vault
image:
name: vault:1.13.3
secrets:
DATABASE_PASSWORD:
vault: docker-registry/credentials/password@jh
script:
-
echo $DATABASE_PASSWORD


查看 CI/CD Pipeline 构建结果:



可以看到极狐GitLab CI 读取 Vault 信息成功,并且将其保存到名为 DATABASE_PASSWORD 的文件里面,路径如红色方框截图所示。


CLI 方式

通过 CLI 的方式就像本地访问 Vault 一样,用 Vault 的各种命令即可实现对密钥的增删改查等操作。依旧以前面写入的密钥信息为例来演示 CLI 在极狐GitLab CI 中的使用。


.gitlab-ci.yml 文件内容如下:

get_credentials:
stage: vault
tags:
- vault
image: vault:1.13.3
script:
# vault 服务器的地址
- export VAULT_ADDR=http://163.228.231.126:8200
# vault 认证授权所用的 token
- export VAULT_TOKEN="$(vault write -field=token auth/jwt/login role=jh jwt=$CI_JOB_JWT)"
# 从 vault 读取密钥信息
- export PASSWORD="$(vault kv get -field=password jh/docker-registry/credentials)"
# 打印密钥信息
- echo $PASSWORD


查看 CI/CD Pipeline 构建结果:


可以看到极狐GitLab CI 读取 Vault 信息成功。

注意,直接使用 CLI 方式读取的密钥信息,可以使用 echo 命令打印出来,需要避免在 CI/CD Pipeline 构建中打印密钥信息或者采取第一种方式来避免造成密钥信息在 CI/CD Pipeline 构建过程中的泄漏。


参考

Reference

1. 极狐GitLab vault 官网文档:

https://docs.gitlab.cn/ee/ci/secrets/

2. 极狐GitLab 售前解决方案架构师尹学峰编写的极狐GitLab 与 vault 的详细配置文档:

https://note.youdao.com/ynoteshare/index.html?id=b0b8120e07a7e85a077077da05a8d7cd&type=note&_time=1693468609345

相关推荐

win7专业版一键还原(win7一键还原工具)
  • win7专业版一键还原(win7一键还原工具)
  • win7专业版一键还原(win7一键还原工具)
  • win7专业版一键还原(win7一键还原工具)
  • win7专业版一键还原(win7一键还原工具)
繁体字转换器app(繁体字转换器软件下载)

简体繁体转换工具是一款可以自由转换简体字和繁体字的工具软件。简体繁体转换工具支持中文简体、繁体互相转换,还可以简体和BIG5之间的相互转换,只需要在软件中输入需要转换的简体文字,然后点击一下就可以转换...

用户账户控制怎么打开(用户账户控制在哪里设置)
用户账户控制怎么打开(用户账户控制在哪里设置)

1、按开始(或者按“Win键”),选择“控制面板”;  2、在“控制面板”界面中,选择“用户账户和家庭安全”;  3、在“用户账户和家庭安全”界面中,选择“用户账户”;  4、在“用户账户”界面中,选择“更改用户账户控制设置”;  5、这样...

2025-12-19 00:05 liuian

日语输入法下载安装 app(日语输入法下载安装讯飞)

搜狗输入法可以把中文翻译成日语。1、首先打开短信的文字输入框,输入需要翻译的中文,找到右上方的搜索图标。2、接着在弹出的功能栏中选择左下方的翻译功能,这时就能看到翻译出的多国语言。3、最后选择日文后方...

win10系统补丁怎么安装(win10系统补丁怎么安装不了)

任何系统装补丁都是一样的。下载好补丁的NPK文件,然后放在DNF安装文件夹下面的imagepacks2里面就好。首先,强烈不建议用管家类的软件批量打补丁,非常容易出问题!如果你的电脑是用的正版系统,...

windows10电脑怎么格式化d盘

格式化D盘的步骤如下:首先备份重要的数据,因为格式化会清空盘中的所有数据。打开“我的电脑”,找到需要格式化的D盘。右键点击D盘,选择“格式化”。在弹出的窗口中选择“文件系统”,一般选择NTFS文件系统...

xpu盘启动盘制作工具(xp系统启动盘制作)

XP系统设置U盘启动方法:1、将启动U盘插入电脑USB口,在开机时候按着“F2”(具体按键跟根据个人电脑而已,开机时有提示)键,进入BIOS界面,选择并进入“BOOT(启动)”设置项。2、在启动界面中...

tplink路由器初始账号密码(tp-link路由器默认账号密码)

初始密码:admin,可以在路由器底部标贴中查看到;  2、新版本的TP-Link路由器,没有默认登录密码了;新版的TP-link需要打开tplogin.cn作为管理页面登陆,默认是没有管理员密码的,...

win7纯净版系统之家官网下载

纯净版win7官网站好。win7纯净版就是在原版系统基础上纯净2.win7纯净版就是在原版系统基础上纯净化后的版本,它去除了所有第三方软件和捆绑软件,而且纯净版系统一定是后续封装的系统,非原版系统...

苹果自带的手机管家(苹果自带的手机管家能两个手机吗)

苹果手机没有自带的手机管家的,因为苹果手机并没有必要有管家。因为苹果首先是一个封闭的系统,它是AppStore的里面才能下载软件,软件都是经过安全扫描,不会有太多风险的。的内存管理本身就十分优秀,后台...

水星路由器管理员初始密码(水星路由器管理员密码一般是啥)

水星路由器初始管理员密码旧版默认密码是:admin水星路由器目前有新、旧2个版本,而旧版本的水星路由器,默认密码是:admin注意问题:一台路由器,如果有默认密码。2.新版没有默认密码前面...

华硕笔记本官网序列号查询(华硕官方序列号查询)

1.不提供完整序列号。2.因为华硕官网为了保护用户的隐私和安全,不会公开提供完整的序列号。3.如果您需要查询或注册产品,可以在产品包装盒上或产品本身上找到部分序列号,并在华硕官网上进行相应的操作...

正版win10哪里下载(正版win10在哪下载)
  • 正版win10哪里下载(正版win10在哪下载)
  • 正版win10哪里下载(正版win10在哪下载)
  • 正版win10哪里下载(正版win10在哪下载)
  • 正版win10哪里下载(正版win10在哪下载)
中国三星电子官网(三星电子 中国)

您可以按照以下步骤进行:1.打开浏览器应用程序,在地址栏中输入“www.samsung.com”或者“www.samsung.cn”。2.回车进入网站首页,然后在网站顶部的导航菜单中找到“手机与...

苹果ipad怎么分屏(苹果13怎么分屏)
  • 苹果ipad怎么分屏(苹果13怎么分屏)
  • 苹果ipad怎么分屏(苹果13怎么分屏)
  • 苹果ipad怎么分屏(苹果13怎么分屏)
  • 苹果ipad怎么分屏(苹果13怎么分屏)