Windows 结合 Docker 下使用 Django+Celery+Pool

前景提要:在mac环境中能正常使用的celery及pool多进程的各项功能,但是在Windows环境下无法正常使用,wsl踩过坑无法正常使用,遂切换到 Docker 方案

1、搭建Docker环境

我安装的是Docker桌面版,具体步骤不再赘述

2、编辑 dockerfile 文件

我的 dockerfile 文件放置在项目目录下

bash 复制代码
# 使用官方 Python 镜像作为基础镜像
FROM python:3.10.14
# 设置容器内的工作目录
WORKDIR /xxx
# 将 requirements.txt 复制到容器中的工作目录
COPY requirements.txt .
# 安装 Python 依赖项
RUN pip install --no-cache-dir -r requirements.txt
# 将应用程序代码复制到容器
COPY . .
# 设置环境变量
ENV PYTHONUNBUFFERED=1
# 公开端口
EXPOSE 8000
# 进行数据库迁移
RUN python manage.py migrate
# 指定容器启动时运行的命令
#CMD ["python", "main.py"]
CMD ["/backend/docker_start.sh"] # 我使用的是 dvadmin 项目中有该文件

3、编辑 docker-compose.yml 文件

我的 docker-compose.yml 与 dockerfile 文件放置在相同目录,因为redis、db服务在Windows环境下已经运行,所以不需要Docker启动这两个服务

bash 复制代码
version: '3.8'  # 指定 Docker Compose 版本
services:
  django:  # Django 应用服务
    build:  # 指定构建上下文
      context: .  # Dockerfile 的路径,相对于此 docker-compose.yml 文件
    command: python manage.py runserver 0.0.0.0:8000  # 运行 Django 开发服务器的命令
    ports:
      - "8000:8000"  # 将主机的 8000 端口映射到容器的 8000 端口
    environment:
      - DEBUG=1  # 设置环境变量,启用调试模式
      - DB_HOST=127.0.0.1  # 数据库服务的主机名
      - DB_NAME=stock_project  # 数据库名称
      - DB_USER=root  # 数据库用户
      - DB_PASSWORD=root  # 数据库密码
  celery-beat: # celery beat
    build: .
    command: celery -A application.celery beat --loglevel=info
  celery-worker: # celery worker
    build: .
    command: celery -A application.celery worker -B --loglevel=info

4、打开终端运行项目

bash 复制代码
docker-compose up --build

8000端口能够正常访问时基本代表启动成功,此时多进程任务也能成功运行。

注意:

在 Docker 容器中,127.0.0.1 指的是容器自身,而不是宿主机。您需要使用宿主机的实际 IP 地址或使用特定的域名。对于 Docker Desktop,您可以使用 host.docker.internal 来访问宿主机。

所以在 Django 项目中我将 DATABASE_HOST、REDIS_HOST 都配置成了host.docker.internal

bash 复制代码
DATABASE_HOST = 'host.docker.internal'
REDIS_HOST = 'host.docker.internal'
相关推荐
muyun28002 小时前
Docker 下部署 Elasticsearch 8 并集成 Kibana 和 IK 分词器
elasticsearch·docker·容器
百锦再4 小时前
[特殊字符] Python在CentOS系统执行深度指南
开发语言·python·plotly·django·centos·virtualenv·pygame
路由侠内网穿透5 小时前
本地部署 GPS 跟踪系统 Traccar 并实现外部访问
运维·服务器·网络·windows·tcp/ip
傻傻虎虎7 小时前
【Docker】常用帮忙、镜像、容器、其他命令合集(2)
运维·docker·容器
研华嵌入式13 小时前
如何在高通跃龙QCS6490 Arm架构上使用Windows 11 IoT企业版?
arm开发·windows·嵌入式硬件
计算机编程小央姐14 小时前
跟上大数据时代步伐:食物营养数据可视化分析系统技术前沿解析
大数据·hadoop·信息可视化·spark·django·课程设计·食物
2401_8979300615 小时前
使用Docker轻松部署Neo4j图数据库
数据库·docker·neo4j
诗句藏于尽头15 小时前
Django模型与数据库表映射的两种方式
数据库·python·django
LeeZhao@16 小时前
【AI推理部署】Docker篇04—Docker自动构建镜像
人工智能·docker·容器
程思扬16 小时前
利用JSONCrack与cpolar提升数据可视化及跨团队协作效率
网络·人工智能·经验分享·docker·信息可视化·容器·架构