Jenkins & Gitee 实现持续集成CI/CD工具【免费、推荐】
文章目录1. Jenkins安装Gitee插件2. 插件配置3. 新建构建任务4. Vue项目构建脚本1. Jenkins安装Gitee插件Jenkins安装Gitee插件:安装完记得重启Jenkins。2. 插件配置前往 Jenkins -> 系统管理 -> 系统配置 -> Gitee配置 -> Gitee 链接在 链接名 中输入 Gitee 或者你想要的名字Gitee
文章目录
前面介绍了一些CI/CD 持续集成的工具,如circle ci、travis ci、gitee go等,详情可以看下系列文章:传送门。
但是上面一些工具有的是只支持Github,有的需要收费,有的免费的只支持公开项目不支持私有项目,而且Github在国内访问又比较慢,所以这次介绍下Gitee + Jenkins来实现可私有化且免费的持续集成方案。
1. Jenkins & Gitee持续集成流程

- 在本地编辑器编辑代码,提交到
gitee push操作触发jenkins自动部署(jenkins安装在docker中)jenkins开始构建、打包、最后部署到云服务器
2. Jenkins安装Gitee插件
Jenkins安装Gitee插件:
安装完记得重启Jenkins。
3. 插件配置
-
前往 Jenkins -> 系统管理 -> 系统配置 -> Gitee配置 -> Gitee 链接

-
在
链接名中输入Gitee或者你想要的名字 -
Gitee 域名 URL中输入Gitee完整 URL地址:https://gitee.com(Gitee私有化客户输入部署的域名) -
证书令牌中如还未配置Gitee APIV5私人令牌,点击添加 -> JenkinsDomain选择全局凭据;类型选择Gitee API 令牌;范围选择你需要的范围;Gitee APIV5 私人令牌输入你的Gitee私人令牌,点击获取ID,描述中输入你想要的 ID 和描述即可。

添加完成后,选择这个证书令牌:
点击【测试连接】,若出现成功不报错则表示配置成功。
4. 安装NodeJS
因为Vue项目是基于node 来打包构建的,所以要先安装nodejs插件:
在系统管理 > 系统配置 > 全局工具配置 NodeJS安装:
建议Node版本不要太高,选择LTS 最新的版本即可。
5. 新建构建任务
前往 Jenkins -> 新建任务 , 输入任务名称 Gitee Test,选择构建一个自由风格的软件项目保存即可创建构建项目。
5.1 General
任务全局配置中需要选择前一步中的Gitee链接。前往某个任务(如’Gitee Test’)的 Configure -> General,Gitee 链接 中选择前面所配置的Gitee链接,如图:
5.2 源码管理
- 选择
Git选项,输入你的仓库地址 - 凭据
Credentials中请输入 git 仓库https地址对应的用户名密码凭据,或者ssh对应的ssh key凭据,注意Gitee API Token凭据不可用于源码管理的凭据,只用于gitee插件的 API 调用凭据(这里再添加一个用户名密码的凭据就行啦)。 - 点击【高级】 Advanced 按钮,
Name字段中输入origin,Refspec字段输入+refs/heads/*:refs/remotes/origin/* +refs/pull/*/MERGE:refs/pull/*/MERGE
,注意新版jenkins不再接受多条同时包含*通配符的refs描述,如只对push触发可写前半部分,如只对PR触发可只写后半段。(这里我就先写前半部分) - 指定分支:master

5.3 触发器配置
这里我是配置push代码立即触发构建任务:

- 勾选
Gitee webhook 触发构建,后面有个地址这个后面需要配置到Gitee,Gitee触发构建策略勾选推送代码,其他先默认就行,后面有个Gitee WebHook密码栏位需要配置到Gitee,点击生成就会生成一个密码; - 打开Gitee这个项目的管理,左侧有个
WebHooks,点击【添加webHook】:
将上一步Jenkins生成的URL和密码填进去,点击【添加】:
5.4 构建环境
修改构建任务的构建环境,勾选Provide Node & npm bin/ folder to PATH,默认会选择刚才选择的nodeJS:
5.5 构建脚本
选择【执行shell】:
先随便写一个shell脚本试试水吧:
保存后,我们提交一次看看,很快就构建成功了:
6. Vue项目部署
vue项目通过node 构建后,需要将构建后的dist文件夹的内容部署到云服务器,因为jenkins是docker容器创建的,容器内部不能直接移动文件,因为没有挂载,所以这里可以使用SSH登录的方式登录到远程主机再来使用docker命令来移动容器的文件到宿主机的nginx服务器。先来安装下Publish over SSH,进入插件管理:
安装完成后,在系统管理->系统配置 会多出一个Publish over SSH。
先在宿主机生成SSH key(若已经有了SSH Key可以直接使用):
ssh-keygen -t rsa -C "xxxx@qq.com"

# 将公钥放到authorized_keys,否则SSH Server配置会不成功
cat id_rsa.pub >> authorized_keys
在系统管理 > 系统配置 中配置 Publish over SSH , 配置Jenkins SSH Key:
点击 Test Configuration按钮,左侧显示 Success 即表示SSH可以连接成功:
Jenkins 会通过 Git 下载项目,会下载到/var/jenkins_home/workspace/目录,Jenkins 镜像通过 ssh 登陆到宿主机时,可以直接访问到镜像中的该目录,所以能在宿主机执行该命令。
其他步骤同上,构建步骤修改脚本:
先添加一个Transfer Set 删除部署目录的文件:
再加一个 Transfer Set 传送文件到部署目录:
部署效果:
注意点:
1.若
jenkins不是用docker容器安装的,可以直接用cp命令复制将jenkins打包的文件复制到nginx对应的目录,不用SSH 来传输文件。
2.node版本记得改成和本地相同的,曾经在安装vue-element-admin时遇到install失败的问题就是node版本太高了。
3.vue-element-admin我去除了tui-editor,因为从git下载总是报错(可以通过加hosts来解决)

更多推荐



所有评论(0)