type
status
date
slug
summary
tags
category
icon
password
Property
Mar 4, 2024 12:01 PM
目的
Jenkins + Gitlab 实现前端构建
正式开始
Jenkins 安装 NodeJS
因为在 Jenkins 构建的时候我们需要去执行一些 shell,需要用到 NodeJS,因此我们先安装 NodeJS。
在这里我们采用插件方式安装。
在 Jenkins 插件管理中心搜索 NodeJS
data:image/s3,"s3://crabby-images/396be/396bef025e23194bf6721588845a1e942603f09a" alt="notion image"
image
我这里已经安装了
data:image/s3,"s3://crabby-images/82b88/82b88c3b05479c090ae00319456beaa34f95ef76" alt="notion image"
image
没有安装的话应给在可选插件的 Tab,勾选之后选择直接安装即可。
data:image/s3,"s3://crabby-images/af8b1/af8b161f307e8b6ccde3fd739c0cf04700395000" alt="notion image"
image
data:image/s3,"s3://crabby-images/94e00/94e00cb1acbff418c5be5f5f8d3202cc1bffd601" alt="notion image"
image
全局配置
在系统设置–系统工具设置可以为全局配置 NodeJS。
data:image/s3,"s3://crabby-images/3782e/3782e323bbab4280b4ac2eb48a4e27843335a860" alt="notion image"
image
选择好对应的版本之后保存即可。
data:image/s3,"s3://crabby-images/3454d/3454dd8a0e08f9e12a37cb2766bee04b476d7824" alt="notion image"
image
使用
我们只需要在任务的“配置”中,找到“构建环境”,选中 “Provide Node & npm bin/ folder to PATH” ,选择刚才配置好的 NodeJS 即可。
data:image/s3,"s3://crabby-images/18b6b/18b6be310b5eaad8d772885a5251900ffaf82f19" alt="notion image"
image
第一次执行会下载对应的 Node 版本,后续不会下载。
开始集成
因为集成构建的时候我们需要 Jenkins 去 Gitlab 拉去代码,因此我们需要用 ssh 的方式去鉴权。
生成公钥私钥
Jenkins 拉取,因此要在 Jenkins 上生成,并且将公钥传输到 Gitlab,这样就可以实现鉴权的作用。
data:image/s3,"s3://crabby-images/a2606/a2606bdbd19e5110799921f1f82294f0ee0fb6f1" alt="notion image"
image
data:image/s3,"s3://crabby-images/e9298/e9298cb92b09745762804a50bde434db7bee4b6a" alt="notion image"
image
Gitlab 配公钥
将公钥存入即可
data:image/s3,"s3://crabby-images/1eb70/1eb703bff2f1f71b58a76a01e7f4fd4422e81762" alt="notion image"
image
Jenkins 配私钥
在系统管理,管理凭证。
data:image/s3,"s3://crabby-images/e1bbc/e1bbc9de67386e2efe89f97229f9a3551795d4b4" alt="notion image"
image
在全局添加凭证
data:image/s3,"s3://crabby-images/1318d/1318d444d25509ab91ec3317977fd4f891d25142" alt="notion image"
image
类型为 “SSH Username with private key.”,ID 为此凭据在 Jenkins 的标识符,UserName 为你的 Gitlab 用户名,PrivateKey 为你的服务器私钥。
data:image/s3,"s3://crabby-images/31897/31897469f92e526842d36a56c45973cbd655b5c2" alt="notion image"
image
配置完之后最好还是重启一下 jenkins 和 gitlab
至此,Jenkins 配置完毕。
小试牛刀,构建一下
新建任务
选择:构建一个自由风格的软件项目,我这里用的 ssh-way
data:image/s3,"s3://crabby-images/0dc5d/0dc5d3f01ead4576b3072f31608153f3514be2d8" alt="notion image"
image
配置任务
我这里是临时用的一个 Vue-Cli 搭建的项目演示。
进入任务配置,在任源码管理这里选择 Git
data:image/s3,"s3://crabby-images/e29ac/e29ac2edd897c3615db8e325c10aac06e361d6c1" alt="notion image"
image
注意
仓库地址为 gitlat 的 ssh 方式
直接复制的地址有两个端口号,要改为 ssh 的 333 端口。端口为 333 是在之前配置的这个端口号。
image
选择对应的 NodeJS 版本
data:image/s3,"s3://crabby-images/b65a7/b65a70f39608180ed62ab13b452dcb6dc57009e6" alt="notion image"
image
构建选择–执行 Shell
data:image/s3,"s3://crabby-images/5a672/5a672b712120dd3eb889e4aaeedc5082d9b089bc" alt="notion image"
image
填写基本的 shell
保存再立即构建一波。
data:image/s3,"s3://crabby-images/d8686/d8686ff67a14e476394aaab35b7eb073a4b3f72c" alt="notion image"
image
看到
Finished: SUCCESS
,完美。同步到 Nginx 环境
当我们构建成功之后,我们只需要把 Jenkins 的 dist 目录下面的资源全部拷贝到服务器 Nginx 上面就可以实现更新了。而且没有不会变更配置文件,也不用重启 Nginx。
创建文件夹
为了避免我们后续找不到文件夹,我们就先创建秘钥顺便创建文件夹。
配置鉴权文件
因为我们已经在 Jenkins 生成过私钥公钥了,我们只需要将这边的文件复制到 Nginx 的
/root/.ssh/authorized_keys
就好了。第一次需要输入密码,后续都不需要了。
data:image/s3,"s3://crabby-images/6e3aa/6e3aa57f1dc351694d065e23492d0f4d9fe87ba0" alt="notion image"
image
发布到 Nginx
原理很简单,将 build 生成的 dist 的全部文件全部都拷贝到 nginx 的 html 的目录下。(Nginx 资源路径具体要看配置)
在之前的 shell 命令中加入以下命令。
data:image/s3,"s3://crabby-images/a8eb3/a8eb34fffc830ae9fe36271f7d034f283e744955" alt="notion image"
image
修改测试
修改了,提交了,我们构建一下。
data:image/s3,"s3://crabby-images/1366b/1366b5dac261d0f8e86ac4a9aabf9fd318f11816" alt="notion image"
image
构建成功
data:image/s3,"s3://crabby-images/2eac2/2eac2599b3b3fd4b8a3c056880e6c0d439d7b046" alt="notion image"
image
完美
data:image/s3,"s3://crabby-images/63937/639374b8db129a0c37e0d60604de8f08840a96ab" alt="notion image"
image
结语
至此,我们已经完整搭建了 Jenkins + Gitlab 实现前端构建,搭了这么久的环境终于开始实战了。撒花!
- 作者:Kitety
- 链接:https://www.kitety.com/article/cicd-actual-combat-jenkins-gitlab-to-achieve-frontend-construction
- 声明:本文采用 CC BY-NC-SA 4.0 许可协议,转载请注明出处。
相关文章