在docker-compose首次构建上配置postgres数据库,以供“ background_tasks”使用

如何解决在docker-compose首次构建上配置postgres数据库,以供“ background_tasks”使用

我有一个很棒的Django项目。该数据库未在存储库中注册。 因此,当我从头开始进行docker-compose时,项目无法找到与“后台任务”相对应的表...

任务是在Django项目开始时立即读取的urls.py中引用的。

在不事先编辑对该表的代码调用的情况下启动项目的方式是什么?

docker-compose:

  version: '3'

  services:
    db:
      image: postgres
      environment:
        - POSTGRES_DB=postgres
        - POSTGRES_USER=postgres
        - POSTGRES_PASSWORD=postgres
        - POSTGRES_HOST_AUTH_METHOD=trust
      ports:
        - "5432:5432"
      volumes:
        - ./postgres-data:/var/lib/postgresql/data
    web:
      build: .
      command: bash -c "
        python manage.py runserver 0.0.0.0:8000
        & python manage.py migrate
        & python manage.py process_tasks"
      volumes:
        - .:/code
      ports:
        - "8000:8000"
        - "5555:5555"
      depends_on:
        - db

记录错误:

db_1   | 2020-10-16 11:48:35.090 UTC [32] ERROR:  relation "background_task" does not exist at character 24
db_1   | 2020-10-16 11:48:35.090 UTC [32] STATEMENT:  SELECT (1) AS "a" FROM "background_task" WHERE "background_task"."verbose_name" = 'zmq_puller' LIMIT 1
db_1   | 2020-10-16 11:48:35.090 UTC [33] ERROR:  relation "background_task" does not exist at character 24
db_1   | 2020-10-16 11:48:35.090 UTC [33] STATEMENT:  SELECT (1) AS "a" FROM "background_task" WHERE "background_task"."verbose_name" = 'zmq_puller' LIMIT 1
web_1  | Traceback (most recent call last):
web_1  |   File "/usr/local/lib/python3.9/site-packages/django/db/backends/utils.py",line 84,in _execute
web_1  |     return self.cursor.execute(sql,params)
web_1  | psycopg2.errors.UndefinedTable: relation "background_task" does not exist
web_1  | LINE 1: SELECT (1) AS "a" FROM "background_task" WHERE "background_t...
web_1  |                                ^
web_1  |
web_1  |
web_1  | The above exception was the direct cause of the following exception:
web_1  |
web_1  | Traceback (most recent call last):
web_1  |   File "/code/manage.py",line 22,in <module>
web_1  | Traceback (most recent call last):
web_1  |   File "/usr/local/lib/python3.9/site-packages/django/db/backends/utils.py",in <module>
web_1  |     main()
web_1  |   File "/code/manage.py",line 18,in main
web_1  |     main()
web_1  |   File "/code/manage.py",in main
web_1  |     execute_from_command_line(sys.argv)
web_1  |   File "/usr/local/lib/python3.9/site-packages/django/core/management/__init__.py",line 401,in execute_from_command_line
web_1  |     utility.execute()
web_1  |   File "/usr/local/lib/python3.9/site-packages/django/core/management/__init__.py",line 395,in execute
web_1  |     self.fetch_command(subcommand).run_from_argv(self.argv)
web_1  |   File "/usr/local/lib/python3.9/site-packages/django/core/management/base.py",line 330,in run_from_argv
web_1  |     self.execute(*args,**cmd_options)
web_1  |   File "/usr/local/lib/python3.9/site-packages/django/core/management/base.py",line 371,in execute
web_1  |     output = self.handle(*args,**options)
web_1  |   File "/usr/local/lib/python3.9/site-packages/django/core/management/base.py",line 85,in wrapped
web_1  |     res = handle_func(*args,**kwargs)
web_1  |   File "/usr/local/lib/python3.9/site-packages/django/core/management/commands/migrate.py",line 75,in handle
web_1  |     self.check(databases=[database])
web_1  |   File "/usr/local/lib/python3.9/site-packages/django/core/management/base.py",line 392,in check
web_1  |     execute_from_command_line(sys.argv)
web_1  |   File "/usr/local/lib/python3.9/site-packages/django/core/management/__init__.py",in execute_from_command_line
web_1  |     all_issues = checks.run_checks(
web_1  |   File "/usr/local/lib/python3.9/site-packages/django/core/checks/registry.py",line 70,in run_checks
web_1  |     new_errors = check(app_configs=app_configs,databases=databases)
web_1  |   File "/usr/local/lib/python3.9/site-packages/django/core/checks/urls.py",line 13,in check_url_config
web_1  |     return check_resolver(resolver)
web_1  |   File "/usr/local/lib/python3.9/site-packages/django/core/checks/urls.py",line 23,in check_resolver
web_1  |     return check_method()
web_1  |   File "/usr/local/lib/python3.9/site-packages/django/urls/resolvers.py",line 408,in check
web_1  |     utility.execute()
web_1  |   File "/usr/local/lib/python3.9/site-packages/django/core/management/__init__.py",in execute
web_1  |     for pattern in self.url_patterns:
web_1  |   File "/usr/local/lib/python3.9/site-packages/django/utils/functional.py",line 48,in __get__
web_1  |         self.fetch_command(subcommand).run_from_argv(self.argv)res = instance.__dict__[self.name] = self.func(instance)
web_1  |
web_1  |   File "/usr/local/lib/python3.9/site-packages/django/urls/resolvers.py",line 589,in url_patterns
web_1  |   File "/usr/local/lib/python3.9/site-packages/django/core/management/base.py",line 368,in execute
web_1  |     patterns = getattr(self.urlconf_module,"urlpatterns",self.urlconf_module)
web_1  |   File "/usr/local/lib/python3.9/site-packages/django/utils/functional.py",in __get__
web_1  |         res = instance.__dict__[self.name] = self.func(instance)self.check()
web_1  |
web_1  |   File "/usr/local/lib/python3.9/site-packages/django/urls/resolvers.py",line 582,in urlconf_module
web_1  |   File "/usr/local/lib/python3.9/site-packages/django/core/management/base.py",in check
web_1  |     all_issues = checks.run_checks(
web_1  |   File "/usr/local/lib/python3.9/site-packages/django/core/checks/registry.py",in run_checks
web_1  |     return import_module(self.urlconf_name)
web_1  |   File "/usr/local/lib/python3.9/importlib/__init__.py",line 127,in import_module
web_1  |     new_errors = check(app_configs=app_configs,in check_url_config
web_1  |         return check_resolver(resolver)return _bootstrap._gcd_import(name[level:],package,level)
web_1  |
web_1  |   File "/usr/local/lib/python3.9/site-packages/django/core/checks/urls.py",in check_resolver
web_1  |   File "<frozen importlib._bootstrap>",line 1030,in _gcd_import
web_1  |     return check_method()
web_1  |   File "/usr/local/lib/python3.9/site-packages/django/urls/resolvers.py",in check
web_1  |     for pattern in self.url_patterns:
web_1  |   File "/usr/local/lib/python3.9/site-packages/django/utils/functional.py",in __get__
web_1  |     res = instance.__dict__[self.name] = self.func(instance)
web_1  |   File "/usr/local/lib/python3.9/site-packages/django/urls/resolvers.py",in url_patterns
web_1  |     patterns = getattr(self.urlconf_module,in urlconf_module
web_1  |     return import_module(self.urlconf_name)
web_1  |   File "/usr/local/lib/python3.9/importlib/__init__.py",in import_module
web_1  |       File "<frozen importlib._bootstrap>",line 1007,in _find_and_load
web_1  | return _bootstrap._gcd_import(name[level:],level)
web_1  |   File "<frozen importlib._bootstrap>",in _gcd_import
web_1  |   File "<frozen importlib._bootstrap>",line 986,in _find_and_load_unlocked
web_1  |   File "<frozen importlib._bootstrap>",in _find_and_load
web_1  |   File "<frozen importlib._bootstrap>",line 680,in _load_unlocked
web_1  |   File "<frozen importlib._bootstrap_external>",line 790,in exec_module
web_1  |   File "<frozen importlib._bootstrap>",line 228,in _call_with_frames_removed
web_1  |   File "<frozen importlib._bootstrap>",in _call_with_frames_removed
web_1  |   File "/code/drf_accordion/urls.py",line 45,in <module>
web_1  |   File "/code/drf_accordion/urls.py",in <module>
web_1  |     if not Task.objects.filter(verbose_name="zmq_puller").exists():
web_1  |   File "/usr/local/lib/python3.9/site-packages/django/db/models/query.py",line 809,in exists
web_1  |     return self.query.has_results(using=self.db)
web_1  |   File "/usr/local/lib/python3.9/site-packages/django/db/models/sql/query.py",line 535,in has_results
web_1  |     return compiler.has_results()
web_1  |   File "/usr/local/lib/python3.9/site-packages/django/db/models/sql/compiler.py",line 1126,in has_results
web_1  |     return bool(self.execute_sql(SINGLE))
web_1  |   File "/usr/local/lib/python3.9/site-packages/django/db/models/sql/compiler.py",line 1156,in execute_sql
web_1  |     cursor.execute(sql,params)
web_1  |   File "/usr/local/lib/python3.9/site-packages/django/db/backends/utils.py",line 98,in execute
web_1  |     return super().execute(sql,line 66,in execute
web_1  |     return self._execute_with_wrappers(sql,params,many=False,executor=self._execute)
web_1  |   File "/usr/local/lib/python3.9/site-packages/django/db/backends/utils.py",in _execute_with_wrappers
web_1  |     return executor(sql,many,context)
web_1  |   File "/usr/local/lib/python3.9/site-packages/django/db/backends/utils.py",params)
web_1  |   File "/usr/local/lib/python3.9/site-packages/django/db/utils.py",line 90,in __exit__
web_1  |     if not Task.objects.filter(verbose_name="zmq_puller").exists():
web_1  |   File "/usr/local/lib/python3.9/site-packages/django/db/models/query.py",in exists
web_1  |         return self.query.has_results(using=self.db)
web_1  |   File "/usr/local/lib/python3.9/site-packages/django/db/models/sql/query.py",in has_results
web_1  | raise dj_exc_value.with_traceback(traceback) from exc_value    return compiler.has_results()
web_1  |   File "/usr/local/lib/python3.9/site-packages/django/db/models/sql/compiler.py",in has_results
web_1  |
web_1  |   File "/usr/local/lib/python3.9/site-packages/django/db/backends/utils.py",in _execute
web_1  |     return bool(self.execute_sql(SINGLE))
web_1  |   File "/usr/local/lib/python3.9/site-packages/django/db/models/sql/compiler.py",in execute_sql
web_1  |     return self.cursor.execute(sql,params)
web_1  | django.db.utils.ProgrammingError: relation "background_task" does not exist
web_1  | LINE 1: SELECT (1) AS "a" FROM "background_task" WHERE "background_t...
web_1  |                                ^
web_1  |
web_1  |     cursor.execute(sql,in __exit__
web_1  |     raise dj_exc_value.with_traceback(traceback) from exc_value
web_1  |   File "/usr/local/lib/python3.9/site-packages/django/db/backends/utils.py",params)
web_1  | django.db.utils.ProgrammingError: relation "background_task" does not exist
web_1  | LINE 1: SELECT (1) AS "a" FROM "background_task" WHERE "background_t...

感谢您阅读!

解决方法

确保已将background_task添加到INSTALLED_APPShttps://github.com/arteria/django-background-tasks/blob/master/docs/index.rst#installation

,

确保在应用迁移后运行服务器。
尝试更改此设置

version: '3'
    ...
    web:    
        build: .
        command: bash -c "    
        python manage.py runserver 0.0.0.0:8000
        & python manage.py migrate
        & python manage.py process_tasks"
     ...

为此

version: '3'.  
    ...
    web:    
      build: .    
      command: bash -c "
        python manage.py migrate
        & python manage.py runserver 0.0.0.0:8000
        & python manage.py process_tasks"
     ...

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


使用本地python环境可以成功执行 import pandas as pd import matplotlib.pyplot as plt # 设置字体 plt.rcParams[&#39;font.sans-serif&#39;] = [&#39;SimHei&#39;] # 能正确显示负号 p
错误1:Request method ‘DELETE‘ not supported 错误还原:controller层有一个接口,访问该接口时报错:Request method ‘DELETE‘ not supported 错误原因:没有接收到前端传入的参数,修改为如下 参考 错误2:cannot r
错误1:启动docker镜像时报错:Error response from daemon: driver failed programming external connectivity on endpoint quirky_allen 解决方法:重启docker -&gt; systemctl r
错误1:private field ‘xxx‘ is never assigned 按Altʾnter快捷键,选择第2项 参考:https://blog.csdn.net/shi_hong_fei_hei/article/details/88814070 错误2:启动时报错,不能找到主启动类 #
报错如下,通过源不能下载,最后警告pip需升级版本 Requirement already satisfied: pip in c:\users\ychen\appdata\local\programs\python\python310\lib\site-packages (22.0.4) Coll
错误1:maven打包报错 错误还原:使用maven打包项目时报错如下 [ERROR] Failed to execute goal org.apache.maven.plugins:maven-resources-plugin:3.2.0:resources (default-resources)
错误1:服务调用时报错 服务消费者模块assess通过openFeign调用服务提供者模块hires 如下为服务提供者模块hires的控制层接口 @RestController @RequestMapping(&quot;/hires&quot;) public class FeignControl
错误1:运行项目后报如下错误 解决方案 报错2:Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.8.1:compile (default-compile) on project sb 解决方案:在pom.
参考 错误原因 过滤器或拦截器在生效时,redisTemplate还没有注入 解决方案:在注入容器时就生效 @Component //项目运行时就注入Spring容器 public class RedisBean { @Resource private RedisTemplate&lt;String
使用vite构建项目报错 C:\Users\ychen\work&gt;npm init @vitejs/app @vitejs/create-app is deprecated, use npm init vite instead C:\Users\ychen\AppData\Local\npm-
参考1 参考2 解决方案 # 点击安装源 协议选择 http:// 路径填写 mirrors.aliyun.com/centos/8.3.2011/BaseOS/x86_64/os URL类型 软件库URL 其他路径 # 版本 7 mirrors.aliyun.com/centos/7/os/x86
报错1 [root@slave1 data_mocker]# kafka-console-consumer.sh --bootstrap-server slave1:9092 --topic topic_db [2023-12-19 18:31:12,770] WARN [Consumer clie
错误1 # 重写数据 hive (edu)&gt; insert overwrite table dwd_trade_cart_add_inc &gt; select data.id, &gt; data.user_id, &gt; data.course_id, &gt; date_format(
错误1 hive (edu)&gt; insert into huanhuan values(1,&#39;haoge&#39;); Query ID = root_20240110071417_fe1517ad-3607-41f4-bdcf-d00b98ac443e Total jobs = 1
报错1:执行到如下就不执行了,没有显示Successfully registered new MBean. [root@slave1 bin]# /usr/local/software/flume-1.9.0/bin/flume-ng agent -n a1 -c /usr/local/softwa
虚拟及没有启动任何服务器查看jps会显示jps,如果没有显示任何东西 [root@slave2 ~]# jps 9647 Jps 解决方案 # 进入/tmp查看 [root@slave1 dfs]# cd /tmp [root@slave1 tmp]# ll 总用量 48 drwxr-xr-x. 2
报错1 hive&gt; show databases; OK Failed with exception java.io.IOException:java.lang.RuntimeException: Error in configuring object Time taken: 0.474 se
报错1 [root@localhost ~]# vim -bash: vim: 未找到命令 安装vim yum -y install vim* # 查看是否安装成功 [root@hadoop01 hadoop]# rpm -qa |grep vim vim-X11-7.4.629-8.el7_9.x
修改hadoop配置 vi /usr/local/software/hadoop-2.9.2/etc/hadoop/yarn-site.xml # 添加如下 &lt;configuration&gt; &lt;property&gt; &lt;name&gt;yarn.nodemanager.res