Arbess从基础到实践(20) - 集成GitHub+SonarQube实现Java项目自动化部署

Arbess 是一款开源免费的 CI/CD 工具,支持免费私有化部署,一键安装零配置。本文将详细介绍如何使用安装配置SonarQube、Arbess系统,使用流水线拉取GitHub源码、使用SonarQube代码扫描、构建安装包并进行主机部署。

1、GitHub 配置

本章节将介绍如何创建GitHub个人访问令牌,提供给Arbess克隆源码。

1.1 配置

登录GitHub仓库,登录后点击右上角头像,选择Settings进入设置。

进入设置

进入设置后,点击Developer settings→Personal access tokens,进入个人令牌界面。点击创建令牌。

创建个人令牌

根据自身需求,输入名称、到期时间、访问仓库、权限等信息。

创建个人令牌

创建完成之后,保存创建的个人令牌,后续提供给Arbess调用使用。

2、SonarQube 安装与配置

本章节将介绍如何使用CentOS9搭建SonarQube25.1服务,在SonarQube创建项目,提供给Arbess调用。

2.1 安装

  • 安装依赖

首先需要Java17和PostgreSQL。安装PostgreSQL数据库之后,执行如下命令,创建数据库sonarqube→创建用户名密码→赋予权限。

sudo -u postgres psql

CREATE DATABASE sonarqube WITH ENCODING 'UTF8' TEMPLATE template0;

CREATE USER sonar WITH PASSWORD 'sonar';

GRANT ALL PRIVILEGES ON DATABASE sonarqube TO sonar;

创建SonarQube数据库

数据库创建完成之后,可以修改数据库认证配置,编辑/var/lib/pgsql/15/data/pg_hba.conf,在最下方添加如下内容,并重启服务。

host sonarqube sonar 127.0.0.1/32 scram-sha-256

  • 安装SonarQube

依赖安装完毕之后,安装SonarQube 25.1。

wget https://binaries.sonarsource.com/Distribution/sonarqube/sonarqube-25.1.0.77747.zip

sudo unzip sonarqube-*.zip -d /opt

sudo mv /opt/sonarqube-* /opt/sonarqube

创建专用用户。

sudo useradd -M -d /opt/sonarqube -s /bin/false sonar

sudo chown -R sonar:sonar /opt/sonarqube

修改SonarQube数据连接信息。编辑/opt/sonarqube/conf/sonar.properties

sonar.jdbc.url=jdbc:postgresql://localhost:5432/sonarqube

sonar.jdbc.username=sonar

sonar.jdbc.password=sonar

sonar.web.port=9000

修改完成后进入,启动SonarQube服务。

sudo -u sonar /opt/sonarqube/bin/linux-x86-64/sonar.sh start

启动SonarQube服务

安装成功后访问 http://127.0.0.1:9000 地址使用用户名密码:admin\admin,访问SonarQube。

2.2 配置

登录SonarQube系统后,需要创建项目,以及将代码导入项目进行分析。在SonarQube首页,点击Create Project,创建项目。输入项目名称、项目Key,点击下一步进行创建。

创建SonarQube项目

项目创建完成之后,需要生成项目Token,点击右上角头像 → My Account → Security**。**输入Token名称 → 点击 Generate , 复制生成的Token。

创建Token

创建完毕之后,需要记住token和项目名称,Arbess集成SonarQube需要用到。

3、Arbess 安装与配置

3.1 安装

本文以CentOS操作系统为例。

  • 下载,CentOS安装包下载地址:Arbess下载,点击CentOS下载,下载完成后得到类似tiklab-arbess-x.x.x.rpm的文件。
  • 安装,上传到服务器上,在文件同级目录执行命令安装。

rpm -ivh tiklab-arbess-x.x.x.rpm

  • 启动,系统默认安装路径为/opt目录,进入/opt/tiklab-arbess/bin目录下,执行./arbess start即可启动成功。

启动Arbess系统

使用 http://ip:9200 进行访问。使用初始用户名密码admin\123456登录。成功登录后展示Arbess首页。

Arbess首页

3.2 配置

Arbess流水线采用可视化设计,实现Java项目自动化部署,在流水线中可克隆GitHub仓库代码、集成SonarQube进行代码扫描。创建流水线,进入流水线设计页面进行操作。

3.2.1 配置GitHub源码

  • 配置GitHub服务集成

流水线配置GitHub源码任务之前,需要添加GitHub服务集成,在系统设置→集成与开放→服务集成页面添加相关服务。授权类型选择GitHub、填写名称、AccessTocken(个人密钥,即文章1.1部分创建的个人访问令牌)。

添加源码集成

  • 添加GitHub源码任务

服务集成添加完毕之后,进入流水线设计,点击新阶段→源码→GitHub。需要填入任务名称、Git版本、GitHub授权信息(AccessTocken)、仓库、分支等信息。

添加GitHub源码任务

|------------|------------------------------------------------------|
| 字段 | 描述 |
| 任务名称 | 任务名称清晰地标识项目或对象。 |
| Git版本 | Arbess所在服务器Git安装路径。 |
| GitHub授权信息 | 私人令牌,AccessTocken。 |
| 仓库 | 选择授权信息后点击仓库,程序会自动获取凭证权限下的仓库列表,管理者只需选择需要配置的仓库即可。 |
| 分支 | 选择代码的分支。填写需要拉取远程仓库具体的分支,不填默认为master分支,填写错误会导致任务执行失败。 |

3.2.2 配置SonarQube代码扫描

  • 配置SonarQube服务集成

在系统设置→集成与开放→服务集成页面添加相关服务。授权类型选择Sonar、填写名称、服务地址、认证类型(用户名密码、密钥)、用户名、密码。

添加SonarQube服务

新版本SonarQube只支持个人令牌的方式扫描代码,服务地址认证方式需要选择密钥,填写个人密钥。

添加SonarQube密钥

  • 添加SonarQube代码扫描任务

服务集成添加完毕之后,进入流水线设计,点击新阶段→代码扫描→SonarQube代码扫描。添加成功之后,弹出代码扫描的配置。

配置SonarQube代码扫描任务

|-------------|-----------------------------------------------|
| 字段 | 描述 |
| 任务名称 | 任务名称清晰地标识项目或对象。 |
| 扫描代码语言 | 扫描代码语言。 |
| JDK版本 | 所在服务器JDK安装路径。 |
| Maven版本 | 所在服务器Maven安装路径。 |
| 项目名称 | 扫描的项目名称,在SonarQube中创建的项目名称。 |
| 扫描代码地址 | 扫描代码存放路径,默认为${DEFAULT_CODE_ADDRESS},也可输入绝对路径。 |
| SonarQube服务 | 安装SonarQube的服务器地址、用户名、密码。 |

3.2.3 配置Maven构建任务

代码扫描添加完毕之后,添加构建安装包任务。根据代码构建方式选择Maven构建,点击新阶段→构建→Maven构建。输入构建信息,输入完成后,点击空白处进行保存。

配置Maven构建任务

|---------|-------------------------------------------|
| 字段 | 描述 |
| 任务名称 | 任务名称清晰地标识项目或对象。 |
| JDK版本 | Arbess所在服务器JDK安装路径。 |
| Maven版本 | Arbess所在服务器Maven安装路径。 |
| 模块地址 | 构建路径,默认为${DEFAULT_CODE_ADDRESS},也可输入绝对路径。 |
| 执行命令 | 执行Maven构建的命令。 |

3.2.4 配置主机部署任务

点击新阶段→部署→主机部署。输入部署信息,部署的内容可以使用变量,添加变量后使用${变量名称}进行引用,输入完成后,点击空白处进行保存。

配置主机部署任务

|----------|------------------------------------------------|
| 字段 | 描述 |
| 任务名称 | 任务名称清晰地标识项目或对象。默认主机部署。 |
| 主机地址 | 部署主机远程SSH认证凭证。 |
| 部署文件 | 需要部署的文件,可以写绝对路径,也可以写泛路径,泛路径需要配合部署文件规则来匹配到部署文件。 |
| 部署文件匹配规则 | 文件匹配规则,支持正则表达式。 |
| 部署位置 | 部署远程主机位置。 |
| 部署命令 | 文件部署命令。 |

至此流水线设计完毕,下面介绍流水线运行以及查看代码扫描报告。

4、运行流水线

  • 运行流水线

流水线设计完毕之后,Arbess支持自动触发、Webhook触发、手动触发三种运行模式。点击右上角"运行"按钮,手动触发流水线。

运行流水线

流水线运行同时,点击认为标签右下角"日志",可查看运行实时日志。

查看详细日志

  • 查看代码扫描日志

全部任务显示为√则运行成功,运行完毕之后,可以在测试报告页面查看SonarQube代码扫描报告,点击测试报告→代码扫描→SonarQube,查看SonarQube代码扫描报告。

查看SonarQube测试报告

点击SonarQube代码扫描报告名称,进入跳转到SonarQube查看详细报告。

查看SonarQube详细报告

  • 查看运行历史

可以在Arbess历史页面查看到流水线运行历史。点击运行历史序号,即可查看详细的运行日志。

运行历史

至此,使用Arbess成功搭建流水线,用来拉取GitHub源码、使用SonarQube代码扫描,构建安装包并进行主机部署。

相关推荐
极智-9968 小时前
GitHub 热榜项目 · 日榜精选(2026-01-06)
github·开源项目·技术趋势·开发者工具
李慕婉学姐8 小时前
【开题答辩过程】以《基于JAVA的校园即时配送系统的设计与实现》为例,不知道这个选题怎么做的,不知道这个选题怎么开题答辩的可以进来看看
java·开发语言·数据库
数据大魔方8 小时前
【期货量化实战】日内动量策略:顺势而为的短线交易法(Python源码)
开发语言·数据库·python·mysql·算法·github·程序员创富
奋进的芋圆9 小时前
Java 延时任务实现方案详解(适用于 Spring Boot 3)
java·spring boot·redis·rabbitmq
sxlishaobin10 小时前
设计模式之桥接模式
java·设计模式·桥接模式
model200510 小时前
alibaba linux3 系统盘网站迁移数据盘
java·服务器·前端
荒诞硬汉10 小时前
JavaBean相关补充
java·开发语言
提笔忘字的帝国10 小时前
【教程】macOS 如何完全卸载 Java 开发环境
java·开发语言·macos
2501_9418824810 小时前
从灰度发布到流量切分的互联网工程语法控制与多语言实现实践思路随笔分享
java·开发语言
小龙11 小时前
【Git 报错解决】本地分支与远程分支名称/提交历史不匹配
大数据·git·elasticsearch·github