Gitlab: Python项目CI/CD实践

目录

[1. 说明](#1. 说明)

[2. 准备工作](#2. 准备工作)

[2.1 服务器](#2.1 服务器)

[2.2 开发机hosts文件](#2.2 开发机hosts文件)

[2.3 项目](#2.3 项目)

[3. 步骤过程](#3. 步骤过程)

[3.1 建仓Fastapi T1](#3.1 建仓Fastapi T1)

[3.2 开发机测试构建与推送 ​编辑](#3.2 开发机测试构建与推送 编辑)

[3.3 在工作站添加gitlab-runner](#3.3 在工作站添加gitlab-runner)

[3.4 提交代码,查看Pipelines结果](#3.4 提交代码,查看Pipelines结果)

[3.5 观察部署情况](#3.5 观察部署情况)

[4. 参考](#4. 参考)


1. 说明

  • 分别以一个fastapi应用和一个前后端分离的kinit项目为例,制定从构建,测试到最终部署(CI/CD)的实现步骤
  • 代码管理与自动化部署基于Gitlab系统,部署到装有宝塔的目标服务器以容器方式运行
  • 使用流程:
  1. 提交代码到代码仓库
  2. gitlab根据.gitlab-ci.yml脚本规则,拉起对应的gitlab-runner工作站构建, 测试, 部署
  3. 发布服务器做反向代理设置以供访问

2. 准备工作

2.1 服务器

- 为简单起见,Gitlab Runner工作站与发布服务器合在一起使用

- 关于Gitlab服务器的私有化部署,见前文《 Gitlab: 私有化部署_gitlab私有化部署-CSDN博客

2.2 开发机hosts文件
复制代码
192.168.0.130 host001.dev.ia
192.168.0.130 gitlab.dev.ia

192.168.0.131 host002.dev.ia
192.168.0.131 fastapi-t1.dev.ia
192.168.0.131 kinit-api-t1.dev.ia
192.168.0.131 kinit-admin-t1.dev.ia
2.3 项目

|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 名称 | fastapi-t1 |
| 自定义域名 | fastapi-t1.dev.ia |
| 仓库路径 | http://host001.dev.ia:18181/dev1/fastapi-t1.git |
| 镜像路径 | host001.dev.ia:5050/dev1/fastapi-t1:latest |
| 目录结构 | ./fastapi-t1/ ├── .gitlab-ci.yml ├── Dockerfile ├── README.md ├── app │ ├── init.py │ ├── main.py │ ├── static │ ├── templates │ ├── utils ├── pytest.ini ├── requirements.txt └── tests ├── init.py ├── conftest.py └── test_main.py |
| 运行命令行 | uvicorn app.main:app --reload |
| Dockerfile | 见附件 |
| .gitlab-ci.yml文件 | 见附件 |

|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 名称 | kinit 后端api应用 |
| 自定义域名 | kinit-api-t1.dev.ia |
| 仓库路径 | http://host001.dev.ia:18181/dev1/kinit-api-t1.git |
| 镜像路径 | host001.dev.ia:5050/dev1/kinit-api-t1:latest |
| 目录结构 | kinit-api ├── .gitlab-ci.yml ├── README.md ├── alembic ├── alembic.ini ├── application ├── apps ├── core ├── db ├── logs ├── main.py ├── requirements.txt ├── scripts ├── static ├── temp └── utils |
| .gitlab-ci.yml文件 | 见附件 |

|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 名称 | kinit 前端应用 |
| 自定义域名 | kinit-admin-t1.dev.ia |
| 仓库路径 | http://host001.dev.ia:18181/dev1/kinit-admin-t1.git |
| 镜像路径 | host001.dev.ia:5050/dev1/kinit-admin-t1:latest |
| 目录结构 | kinit-admin ├── .gitlab-ci.yml ├── LICENSE ├── README.md ├── index.html ├── node_modules ├── package.json ├── plop ├── plopfile.js ├── pnpm-lock.yaml ├── postcss.config.js ├── prettier.config.js ├── public ├── scripts ├── src ├── stylelint.config.js ├── tsconfig.json ├── types ├── uno.config.ts └── vite.config.ts |
| .gitlab-ci.yml文件 | 见附件 |

3. 步骤过程

3.1 建仓Fastapi T1

如图:镜像仓库ready

3.2 开发机测试构建与推送
3.3 在工作站添加gitlab-runner

说明:当代码提交后,遇到含有tag=python的.gitlab-ci.yml时调用该runner执行任务

* gitlab-runner所在的工作站需预先安装pip工具

3.4 提交代码,查看Pipelines结果

3.5 观察部署情况

设置子域名与反向代理后访问 http://fastapi-t1.dev.ia/docs

4. 参考

-Gitlab: PHP项目CI/CD实践

相关推荐
亓才孓31 分钟前
[Class类的应用]反射的理解
开发语言·python
小镇敲码人40 分钟前
深入剖析华为CANN框架下的Ops-CV仓库:从入门到实战指南
c++·python·华为·cann
摘星编程1 小时前
深入理解CANN ops-nn BatchNormalization算子:训练加速的关键技术
python
魔芋红茶1 小时前
Python 项目版本控制
开发语言·python
lili-felicity1 小时前
CANN批处理优化技巧:从动态批处理到流水线并行
人工智能·python
一个有梦有戏的人1 小时前
Python3基础:进阶基础,筑牢编程底层能力
后端·python
摘星编程1 小时前
解析CANN ops-nn中的Transpose算子:张量维度变换的高效实现
python
Liekkas Kono2 小时前
RapidOCR Python 贡献指南
开发语言·python·rapidocr
玄同7652 小时前
Python 后端三剑客:FastAPI/Flask/Django 对比与 LLM 开发选型指南
人工智能·python·机器学习·自然语言处理·django·flask·fastapi
爱吃泡芙的小白白2 小时前
环境数据多维关系探索利器:Pairs Plot 完全指南
python·信息可视化·数据分析·环境领域·pairs plot