1、安装gitlab
项目部署:
- 将项目通过maven进行编译打包
- 将文件上传到指定的服务器中
- 将war包放在tomcat服务器目录中
- 通过Dockerfile将Tomcat和war包转换成一个镜像,由docker-compose去管理
CI、CD帮助我们实现持续集成,持续交付和部署。CI(continuous intergration)持续集成
持续继承:编写代码时,完成一个功能后,立即提交代码到Git仓库中,将项目重新构建测试;
- 快速发现错误
- 防止代码偏离主分支。
1、搭建gitlab服务器
- 创建一个全新的虚拟机,gitlab官方推荐4g运行内存;
- 安装Docker和Docker-compose
2、修改ssh的端口:
将ssh的默认端口22,修改为60022端口,因为gitlab要占用22端口
vi /etc/ssh/sshd_config
# 修改配置文件
PORT 22 -> 60022
# 重启sshd服务
systemctl restart sshd
编写docker-compose(版本为1.24.1)文件
version: '3.1'
services:
gitlab:
image: 'twang2218/gitlab-ce-zh:11.1.4'
container_name: "gitlab"
restart: always
privileged: true
hostname: 'gitlab'
environment:
TZ: 'Asia/Shanghai'
GITLAB_OMNIBUS_CONFIG: |
external_url 'http://192.168.9.105'
gitlab_rails['time_zone'] = 'Asia/Shanghai'
gitlab_rails['smtp_enable'] = true
gitlab_rails['gitlab_shell_ssh_port'] = 22
ports:
- '80:80'
- '443:443'
- '22:22'
volumes:
- /opt/docker_gitlab/config:/etc/gitlab
- /opt/docker_gitlab/data:/var/opt/gitlab
- /opt/docker_gitlab/logs:/var/log/gitlab
#启动
docker-compose up -d
#查看日志
docker-compose logs -f
#浏览器访问
192.168.9.105
2.安装gitlab-runner
- 创建工作目录
/opt/docker_gitlab-runner
- 准备docker-compose.yml`文件
(下载镜像 命令:docker pull gitlab/gitlab-runner)- 在宿主机启动docker程序后先执行
sudo chown root:root /var/run/docker.sock
(如果重启过 docker,重新执行)- 在
/opt/docker_gitlab-runner
目录中执行docker-compose up -d --build
启动容器- 添加容器权限,保证容器可以使用宿主机的docker
docker exec -it gitlab-runner usermod -aG root gitlab-runner
version: "3.1"
services:
gitlab-runner:
image: gitlab-runner
restart: always
container_name: gitlab-runner
privileged: true
volumes:
- ./config:/etc/gitlab-runner
- /var/run/docker.sock:/var/run/docker.sock
docker -compose up -d 执行命令
# 注册Runner信息到gitlab
docker exec -it gitlab-runner gitlab-runner register
# 输入 GitLab 地址
Please enter the gitlab-ci coordinator URL (e.g. https://gitlab.com/):
http://192.168.9.105/
# 输入 GitLab Token
Please enter the gitlab-ci token for this runner:
1Lxq_f1NRfCfeNbE5WRh
# 输入 Runner 的说明
Please enter the gitlab-ci description for this runner:
可以为空
# 设置 Tag,可以用于指定在构建规定的 tag 时触发 ci
Please enter the gitlab-ci tags for this runner (comma separated):
deploy
# 这里选择 true ,可以用于代码上传后直接执行(根据版本,也会没有次选项)
Whether to run untagged builds [true/false]:
true
# 这里选择 false,可以直接回车,默认为 false(根据版本,也会没有次选项)
Whether to lock Runner to current project [true/false]:
false
# 选择 runner 执行器,这里我们选择的是 shell
Please enter the executor: virtualbox, docker+machine, parallels, shell, ssh, docker-ssh+machine, kubernetes, docker, docker-ssh:
shell
- gitlab 地址和gitlab token 图解
- 修改runner 配置
3.部署项目测试CI
- 创建maven项目进行测试
- 编写 .gitlab-ci.yml文件
stages:
- test
test:
stage: test
script:
- echo first test ci # 输入命令
- 将maven工程推送到gitlab
- 在gitlab中查看gitlab-ci.yml中编写的内容
- Dockerfile文件和docker-compose.yml
# Dockerfile
FROM daocloud.io/library/tomcat:8.5.15-jre8
COPY testcd-1.0-SNAPSHOT.war /usr/local/tomcat/webapps
# docker-compose.yml
version: "3.1"
services:
testcd:
build: docker
container_name: testcd
restart: always
environment:
TZ: Asia/Shanghai
ports:
- 8081:8080
项目工程截图
Ci持续集成测试
# ci.yml
stages:
- test
test:
stage: test
script:
- echo woshidahaoren test ci # 输入命令
- /usr/local/apache-maven-3.6.3/bin/mvn package
- cp target/testci-1.0-SNAPSHOT.war docker/testci.war
- docker-compose down
- docker-compose up -d --build
- docker rmi $(docker images -qf dangling=true) # 删除没有名称的images```
版权声明:本文为fengtao0821原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。