基于阿里云系列平台的python微服务设计与DevOps实践

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档

文章目录

  • 前言
  • [1. 项目构建](#1. 项目构建)
  • [2. 新建代码仓库](#2. 新建代码仓库)
  • [3. 建立流水线](#3. 建立流水线)
    • [3.1 流水线源](#3.1 流水线源)
    • [3.2 镜像构建](#3.2 镜像构建)
    • [3.3 服务部署](#3.3 服务部署)
  • 总结

前言

1. 项目构建

java 复制代码
#基于Python最新基础镜像
FROM crpi-ru2a6rcf4x9ry77a.cn-hangzhou.personal.cr.aliyuncs.com/ck_acr_test/ck_acr_test_images_house:my_python_-slim-bookworm
LABEL maintainer="<ck@uestc.edu.cn>"
# 工作目录
WORKDIR /app
# 安装Python库
COPY requirements.txt requirements.txt
RUN  pip3 install -r requirements.txt -i https://mirrors.aliyun.com/pypi/simple/

#复制当前文件夹中全部文件到镜像中
COPY  .  .

#容器启动时执行命令
CMD ["python3","server.py"]
java 复制代码
sanic
requests
java 复制代码
#引入Sanic库中必要的子模块
from sanic import Sanic,response
#创建Sanic应用
app = Sanic("Sample_HTTP_Api")
#将异常反馈以JSON的形式输出
app.config.FALLBACK_ERROR_FORMAT="json"
#默认情况下,Sanic会忽略GET请求的消息体,将ignore_body参数设置为False可以让Sanic接收Get请求的消息体
@app.get("/v1/devices",ignore_body=False)
async def get_devices(request):
#request参数包含路由到该处理函数的请求的所有信息,包括uRL、header、body
#Sanic提供了多种便捷的HTTP响应的封装格式,这里使用JSON作为响应
    return response.json(
        {
            "status":0,
            "message":"get_devices接口尚未完成"
        }
    )
#定义添加设备的接口
@app.post("/v1/devices")
async def add_devices(request):
    return response.json(
        {
            "status":0,
            "message":"add_devices接口尚未完成"
        }
    )

#定义添加修改的接口
@app.put("/v1/devices")
async def update_devices(request):
    return response.json(
        {
            "status":0,
            "message":"update_devices接口尚未完成"
        }
    )

#定义删除设备的接口
@app.delete("/v1/devices")
async def delete_devices(request):
    return response.json(
        {
        "status":0,
        "message":"delete_devices接口尚未完成"
        }
    )

if __name__ == "__main__":
    #启动Sanic应用,为了避免多进程的额外问题,这里使用单进程模式
    app.run(host="0.0.0.0",port=8000,single_process=True)
java 复制代码
curl 127.0.0.1:8000/v1/device

2. 新建代码仓库

在ECS上

java 复制代码
git clone git@codeup.aliyun.com:6835bbe8c3d70bfc7878f751/exp_pyms_basic.git

然后把代码文件传到上面去

3. 建立流水线

我们复制以前的流水线 2025-09-21_docker_2,然后进行修改

3.1 流水线源

只需要更改代码仓库就可以了

3.2 镜像构建

不用修改

3.3 服务部署

只需要更改部署脚本

java 复制代码
docker login --username=xxxxx xxxxx.com -pxxxxx
docker rm -f exp_pyms_basic
#确保历史容器实例
docker pull ${CONTAINER_TAG}
docker run -d --restart=always --name exp_pyms_basic -p 8000:8000 ${CONTAINER_TAG}

然后就可以运行了

然后开始运行流水线


总结

相关推荐
jerryinwuhan1 分钟前
python数据挖掘基础
python·数据挖掘·numpy
echome8885 分钟前
Python 异步编程实战:asyncio 核心概念与最佳实践
开发语言·网络·python
yunyun321239 分钟前
自动化与脚本
jvm·数据库·python
暮冬-  Gentle°10 分钟前
使用PyTorch构建你的第一个神经网络
jvm·数据库·python
setmoon21411 分钟前
构建一个基于命令行的待办事项应用
jvm·数据库·python
研究点啥好呢20 分钟前
3月22日GitHub热门项目推荐|网页浏览,何须手动
人工智能·python·开源·github
三块可乐两块冰24 分钟前
【机器学习笔记三十二】机器学习三十二
python
love530love33 分钟前
ComfyUI-3D-Pack:Windows 下手动编译 mesh_inpaint_processor C++ 加速模块
c++·人工智能·windows·python·3d·hunyuan3d·comfyui-3d-pack
掘根37 分钟前
【微服务即时通讯】用户管理子服务1
微服务·云原生·架构
vx_biyesheji000143 分钟前
计算机毕业设计:Python多源新闻数据智能舆情挖掘平台 Flask框架 爬虫 SnowNLP ARIMA 可视化 数据分析 大数据(建议收藏)✅
爬虫·python·机器学习·数据分析·django·flask·课程设计