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实践

相关推荐
IVEN_17 小时前
只会Python皮毛?深入理解这几点,轻松进阶全栈开发
python·全栈
Ray Liang18 小时前
用六边形架构与整洁架构对比是伪命题?
java·python·c#·架构设计
AI攻城狮19 小时前
如何给 AI Agent 做"断舍离":OpenClaw Session 自动清理实践
python
千寻girling19 小时前
一份不可多得的 《 Python 》语言教程
人工智能·后端·python
AI攻城狮1 天前
用 Playwright 实现博客一键发布到稀土掘金
python·自动化运维
曲幽1 天前
FastAPI分布式系统实战:拆解分布式系统中常见问题及解决方案
redis·python·fastapi·web·httpx·lock·asyncio
孟健2 天前
Karpathy 用 200 行纯 Python 从零实现 GPT:代码逐行解析
python
码路飞2 天前
写了个 AI 聊天页面,被 5 种流式格式折腾了一整天 😭
javascript·python
曲幽2 天前
FastAPI压力测试实战:Locust模拟真实用户并发及优化建议
python·fastapi·web·locust·asyncio·test·uvicorn·workers