- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个带有 FileField 的模型。我的应用程序在使用 dockerfile 创建的 docker 容器中运行。当我保存文件时,它保存在我的本地路径而不是容器根目录中。但是当我尝试检索文件并将其作为电子邮件附件发送时,我收到一个文件未找到错误。媒体根目录基于 Dockerfile 的基本根目录。电子邮件作为异步任务构建并在另一个容器中发送。Dockerfile 如下所示:
# pull official base image
FROM python:3.9.1-alpine
# set work directory
#ENV APP_HOME=/code
#RUN mkdir $APP_HOME
#RUN mkdir $APP_HOME/static
#RUN mkdir $APP_HOME/media
#WORKDIR $APP_HOME
WORKDIR /code
# set environment variables
ENV PYTHONDONTWRITEBYTECODE 1
ENV PYTHONUNBUFFERED 1
COPY requirements.txt /code/
RUN apk --update --upgrade --no-cache add \
postgresql-libs make gdal-dev geos-dev g++ python3-dev cairo-dev pango-dev gdk-pixbuf-dev ttf-ubuntu-font-family
RUN \
apk add --virtual .build-deps gcc musl-dev postgresql-dev jpeg-dev zlib-dev libffi-dev && \
pip3 install --no-cache-dir -r /code/requirements.txt && \
apk --purge del .build-deps
COPY entrypoint.sh /entrypoint.sh
RUN chmod +x /entrypoint.sh
# copy project
COPY . /code/
我有一个 docker-compose 文件来构建镜像并运行容器。看起来像这样:
version: "3.9"
services:
db:
image: postgis/postgis:13-3.0-alpine
volumes:
- postgres_data:/var/lib/postgresql/data/
# TODO remove ports for production
ports:
- "5432:5432"
environment:
- POSTGRES_DB=DB
- POSTGRES_USER=USER
- POSTGRES_PASSWORD=PW
api:
build: .
image: app/api
command: python manage.py runserver 0.0.0.0:8000 --settings=api.settings.production
volumes:
- .:/code
- static:/code/static
- media:/code/media
ports:
- "8000:8000"
env_file:
- ./.env.dev
depends_on:
- db
entrypoint: /entrypoint.sh
mail:
image: app/api
command: python manage.py qcluster --settings=api.settings.production
depends_on:
- api
volumes:
postgres_data:
static:
media:
示例模型如下所示:
def order_nested_item_directory_path(instance, filename):
# file will be uploaded to MEDIA_ROOT/orders/user_<id>/<filename>
user_id = instance.order.user.id if instance.order.user else 'anonymous'
return f'orders/user_{user_id}/order_{instance.order.id}/{filename}'
class Invoice(TimeStampedModel):
order = models.ForeignKey(Order, related_name='invoices', on_delete=models.CASCADE)
number = models.CharField(max_length=100)
pdf = models.FileField(upload_to=order_nested_item_directory_path)
使用媒体根设置:
BASE_DIR = Path(__file__).resolve().parent.parent.parent
MEDIA_URL = '/media/'
MEDIA_ROOT = os.path.join(BASE_DIR, 'media')
任何人都可以帮助如何将文件保存在 Dockerfile 的根目录中?
最佳答案
我不确定它会解决您的问题,但如果您想使用 docker-compose 在容器之间共享命名卷中的数据,您需要将这些卷添加到所有这些容器或使用扩展字段。
因为第一件事更容易,所以只需添加
volumes:
- media:/code/media
到您的mail
docker-compose 中的服务。
之后重建你的容器。
然后,当它运行时,运行 docker exec -it <image id> sh
并检查是否/code/media
在那里。
关于Django 将 FileField 中的文件保存在 docker 容器中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/65818682/
我对 Python-Django 和 web 开发还很陌生,我被困在这个使用 POST 创建新资源的特殊问题上。 我正在为 REST API 使用 Django REST 框架,我正在尝试创建一个新资
我已经使用 Django-storages 成功地将 Word 文档存储到 S3。 class Document(TitleSlugDescriptionModel, TimeStampedModel
我有 2 个关于模型代理的问题, 如何从模型对象创建代理对象? 如何从模型查询集创建代理查询集? 例如,假设我们定义了: from django.contrib.auth.models import
我想编写一个直接执行 HTTP 请求的单元测试(而不是使用 django.test.client.Client)。 如果您好奇为什么 - 那是因为我想测试我从 Django 应用程序公开的 Thrif
我为我的个人网站启动了一个 django 项目来学习 django。到目前为止,我已经将我的开发环境设置为我需要的一切,并遵循 this很棒的教程来创建一些基本的数据结构和模板。现在我想开始使用我之前
我已经阅读了很多关于如何在使用 Django 注册时添加额外字段的信息,例如 here 、 here 和 here 。代码片段是: forms.py(来自注册应用程序) class Registrat
我正在编写小型社交应用程序。功能之一是在网站标题中写入用户名。因此,例如,如果我登录并且我的名字是Oleg(用户名),那么我应该看到: Hello, Oleg | Click to edit prof
我有一个使用 Django 和 Django Rest 框架开发的应用程序。我想将 django-reversion 功能添加到我的应用程序中。 我已经尝试过http://django-reversi
我有一个简单的 HTML 表单,我没有使用 Django 表单,但现在我想添加一个选择。 选择最容易创建为 Django ChoiceField (与通过循环等手动创建选择相反),但是,如果没有在 D
我不明白为什么人们以两种方式编写外键,这样做的目的是什么?它们是相同还是不同? 我注意到有些人这样写: author = models.ForeignKey(Author, on_delete=mod
我想在我的 Django 应用程序中获取评论最多的十个帖子,但我做不到,因为我想不出合适的方法。 我目前正在使用 django 评论框架,并且我已经看到使用 aggregate or annotate
这对于 Django 1.2 仍然有效吗? Custom Filter in Django Admin on Django 1.3 or below 我已经尝试过,但管理类中的 list_filter
问题在于,当 django-compressor 编译为 .js 文件的 CoffeeScript 文件中引用 {{ STATIC_URL }} 时,它无法正确加载。 在我的 django 模板中,我
我正在尝试将一些字段从一个 django 模型移动到一个新模型。假设我有一个书籍模型: class Book(models.Model): title = models.CharField(max
我想在我的 Django 应用程序中获取评论最多的十个帖子,但我做不到,因为我想不出合适的方法。 我目前正在使用 django 评论框架,并且我已经看到使用 aggregate or annotate
目前我正在寻找在 Django 中实现访问控制。我已经阅读了有关内置权限的内容,但它并不关心每个对象的基础。例如,我想要“只有创建者可以删除自己的项目”之类的权限。所以我读到了 django-guar
嗨,我正在将我的 Django 模型的一个字段的值设置为其他模型的另一个字段的值。这个值应该是动态变化的。 这是我的第一个模型 class MainModel(AbstractBaseUser, Pe
我正在尝试为我的模型创建一个编辑表单。我没有使用模型表单,因为根据模型类型,用户可以使用不同的表单。 (例如,其中一个表单有 Tinymce 小部件,而另一个没有。) 有没有什么方法可以使用模型设置表
Django 模板中的搜索字段 如何在类似于此图像的 Django 模板中创建搜索字段 http://asciicasts.com/system/photos/1204/original/E354I0
根据 Django documentation ,如果 Django 安装激活了 AuthenticationMiddleware,HttpRequest 对象有一个“user”属性代表当前登录的用户
我是一名优秀的程序员,十分优秀!