DevOps实战(7) - 使用Arbess+GitPuk+sourcefare实现Node.js项目自动化部署

Arbess 是一款国产开源免费的 CI/CD 工具,工具支持一键部署,页面简洁易用。本文将详细介绍如何安装配置使用GitPuk、sourcefare、Arbess系统,使用流水线拉取GitPuk源码、使用sourcefare代码扫描、构建安装包并进行主机部署。

1、GitPuk 安装与配置

GitPuk是TikLab DevOps下一款开源免费代码管理工具,本章节将介绍如何使用CentOS搭建GitPuk服务器,并将代码存放在GitPuk服务器,提供给Arbess克隆。

1.1 安装

本文以CentOS操作系统为例。

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

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

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

启动GitPuk系统

使用 http://ip:9800 进行访问。使用初始用户名密码admin\123456登录,首次登录需要修改管理员密码。成功登录后展示GitPuk首页。

GitPuk首页

1.2 配置

GitPuk登录成功,需要添加代码仓库,GitPuk支持新建仓库上传代码和从其他软件导入仓库两种方式。

  • 新建仓库

在仓库页面点击右上角“新建仓库”。

创建仓库

新建的仓库可通过HTTP和SSH方式按步骤上传代码。

上传代码

  • 导入仓库

GitPuk也支持从外部仓库导入。

导入仓库

以私有Gitlab为例,导入需要提供私有Gitlab地址,以及访问密钥。添加外部仓库信息完成后,选择Gitlab的仓库,进行导入。

导入仓库

2、sourcefare 安装与配置

sourefare是TikLab DevOps下一款开源免费代码扫描工具,本章节将介绍如何使用CentOS搭建sourcefare服务,提供给Arbess调用进行代码扫描。

2.1 安装

本文以CentOS操作系统为例。

  • 下载,服务端安装包含Agent安装,CentOS安装包下载地址:Sourcefare下载,点击CentOS下载,下载安装包如tiklab-sourcefare-x.x.x.rpm。
  • 安装,上传到服务器上,在文件同级目录执行npm命令安装。

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

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

启动SourceFare系统

使用 http://ip:9900 进行访问。使用初始用户名密码admin\123456登录,首次登录需要修改管理员密码。成功登录后展示sourcefare首页。

sourcefare首页

2.2 配置

SourceFare登录成功,需要添加项目,以及代码扫描计划,Arbess运行代码扫描需要代码扫描计划ID,代码扫描报告会归类到相应代码扫描计划。

在项目页面点击新建项目按钮进行新建。输入项目名称以及项目访问信息(公开、私密)进行创建。

新建项目

成功创建扫描计划后,在扫描计划页面,需要记住ProjectKey,后期Arbess集成SourceFare需要用到,也可查看Arbess调用的历史扫描计划报告。

创建扫描计划

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项目自动化部署,在流水线中可克隆GitPuk仓库代码、集成SourceFare进行代码扫描。创建流水线,进入流水线设计页面进行操作。

3.2.1 配置GitPuk源码

  • 配置GitPuk服务集成

流水线配置GitPuk源码任务之前,需要添加GitPuk服务集成,在在系统设置→集成与开放→服务集成页面添加相关服务。授权类型选择GitPuk、填写名称、服务地址(即文章1部分安装的GitPuk地址)、用户名、密码。

添加源码集成

  • 添加GitPuk源码任务

服务集成添加完毕之后,进入流水线设计,点击新阶段→源码→自建GitPuk。

添加GitPuk源码任务

字段

描述

任务名称

任务名称清晰地标识项目或对象。

Git版本

Arbess所在服务器Git安装路径。

自建GitPuk服务

自建GitPuk服务地址。

仓库

选择授权信息后点击仓库,程序会自动获取凭证权限下的仓库列表,管理者只需选择需要配置的仓库即可。

分支

选择代码的分支。填写需要拉取远程仓库具体的分支,不填默认为master分支,填写错误会导致任务执行失败。

3.2.2 配置sourcefare代码扫描

  • 配置sourcefare服务集成

流水线配置sourcefare任务之前,需要添加sourcefare服务集成,系统设置→集成与开放→服务集成页面添加相关服务。授权类型选择sourcefare、填写名称、服务地址、认证类型(用户名密码、密钥)、用户名、密码。

添加sourcefare服务

  • 配置sourcefare Scanner工具集成

还需要配置sourcefare Scanner工具,进入下载地址:SourceFareAgent下载。下载对应系统文件。在系统设置→集成与开放→工具集成页面添加相关服务。授权类型选择Sonar Scanner、填写名称、安装方式选择安装包,上传sourcefare Scanner工具安装包。

添加sourcefare Scanner工具

上传sourcefare Scanner工具安装包,系统会自动解析运行文件地址。

添加sourcefare Scanner工具

  • 添加sourcefare代码扫描任务

工具集成完毕之后,点击新阶段→代码扫描→sourcefare代码扫描。添加成功之后,弹出代码扫描的配置。

配置sourcefare代码扫描任务

字段

描述

任务名称

任务名称清晰地标识项目或对象。

扫描代码语言

扫描代码语言。

JDK版本

所在服务器JDK安装路径。

Maven版本

所在服务器Maven安装路径。

sourcefare服务

安装sourcefare的服务器地址、用户名、密码。

sourcefare Scanner版本

安装sourcefare Scanner的安装路径。

项目ID

扫描的项目ID,在sourcefare中创建的项目ID。

扫描代码地址

扫描代码存放路径,默认为${DEFAULT_CODE_ADDRESS},也可输入绝对路径。

3.2.3 配置Node.js构建任务

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

配置Node.js构建任务

字段

描述

任务名称

任务名称清晰地标识项目或对象。

Node版本

Arbess所在服务器Node安装路径。

模块地址

构建路径,默认为${DEFAULT_CODE_ADDRESS},也可输入绝对路径。

执行命令

执行Node构建的命令。

3.2.4 配置主机部署任务

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

配置主机部署任务

字段

描述

任务名称

任务名称清晰地标识项目或对象。默认主机部署。

主机地址

部署主机远程SSH认证凭证。

部署文件

需要部署的文件,可以写绝对路径,也可以写泛路径,泛路径需要配合部署文件规则来匹配到部署文件。
部署文件匹配规则文件匹配规则,支持正则表达式。

部署位置

部署远程主机位置。

部署命令

文件部署命令。

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

4、运行流水线

  • 运行流水线

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

运行流水线

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

查看日志

  • 查看代码扫描报告

点击测试报告→代码扫描→sourcefare,查看sourcefare代码扫描报告。

查看sourcefare测试报告

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

查看sourcefare详细报告

问题TAB显示详细问题列表,点击问题列表的问题名称,还可以查看代码详细问题。

查看sourcefare详细问题

sourcefare还可以查看代码重复率、复杂度、覆盖率等信息。

查看sourcefare代码重复率

  • 查看运行历史

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

运行历史

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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/news/922454.shtml
繁体地址,请注明出处:http://hk.pswp.cn/news/922454.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

算法,蒜鸟蒜鸟-P1-理解“双指针”

欢迎来到啾啾的博客🐱。 记录学习点滴。分享工作思考和实用技巧,偶尔也分享一些杂谈💬。 有很多很多不足的地方,欢迎评论交流,感谢您的阅读和评论😄。 目录引言1 双指针:Two Pointers1.1 左右指…

使用cookiecutter创建python项目

一、关于Python项目结构Python 项目并没有完全统一的 “固定结构”,但行业内有一些广泛遵循的约定俗成的目录结构(尤其针对可分发的包或大型项目)。同时,确实有工具可以快速生成这些标准化结构,提高开发效率&#xff0…

台积电生态工程深度解析:从晶圆厂到蜂巢的系统架构迁移

当半导体巨头将工厂视为生态系统,用工程思维解决环境问题概述:生态系统的工程化再造台积电近日开展的"积蜜"项目绝非简单的企业CSR行为,而是一场将生态系统视为复杂系统进行工程化改造的技术实践。本文将从系统架构、数据监控、循环…

从零实现一个简易计算器

最近在刷算法题时,遇到了实现计算器的问题。一开始觉得很简单,但真正动手实现时才发现其中有很多细节需要考虑。今天就来分享一下我的实现思路和学到的经验。问题分析我们需要实现一个能够处理加减乘除四则运算的计算器,要正确处理运算符的优…

Actix-webRust Web框架入门教程

文章目录引言Actix-web是什么?准备工作你的第一个Actix-web应用理解代码结构处理请求和响应接收请求数据返回响应中间件 - 增强你的应用状态管理和依赖注入实用示例:构建RESTful API测试你的Actix-web应用部署Actix-web应用结语额外资源引言 嘿&#xf…

若依框架前端通过 nginx docker 镜像本地运行

1. 前言 项目运行过程图:对于前端项目通过命令 npm run build 打包后,无法直接运行。存在如下错误:可以通过配置 nginx 服务器运行前端项目解决如上问题。 2. Nginx 运行 采用 docker 镜像的方式运行,docker-compose.yml 文件内容…

浅聊一下HTTP协议

在日常上网浏览网页、刷视频时,背后都离不开 HTTP 协议的支持。作为 Web 世界的 “交通规则”,它负责服务器和客户端浏览器之间的数据传输。这篇文章就带大家全面了解 HTTP 协议,从基本概念到通信细节,再到安全相关的 HTTPS&#…

机器人控制器开发(定位——cartographer ros2 使用2)

文章总览 1 纯定位模式 当完成建图后,会生成pbstream格式的地图文件 配置纯定位模式的lua脚本 backpack_2d_localization.lua include "backpack_2d.lua"TRAJECTORY_BUILDER.pure_localization_trimmer {max_submaps_to_keep 3, } POSE_GRAPH.optimi…

《大数据之路1》笔记3:数据管理

一 元数据 1.1 元数据概述 定义: 元数据是关于数据的数据,元数据打通了源数据、数据仓库、数据应用,记录了数据从生产到消费的全部过程。元数据主要记录数据仓库中模型的定义、各层级间的映射关系、监控数据仓库的数据状态和ETL的任务运行状态…

排序实现java

排序算法概述Java中实现排序可以通过多种方式,包括内置方法、自定义算法或使用第三方库。常见的排序算法有冒泡排序、选择排序、插入排序、快速排序、归并排序等。使用Arrays.sort()方法对于数组排序,Java提供了Arrays.sort()方法,支持对基本…

51c大模型~合集182

我自己的原文哦~ https://blog.51cto.com/whaosoft/14174587 #LaV-CoT 超越GPT-4o,蚂蚁集团与南洋理工大学提出:首个语言感知的视觉思维链 随着大型视觉语言模型(VLM)的飞速发展,它们在处理复杂的视…

C++ STL之deque的使用和模拟实现

目录 deque 核心本质与定位 与stack和queue的关系: deque的使用 deque的底层实现 deque的原理介绍 deque的缺陷 总结: deque deque文档 : deque 翻译: 双端队列 deque(通常发音类似“deck”)是“double-ended queue”(双端队列&…

布草洗涤厂设备租赁押金原路退回系统—东方仙盟

设备租赁状态设备管理添加设备设备收押金设备退押金在布草洗涤行业的运营版图中,设备租赁是连接厂商与客户的重要纽带,而押金的收取与退还则是这一环节中关乎信任与效率的关键节点。未来之窗布草洗涤厂深谙此道,专为设备租赁业务打造的 “押金…

换源rocklinux和centos

一、Rockylinux换源,国外的源换成国内的源#nmcli connection modify ens33 ipv4.addresses 192.168.121.11 ipv4.gateway 192.168.121.2 ipv4.method manual ipv4.dns 114.114.114.114 connection.autoconnect yes修改地址#systemctl stop firewalld#systemctl diab…

第一部分:服务器硬件配置

目录1.1 服务器上架与连线1.2 启用CPU虚拟化功能(BIOS设置)1.3 配置RAID存储步骤1:进入RAID配置界面步骤2:确认RAID控制器信息步骤3:创建系统RAID(用于安装ESXi)步骤4:创建数据RAID&…

手搓一个 DELL EMC Unity存储系统健康检查清单

写在前面对于DELL EMC存储系统Unity的一些深度的健康检查通过Web的Unisphere图形化界面是做不到的,图形化界面只能看到是否有告警,物理的东西是否有问题的,逻辑的Pool和LUN等是否ready,再深入的潜在的问题是查不到的。另外&#x…

【数据结构】二叉树的概念

01 概念定义:二叉树既然叫二叉树,顾名思义即度最大为2的树称为二叉树。 它的度可以为 1 也可以为 0,但是度最大为 2 。 一颗二叉树是节点的一个有限集合,该集合:① 由一个根节点加上两棵被称为左子树和右子树的二叉树组…

【RK3576】【Android14】如何在Android14下单独编译kernel-6.1?

单独编译kernel依赖如下几个源码:【交叉编译工具链】prebuilts/clang/host/linux-x86/clang-r487747c【内核源码】kernel-6.1为什么Android下编译内核使用clang作为交叉编译工具链而不是GCC?Android 14 选择使用预置的 Clang 工具链(如 clang…

什么是Redis的Pipeline

介绍Redis的Pipeline是一种网络优化技术,在没有Pipeline的时候,客户端往redis发送请求,客户端需要等到redis响应之后才能发送下一个请求。而Pipeline,使redis可以一次性接收多个请求。减少了通信次数,显著的提高了性能…

【ElementUI el-table跨页勾选】

一、el-table需加上refs和 row-key属性 二、type"selection"勾选框 需加上 reserve-selection储备选择属性 三、在分页请求数据时&#xff0c;触发 setSelected()方法 四、在 selection-change变化时保存 selectedRows <el-table ref"tables" :data&quo…