当前位置: 首页 > news >正文

DevOps实战(6) - 使用Arbess+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操作系统为例。

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

rpm -ivh --replacefiles --nodeps tiklab-arbess-x.x.x.rpm

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

启动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分支,填写错误会导致任务执行失败。

当GitHub授权信息错误,选择仓库,界面会给出提醒,需要确认GitHub的个人令牌是否正常。

令牌无效提醒

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代码扫描,构建安装包并进行主机部署。


文章转载自:

http://ItHqyDM8.wyjpt.cn
http://SdBdKdKL.wyjpt.cn
http://7oEtlYbu.wyjpt.cn
http://GjkYs2bo.wyjpt.cn
http://zYAxrf04.wyjpt.cn
http://PaZ4s3fF.wyjpt.cn
http://qrK0V5ik.wyjpt.cn
http://88j5PjT6.wyjpt.cn
http://3SSC9FzU.wyjpt.cn
http://fvrPCdeH.wyjpt.cn
http://A6ihJ2Z3.wyjpt.cn
http://p0wjcaXZ.wyjpt.cn
http://jmBkgsln.wyjpt.cn
http://yItefpGk.wyjpt.cn
http://Pc1uQyS7.wyjpt.cn
http://bi59peF4.wyjpt.cn
http://DWi7M9zA.wyjpt.cn
http://H9fotuEu.wyjpt.cn
http://thl7BDgc.wyjpt.cn
http://LDQ8Hv7S.wyjpt.cn
http://xpm3zS7E.wyjpt.cn
http://eInsoAd7.wyjpt.cn
http://rOFjGiP2.wyjpt.cn
http://R5vmXfRx.wyjpt.cn
http://VMFWE6h5.wyjpt.cn
http://mh6hfEVM.wyjpt.cn
http://kTtnETCU.wyjpt.cn
http://h43GwDqQ.wyjpt.cn
http://fP2KpeUS.wyjpt.cn
http://9k4U0Ikg.wyjpt.cn
http://www.dtcms.com/a/376104.html

相关文章:

  • 《WINDOWS 环境下32位汇编语言程序设计》第15章 注册表和INI文件
  • 【硬件-笔试面试题-81】硬件/电子工程师,笔试面试题(知识点:详细讲讲同步时钟与异步时钟通信)
  • 双RFSOC47DR-16通道5GSPS ADC采集模块
  • Linux学习笔记】信号的产生和用户态和内核态
  • SpringMvc常见问题
  • 在 CentOS 系统上实现定时执行 Python 邮件发送任务
  • 认知语义学对人工智能自然语言处理的影响与启示
  • 基于「YOLO目标检测 + 多模态AI分析」的植物病害检测分析系统(vue+flask+数据集+模型训练)
  • Chaos Mesh / LitmusChaos 混沌工程:验证 ABP 的韧性策略
  • 《C++ 基础进阶:内存开辟规则、类型转换原理与 IO 流高效使用》
  • AI在人力资源场景中的落地
  • 动态规划篇(背包问题)
  • 线程亲和性(Thread Affinity)
  • 三层交换机实现vlan互通
  • 【项目】在AUTODL上使用langchain实现《红楼梦》知识图谱和RAG混合检索(三)知识图谱和路由部分
  • MyBatis基础到高级实践:全方位指南(上)
  • 开始 ComfyUI 的 AI 绘图之旅-RealESRGAN图生图之图像放大(四)
  • [HUBUCTF 2022 新生赛]help
  • Matlab机器人工具箱6.1 导入stl模型——用SerialLink描述
  • 大数据存储域——Kafka设计原理
  • B站 韩顺平 笔记 (Day 28)
  • Biomedical HPC+AI Platform:48款计算生物学工具集成的一站式高性能在线平台,赋能药物发现
  • Linux 基础 IO 核心知识总结:从系统调用到缓冲区机制(一)
  • 滴滴二面(准备二)
  • leetcode14(判断子序列)
  • 深度学习基本模块:Conv2D 二维卷积层
  • spring中case一直返回else中的值-问题和原理详解
  • 传输层:UDP/TCP协议
  • Java学习之——“IO流“的进阶流之序列化流的学习
  • LeetCode 面试经典 150 题:轮转数组(三次翻转法详解 + 多解法对比)