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

相关推荐
陈苏同学14 分钟前
4. 将pycharm本地项目同步到(Linux)服务器上——深度学习·科研实践·从0到1
linux·服务器·ide·人工智能·python·深度学习·pycharm
唐家小妹18 分钟前
介绍一款开源的 Modern GUI PySide6 / PyQt6的使用
python·pyqt
羊小猪~~1 小时前
深度学习项目----用LSTM模型预测股价(包含LSTM网络简介,代码数据均可下载)
pytorch·python·rnn·深度学习·机器学习·数据分析·lstm
Marst Code1 小时前
(Django)初步使用
后端·python·django
985小水博一枚呀1 小时前
【对于Python爬虫的理解】数据挖掘、信息聚合、价格监控、新闻爬取等,附代码。
爬虫·python·深度学习·数据挖掘
立秋67892 小时前
Python的defaultdict详解
服务器·windows·python
萧鼎2 小时前
Python第三方库选择与使用陷阱避免
开发语言·python
白拾2 小时前
使用Conda管理python环境的指南
开发语言·python·conda
是刃小木啦~3 小时前
三维模型点云化工具V1.0使用介绍:将三维模型进行点云化生成
python·软件工程·pyqt·工业软件
总裁余(余登武)3 小时前
算法竞赛(Python)-万变中的不变“随机算法”
开发语言·python·算法