为了演示方便,我这里创建了如下的一些任务,各个任务由包含在对应的目录中树形结构大概如下:
jenkins-authority 目录类型任务
├── dev-project-group 目录类型任务
│ ├── dev-account-service 自由风格任务
│ └── dev-message-service 自由风格任务
├── prod-project-group 目录类型任务
│ ├── prod-account-service 自由风格任务
│ └── prod-message-service 自由风格任务
└── test-project-group 目录类型任务
├── test-account-service 自由风格任务
└── test-message-service 自由风格任务
data:image/s3,"s3://crabby-images/c9523/c9523ce275255c40b8e558f5f5c52c115a383a47" alt="image.png"
最后分别用张三、李四、王五账号登录到 Jenkins 系统看看权限设置的效果。没有意外的话王五是运维人员角色可以构建和管理 dev、test 和 prod 的任务,李四只能构建和管理 test 的任务,张三只能管理和构建 dev 的任务。并且张三、李四也只能在对应的环境目录下创建新的任务,不能在其他目录创建任务。
用开发组张三账号登陆到 Jenkins ,去到 dev-project-group 目录和下面的具体某个任务下面,看到左侧的菜单栏可以进行修改编辑操作。
data:image/s3,"s3://crabby-images/ce75c/ce75cdc058516c095e24a83f258623a4a94454b8" alt="image.png"
data:image/s3,"s3://crabby-images/6dccb/6dccbf9c4ddc8e3fe7266132744e220db5f96ce6" alt="image.png"
如果张三去到测试项目组 test-project-group 和目录下的具体某个任务,可以看到左侧的菜单栏是没法进行编辑和构建操作的。
data:image/s3,"s3://crabby-images/eacdc/eacdcc66bd919c5c32731c325efc2b873b12fd15" alt="image.png"
data:image/s3,"s3://crabby-images/d2ea2/d2ea2d5aed07e0957344cb6dc5fa32a2581089a7" alt="image.png"
然后可以在用测试组账号李四登陆到 Jenkins 看看是什么样的效果:
data:image/s3,"s3://crabby-images/cff2f/cff2f43a6d801e999053a70ca3643ce930273fa0" alt="image.png"
data:image/s3,"s3://crabby-images/c1be0/c1be080e242741afba479a71751750dcbeab261e" alt="image.png"
data:image/s3,"s3://crabby-images/b0317/b0317363ff583294ff9bc2eb42870ce12f5c1fa6" alt="image.png"
data:image/s3,"s3://crabby-images/413b7/413b789024a13fc047e736a43bae61d540496735" alt="image.png"
data:image/s3,"s3://crabby-images/fffc4/fffc47ae301cfa5aaad0870904a4c1f7db87c389" alt="image.png"
王五为运维角色,可以管理 dev、test、prod 组的任务:
data:image/s3,"s3://crabby-images/d42a4/d42a4b818b1df1643133f1212c6d8f3106cf8da7" alt="image.png"
data:image/s3,"s3://crabby-images/e33b1/e33b14547cce5ef9e7e55c35bafbd2768ebf4bfb" alt="image.png"
data:image/s3,"s3://crabby-images/7e5f1/7e5f1539a6cbf0ba546dcff417f71da511b4e17f" alt="image.png"
data:image/s3,"s3://crabby-images/766a8/766a8335d2610686addaf1cdc188c3982473a08e" alt="image.png"
经过上面的配置,我们的 Jenkins 权限管控就相对精细并且也符合我们的要求和预期了。其实除了对任务进行权限控制外还可以对 Jenkins 节点进行权限控制,只是一般用不到,并且节点最好是都允许进行任务在上面进行构建执行,否则节点的压力负载分担就会出问题。
|