作为整个课程的一部分,今天进行gitlab与sonarqube相关集成的详解,以及利用现有机制进行项目管理的思路。配置的过程中以一个maven的案例作为介绍,实现与gitlab CI的集成。最后将权限配置进行了说明,以满足多人、多项目使用的场景。其中的配置并不是固定的,各位可以结合自己实际的情况进行修改。
sonarqube的官方文档,大家可以参考看下。
https://docs.sonarqube.org/latest/instance-administration/authentication/gitlab/
https://docs.sonarqube.org/latest/devops-platform-integration/gitlab-integration/
一、sonarqube与gitlab的认证对接配置(authentication)
首先需要前往gitlab配置一个OAuth app,管理员账号>偏好设置>应用
此处scope说明:
api: 假如需要启用group同步。
read_user :假如需要进行用户的鉴权。
data:image/s3,"s3://crabby-images/5d446/5d446193fcd31ce68a5fd942b4c335d19cd83520" alt=""
将信息进行复制,用于下边sonar的配置:
data:image/s3,"s3://crabby-images/affbf/affbfb0bf13de5f0b0a667fd03093b2a26127396" alt=""
接下去我们来到sonar端进行配置:
admin账号>Administration>Configuration>Authentication>Gitlab
data:image/s3,"s3://crabby-images/c68c6/c68c6348346f8968c284ab258bcb6907cf636f9f" alt=""
data:image/s3,"s3://crabby-images/4cc28/4cc2824dc022244cfdfec35175b4d1cab0997929" alt=""
data:image/s3,"s3://crabby-images/ac31f/ac31fd8350fa3b47588f013c92e898d1ab566c05" alt=""
关于组同步:
For each GitLab group they belong to, the user will be associated to a group with the same name (if it exists) in SonarQube. If enabled, the GitLab Oauth2 application will need to provide the api scope.
可以看到sonar的描述是只有在gitlab与sonar中存在同样的group name,才会触发用户与组直接的关联关系的同步。gitlab中的组是不会直接在sonar中自动同步并创建的。此处较坑,需要自己使用gitlab与sonar的API进行同步程序的编写,待补充。
除了上述的配置之外,最后还要在admin账号>Administration>Configuration>Gneneral处
完成Server base URL的配置:
data:image/s3,"s3://crabby-images/068ae/068aebd238b8941eb6a933f95f9f350b7fa5fe4f" alt=""
此时sonarqube就可以使用gitlab进行登录了。
data:image/s3,"s3://crabby-images/52632/526323a2aeb42093bbacadb292ea53dcf22bcae5" alt=""
二、sonarqube与gitlab的集成配置(integration)
免费版配置完成之后,能够实现sonar自动读取到相应账号账号在gitlab中的项目,将sonar的扫描嵌入至gitlab的CI。再登录至sonar查看代码质量及漏洞情况。
在merge request页面新增sonarqube的装饰,是付费版的功能。虽然用不了,但是我们在整个配置的过程中还是需要去创建对应的access token,并配置。
2.1 sonarqube建议创建一个独立的账号,具备Reporter的权限并能访问所有的项目,基于此账号创建一个具备api scope的Personal Access Token。这个token将在随后sonar的全局配置中用到:
此处创建新的sonarqube用户,
data:image/s3,"s3://crabby-images/42eef/42eefc5f78e959e644b7dab33eadd767f43937a4" alt=""
data:image/s3,"s3://crabby-images/649f9/649f9195d3809c7a92638fc343a4aef0aaaf2e17" alt=""
保留token。
在某个项目中将sonarqube用户添加为Reporter。假如上边在创建sonarqube账号时选择作为管理员账号,则默认具有所有项目的访问权限,不需要再在项目中额外进行授权,此处从安全的角度出发,单独授权。
data:image/s3,"s3://crabby-images/35607/35607ed176cca04cbbec790ddf094c31fb3098d8" alt=""
2.2 回到sonar进行配置
此处我先解释一下sonar的配置逻辑,我们首先需要使用管理员账号进行一个全局access token的配置,这个token主要的作用是将代码质量的状态推送至merge request/pull request,需要使用api scope。
其次个人用户在进行项目关联及导入的时候,需要配置个人的access token,此时需要read_api scope。配置完成之后你就可以在sonarqube中看到你权限下的项目,并进行配置,配置完成之后,merge request处也会看到相应的菜单,付费版功能。(Setting up your projects this way also sets your project settings for merge request decoration.)
因此,我建议全局配置可以将权限收的小一点,有就可以了,没必要给管理员权限。
access token信息较为敏感,建议参考sonar的文档,将加密配置起来,很简单的,此处不再赘述。https://docs.sonarqube.org/9.9/instance-administration/security/#settings-encryption
下边正式开始配置:
建议加密token,此处需要提前完成加密配置,链接就在上头。
data:image/s3,"s3://crabby-images/9b4d7/9b4d7e4ef92ffa6d9c48895fdf2c0902c3a28b6f" alt=""
在管理员账号下进行global token setting:Administration>Configuration>DevOps Platform Integrations
data:image/s3,"s3://crabby-images/22edf/22edfd40bcc991d4ae974ea8da15c9e7f6f9c18b" alt=""
data:image/s3,"s3://crabby-images/2404f/2404f1602af1d34e36265d9e8ff2d8296dfe9ce1" alt=""
接下去将gitlab及sonarqube的账号都切换至某个普通账号:
在gitlab中再次生成access token,Preferences>Access Tokens,保存token
data:image/s3,"s3://crabby-images/c6b57/c6b57a9f8757e6c3109991a86030f892554b0c5e" alt=""
单点至sonarqube,进行项目导入的配置,在首页选择From Gitlab
data:image/s3,"s3://crabby-images/87481/8748134e3a19155b66f32fa01efa74153ed34f7d" alt=""
将token粘贴之后就可以看到你账号下的全部项目。
data:image/s3,"s3://crabby-images/ac8c7/ac8c78c875829d3ed58b30f237a7be117aff3235" alt=""
点击setup即可开始配置,此处以一个maven的项目为例,使用gitlab CI进行集成:
data:image/s3,"s3://crabby-images/a213c/a213c5b7709803a14e8d5439b2d2298e09bd9f33" alt=""
在pom.xml中添加properties:
data:image/s3,"s3://crabby-images/1895a/1895a8a614a784c73c866da1d1de9d19096ce978" alt=""
在gitlab对应的项目下添加环境变量:
data:image/s3,"s3://crabby-images/c31b2/c31b26b9074962e73afcd7a2eda3b52f04b4cef3" alt=""
data:image/s3,"s3://crabby-images/29a02/29a02a6bb13b04c6aef9c48297f933b506930781" alt=""
在.gitlab-ci.yml中添加对应的stage:
data:image/s3,"s3://crabby-images/8bc5f/8bc5f764c37e4091670daac7fa58bfb8bc31f874" alt=""
data:image/s3,"s3://crabby-images/cc18c/cc18c9b33bc6a6cd83e17c78881d6c71607a8b8f" alt=""
至此,整体的配置完成。
最终的效果:
data:image/s3,"s3://crabby-images/a3333/a33336a6b9c8316413528fb5efdfd8791548e010" alt=""
最后写一下,关于sonar权限管理的问题。
sonar默认导入的项目都是public,需要重新定义成private。Administration>Projects>Default visibility of new projects
data:image/s3,"s3://crabby-images/a0749/a0749c5e8342f94fd20a91eddaa8abd9350e1bde" alt=""
sonarqube默认将所有的用户放入至sonar-users这个group,同时将权限给的很大。我们需要将sonar-users这个组的权限降至最低。同时将权限授予给Creators,最终的效果是,谁创建或导入了项目,则对于该项目拥有管理权限,可以进行对应权限的调配。
data:image/s3,"s3://crabby-images/2da61/2da61d10bcb16d108fb73cb95bf0aaf7e90cb7f8" alt=""
建议修改成:
data:image/s3,"s3://crabby-images/2be0b/2be0be6ae24ba2bf8e01c7d6c4231a2675bd340d" alt=""
权限的模板完成修改之后,不会对于现有的项目生效,需要去项目管理菜单apply一下:
data:image/s3,"s3://crabby-images/7a2ec/7a2ec6408647585b58273b4ae8d4394950675385" alt=""
本站点维护了一个每日更新的华语youtuber的排行榜,欢迎点击收藏: https://chuizi.tech/ytrank/
留言