找不到参数“('',)”的“wagtailadmin_explore”的反向

问题描述 投票:0回答:2

我一直在尝试将我的 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:
python django docker wagtail
2个回答
4
投票

这可能是因为您在迁移后擦除了数据库(或其某些部分)。

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 删除所有表。


0
投票

在对 django 应用程序进行 docker 化时,我也遇到了同样的问题。由entrypoint.sh文件中的flash命令引起的问题。

python manage.py flush --no-input

只需删除此行即可修复。

© www.soinside.com 2019 - 2024. All rights reserved.