使用docker-compose部署fastApi微服务

制作镜像

准备服务代码man.py

文件夹结构

python 复制代码
import os
from loguru import logger
from fastapi import FastAPI
import uvicorn

app = FastAPI()
# 定义日志输出目录
log_directory = os.getenv("LOG", "/work/logs/")
os.makedirs(log_directory, exist_ok=True)
logger.add(os.path.join(log_directory, "app_{time}.log"), rotation="100 MB", retention="10 days")

@app.get("/test")
async def read_root(msg):
    logger.info(msg)
    return {"message": "Hello, World! you input {}".format(msg)}
 
def main():
    uvicorn.run("main:app", reload=True, host="0.0.0.0", port=8080)
    
if __name__ == "__main__":
    main()

生成项目的requirements.txt

  1. 安装pipreqs模块
  2. 使用pipreqs生成项目的 requirements.txt
  3. pipreqs ./ --encoding=utf-8

编辑Dockerfile

bash 复制代码
FROM 192.168.93.20/devops/python:3.9.21-slim-bullseye
LABEL tag="app-depoly"
WORKDIR /work
ENV LOG=./logs
COPY ./service/* ./service/code
RUN pip install --upgrade pip && pip install -r ./service/code/requirements.txt
CMD python3 ./service/code/main.py

构建容器

  • 在Dockerfile目录执行下列命令
bash 复制代码
docker build -t 192.168.93.20/devops/python:deploy_app .
  • 查看构建的镜像
bash 复制代码
docker images
  • 检验镜像是否可用
bash 复制代码
docker run -itd -p 8080:8080 -v /app_logs:/work/logs --name yahoo  192.168.93.20/devops/python:deploy_app # 创建一个容器并将容器的8080端口暴露到宿主机8080端口,挂载一个宿主机共享目录/container_data到/work/service
 
docker ps -al # 查看容器
bash 复制代码
docker logs yahoo #查看服务日志,


到这里服务起来了,验证了Dockerfile的正确性!

使用docker-compose管理服务

  • 编辑docker-compose.yml
bash 复制代码
version: "3.7"
services:
  webapp:
    build:
      context: .
      dockerfile: Dockerfile
      labels:
        - "webapp"
       
    ports:
      - "8080:8080"
    
    restart: on-failure
    volumes:
      - "/app_logs:/work/logs"
  • 使用docker-compose构建镜像并启动容器服务
  • 检验容服务是否OK


这里就实现了docker-compose发布服务了!

相关推荐
web1368856587126 分钟前
使用 GZCTF 结合 GitHub 仓库搭建独立容器与动态 Flag 的 CTF 靶场+基于 Docker 的 Web 出题与部署+容器权限控制
前端·docker·github
phenomenal991 小时前
微服务-01【续】
java·微服务·架构
Don't Look Down4 小时前
docker tdengine windows快速体验
docker·容器·tdengine
运维&陈同学5 小时前
【Elasticsearch01】企业级日志分析系统ELK之Elasticsearch单机部署
大数据·linux·elk·elasticsearch·微服务·云原生·jenkins
DachuiLi7 小时前
Dual-Write Problem 双写问题(微服务)
微服务
水彩橘子7 小时前
构建centos docker基础镜像
linux·docker·centos
{⌐■_■}7 小时前
【微服务】微服务、gRPC和protobuf是什么,及其联系
运维·微服务·架构
wux_labs7 小时前
开发OPEA微服务
人工智能·微服务·云原生·架构·大模型
.生产的驴8 小时前
Docker Compose 多应用部署 一键部署
java·运维·后端·spring cloud·docker·容器·gateway