写给初用Nestj做项目的你(第二篇: 配置gitlab-runner&操作gitlab)
如果不想自己搭建gitlab
, 请直接跳到第6条。
一. CI/CD
我们平时会使用一些CI/CD
持续集成, 比如上传到gitlab
上的dev
分支代码每次更新, 但这些功能可不是CI
来做的, 我们都会直接进行打包并发布到测试环境, 那么接下来我们就来配置这个功能模块。
二. gitlab-runner
执行构建任务是很消耗性能的, 所以gitlab
单独使用gitlab-runner
这种形式来独立的构建项目, 所以其实gitlab
提供了一个接口, 可以对应多个runner
, 不同的项目可以用不同的runner
构建。
第一步: 拉取
docker pull gitlab/gitlab-runner
第二步: 运行
docker run -d --name gitlab-runner --restart always \
-v ~/gitlab-runner/config:/etc/gitlab-runner \
-v /var/run/docker.sock:/var/run/docker.sock \
gitlab/gitlab-runner
上面是对docker
容器里面的配置做一个映射。
第三步: 注册
docker exec -it 容器id gitlab-runner register
意思就是我要去某个镜像内部执行gitlab-runner register
上面的容器id用下面的命令查看
docker container ps -a
注册填写信息
注册命令执行的时候会让我们填写Url
与Token
,这个参数在图里找:
或者打开一个项目:
- 设置标签
你可以理解成是设置一个别名, 方便我们之后管理与调用这个runner
。 - 设置环境
这里就不配置了node
之类的了, 不用shell
, 直接选用docker
。 - 设置默认镜像
三. 配置runner
我们先来查看一下被激活的runner
。
这里的tag就是刚才初始化时候设置的。
设置其为默认runner
四. 拉取项目的地址进行校正(配置gitlab)
进入我们的容器内
docker exec -it gitlab_lulu bash
vim /opt/gitlab/embedded/service/gitlab-rails/config/gitlab.yml
现在可以正确访问到了:
五. 上传一个yml
文件试一下
随便建一个vue
工程
image: node
cache:
paths:
- node_modules/
install:
tags:
- tag1
script:
- echo 1111
六. 初始一个gitlab
模块
这个库挺少用的, 文档也都是英文的, 一会会讲如何学习它。
安装
yarn add @gitbeaker/node
生成gitlab
模块
nest g controller modules/gitlab
nest g service modules/gitlab
简单配置一下
/share/src/modules/gitlab/gitlab.controller.ts
import { Controller, Get } from '@nestjs/common';
import { GitlabService } from './gitlab.service';
@Controller('gitlab')
export class GitlabController {
constructor(
private readonly gitlabService: GitlabService
) { }
@Get()
getTags() {
return this.gitlabService.getTags();
}
}
/share/src/modules/gitlab/gitlab.service.ts
import { Injectable } from '@nestjs/common';
@Injectable()
export class GitlabService {
getTags() {
return 'tags列表'
}
}
效果如下:
七. 使用@gitbeaker/node
操作gitlab
: 获取所有的tag
/share/src/modules/gitlab/gitlab.service.ts
第一步 获取token
有了token
才能有权利访问一些项目, 把权限都开启, 并且设置失效时间。
复制你的令牌放到项目中。
第二步 new
一个api实例
第三步 打上标签试一下
八. 如何学习使用@gitbeaker/node
第一步: 查询想要的api
在这里搜索你想要的关键词, api文档
第二步: 点进去找你想要的操作
比如这个新建标签
第三步: 一般这个操作名就是方法名
查看他的参数设置, options
里面一般就是要传递的参数。
第四步: 调用方法
这个ref可以理解为唯一标签, 所以它可以是commitID
:
第五步: 查看结果
end.
接下来我们要进行数据库的相关操作了, 如果你没做过后端相关项目可要仔细看了, 里面涉及到typeorm如何处理多对多与多对一等关系, 我会把我遇到的坑与心得体会全部展示给你, 希望和你一起进步。
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。