我一直在尝试将我的 Wagtail 网站重建为在 Fargate 上运行的 docker 容器。由于某些原因,我从头开始并重建了所有依赖项。 pip 安装完所有内容后,该网站可以在本地使用 venv 正常运行。
但是,在 Docker 容器中启动时出现奇怪的错误。谁能帮我找到解决这个问题的方法吗?
我在 /admin 收到以下错误:
Error during template rendering
In template /usr/local/lib/python3.8/site-packages/wagtail/admin/templates/wagtailadmin/home/site_summary_pages.html, error at line 4
Reverse for 'wagtailadmin_explore' with arguments '('',)' not found. 1 pattern(s) tried: ['admin/pages/(?P<parent_page_id>[0-9]+)/$']
1 {% load i18n wagtailadmin_tags %}
2
3 <li class="icon icon-doc-empty-inverse">
4 <a href="{% url 'wagtailadmin_explore' root_page.pk %}">
5 {% blocktrans count counter=total_pages with total_pages|intcomma as total %}
6 <span>{{ total }}</span> Page <span class="visuallyhidden">created in {{ site_name }}</span>
7 {% plural %}
8 <span>{{ total }}</span> Pages <span class="visuallyhidden">created in {{ site_name }}</span>
9 {% endblocktrans %}
10 </a>
11 </li>
12
我的 Docker 基础镜像是 Python 3.8 Alpine。我对本地和 Docker 的 pip freeze 进行了比较,并且软件包的版本是相同的。所有迁移都在 docker 和本地运行。
经过下面评论的讨论,问题似乎出在我的 Docker 文件上。我正在为 Wagtail 部署一个 Python 3.8 容器,为数据库部署一个 postgres 容器。当我删除然后在 postgres 容器上重新创建数据库时,错误消失了。因此,部署站点时迁移出现了问题,但我不知道可能是什么......
我的 docker 文件如下:
# pull official base image
FROM python:3.8.0-alpine
# set work directory
WORKDIR /usr/src/app
# set environment variables
ENV PYTHONDONTWRITEBYTECODE 1
ENV PYTHONUNBUFFERED 1
# install psycopg2 dependencies
RUN apk update \
&& apk add postgresql-dev gcc python3-dev \
musl-dev bash libffi-dev zlib zlib-dev make jpeg jpeg-dev
# install dependencies
RUN pip install --upgrade pip
COPY ./requirements.txt /usr/src/app/requirements.txt
RUN pip install -r requirements.txt
# copy entrypoint.sh
COPY ./entrypoint.sh /usr/src/app/entrypoint.sh
# copy project
COPY . /usr/src/app/
# run entrypoint.sh
ENTRYPOINT ["/usr/src/app/entrypoint.sh"]
和我的入口点文件:
#!/bin/sh
if [ "$DATABASE" = "postgres" ]
then
echo "Waiting for postgres..."
while ! nc -z $SQL_HOST $SQL_PORT; do
sleep 0.1
done
echo "PostgreSQL started"
fi
python manage.py flush --no-input
python manage.py migrate
python manage.py collectstatic --no-input --clear
python manage.py runserver 0.0.0.0:8000
exec "$@"
和我的 docker 撰写文件:
version: '3.7'
services:
web:
build: ./
command: python manage.py runserver 0.0.0.0:8000
volumes:
- ./:/usr/src/app/
ports:
- 8000:8000
env_file:
- ./.env.dev
db:
image: postgres:12.0-alpine
volumes:
- postgres_data:/var/lib/postgresql/data/
environment:
- POSTGRES_USER=postgres
- POSTGRES_PASSWORD=postgres
- POSTGRES_DB=blog_project
volumes:
postgres_data:
这可能是因为您在迁移后擦除了数据库(或其某些部分)。
wagtailcore_page
表可能不应该是空的。
使用 wagtail,当您运行
python manage.py migrate
时,迁移不仅会创建所需的表,还会用您构建站点结构的初始根页面填充它。当您删除此页面时,您将收到指定的错误。
{% url 'wagtailadmin_explore' root_page.pk %}
是这里的罪魁祸首。 Wagtail 尝试使用 root_page.pk 反转 wagtailadmin_explore
url,但在您的情况下 root_page
为 None。
仅仅再次运行
python manage.py migrate
是行不通的,因为 Wagtail 会假设其迁移已经运行,并且不会再次创建根页面。
要解决此问题,请完全删除数据库并运行 python manage.py migrate
,或者将正确的数据库传递到 Docker 容器中。
最好使用 wagtail 接口来删除、重组或更改页面。我过去遇到过一些问题,导致 Wagtail 安装失败。
编辑:
我认为你应该删除entrypoint.sh中的
python manage.py flush --no-input
。每次运行容器时都会执行此文件,这意味着每次调用 docker run
或 docker-compose up
时都会刷新数据库。
flush
将清除所有数据,但保留实际表格。如果您运行 migrate
,然后运行 flush
,然后再次运行 migrate
,它将发现没有要应用的迁移(因为它们已经被应用),因此创建根页面的迁移也不会运行。
我不太清楚为什么你每次都想刷新数据库,尤其是在 Docker 容器中。如果您想从一个新的数据库开始,最好将其作为一次性命令运行,并且最好通过 psql 删除所有表。
在对 django 应用程序进行 docker 化时,我也遇到了同样的问题。由entrypoint.sh文件中的flash命令引起的问题。
python manage.py flush --no-input
只需删除此行即可修复。