我是新手,使用Redistogo:
我已经100%使用Heroku构建了我的项目。
我想在用户输入之后对Django模型(数据库事务)运行几个操作。
执行这些操作需要一些时间,因此我决定通过消息代理、消息队列来运行它。
我的第一个偏好是使用芹菜,但我无法在Heroku上按照要求安装芹菜。它没有将"Celery-server“标识为我的需求之一,推送失败。
因此,作为替代,我开始使用RedisToGo,它可以作为Heroku的一个附加组件。
我能够启动worker,甚至连消息都被排到了Redistogo队列中,但作业被移到了失败队列中。请在下面找到跟踪日志。
2018-02-12T06:02:19.675113+00:00 app[worker.1]: Traceback (most recent call last):
2018-02-12T06:02:19.675115+00:00 app[worker.1]: File "/app/.heroku/python/lib/python3.6/site-packages/rq/worker.py", line 789, in perform_job
2018-02-12T06:02:19.675116+00:00 app[worker.1]: rv = job.perform()
2018-02-12T06:02:19.675118+00:00 app[worker.1]: File "/app/.heroku/python/lib/python3.6/site-packages/rq/job.py", line 573, in perform
2018-02-12T06:02:19.675119+00:00 app[worker.1]: self._result = self._execute()
2018-02-12T06:02:19.675121+00:00 app[worker.1]: File "/app/.heroku/python/lib/python3.6/site-packages/rq/job.py", line 579, in _execute
2018-02-12T06:02:19.675123+00:00 app[worker.1]: return self.func(*self.args, **self.kwargs)
2018-02-12T06:02:19.675124+00:00 app[worker.1]: File "/app/.heroku/python/lib/python3.6/site-packages/rq/job.py", line 206, in func
2018-02-12T06:02:19.675126+00:00 app[worker.1]: return import_attribute(self.func_name)
2018-02-12T06:02:19.675128+00:00 app[worker.1]: File "/app/.heroku/python/lib/python3.6/site-packages/rq/utils.py", line 152, in import_attribute
2018-02-12T06:02:19.675130+00:00 app[worker.1]: module = importlib.import_module(module_name)
2018-02-12T06:02:19.675131+00:00 app[worker.1]: File "/app/.heroku/python/lib/python3.6/importlib/__init__.py", line 126, in import_module
2018-02-12T06:02:19.675133+00:00 app[worker.1]: return _bootstrap._gcd_import(name[level:], package, level)
2018-02-12T06:02:19.675144+00:00 app[worker.1]: File "<frozen importlib._bootstrap>", line 994, in _gcd_import
2018-02-12T06:02:19.675146+00:00 app[worker.1]: File "<frozen importlib._bootstrap>", line 971, in _find_and_load
2018-02-12T06:02:19.675147+00:00 app[worker.1]: File "<frozen importlib._bootstrap>", line 955, in _find_and_load_unlocked
2018-02-12T06:02:19.675149+00:00 app[worker.1]: File "<frozen importlib._bootstrap>", line 665, in _load_unlocked
2018-02-12T06:02:19.675150+00:00 app[worker.1]: File "<frozen importlib._bootstrap_external>", line 678, in exec_module
2018-02-12T06:02:19.675152+00:00 app[worker.1]: File "<frozen importlib._bootstrap>", line 219, in _call_with_frames_removed
2018-02-12T06:02:19.675154+00:00 app[worker.1]: File "/app/loginapp/views.py", line 4, in <module>
2018-02-12T06:02:19.675155+00:00 app[worker.1]: from loginapp.forms import studentmaster, UserForm,studmstform,markattdform,User,firstlastpunch,batchmstform
2018-02-12T06:02:19.675157+00:00 app[worker.1]: File "/app/loginapp/forms.py", line 2, in <module>
2018-02-12T06:02:19.675164+00:00 app[worker.1]: from django.contrib.auth.models import User
2018-02-12T06:02:19.675166+00:00 app[worker.1]: File "/app/.heroku/python/lib/python3.6/site-packages/django/contrib/auth/models.py", line 4, in <module>
2018-02-12T06:02:19.675167+00:00 app[worker.1]: from django.contrib.auth.base_user import AbstractBaseUser, BaseUserManager
2018-02-12T06:02:19.675169+00:00 app[worker.1]: File "/app/.heroku/python/lib/python3.6/site-packages/django/contrib/auth/base_user.py", line 52, in <module>
2018-02-12T06:02:19.675170+00:00 app[worker.1]: class AbstractBaseUser(models.Model):
2018-02-12T06:02:19.675172+00:00 app[worker.1]: File "/app/.heroku/python/lib/python3.6/site-packages/django/contrib/auth/base_user.py", line 53, in AbstractBaseUser
2018-02-12T06:02:19.675174+00:00 app[worker.1]: password = models.CharField(_('password'), max_length=128)
2018-02-12T06:02:19.675175+00:00 app[worker.1]: File "/app/.heroku/python/lib/python3.6/site-packages/django/db/models/fields/__init__.py", line 1061, in __init__
2018-02-12T06:02:19.675177+00:00 app[worker.1]: super(CharField, self).__init__(*args, **kwargs)
2018-02-12T06:02:19.675178+00:00 app[worker.1]: File "/app/.heroku/python/lib/python3.6/site-packages/django/db/models/fields/__init__.py", line 172, in __init__
2018-02-12T06:02:19.675179+00:00 app[worker.1]: self.db_tablespace = db_tablespace or settings.DEFAULT_INDEX_TABLESPACE
2018-02-12T06:02:19.675180+00:00 app[worker.1]: File "/app/.heroku/python/lib/python3.6/site-packages/django/conf/__init__.py", line 56, in __getattr__
2018-02-12T06:02:19.675181+00:00 app[worker.1]: self._setup(name)
2018-02-12T06:02:19.675183+00:00 app[worker.1]: File "/app/.heroku/python/lib/python3.6/site-packages/django/conf/__init__.py", line 39, in _setup
2018-02-12T06:02:19.675184+00:00 app[worker.1]: % (desc, ENVIRONMENT_VARIABLE))
2018-02-12T06:02:19.675185+00:00 app[worker.1]: django.core.exceptions.ImproperlyConfigured: Requested setting DEFAULT_INDEX_TABLESPACE, but settings are not configured. You must either define the environment variable DJANGO_SETTINGS_MODULE or call settings.configure() before accessing settings.
2018-02-12T06:02:19.675186+00:00 app[worker.1]: 06:02:19 Moving job to 'failed' queue根据错误,我尝试使用下面的命令设置DJANGO_SETTINGS_MODULE。
heroku运行DJANGO_SETTINGS_MODULE=django.conf.global_settings
但是在这之后,heroku应用程序没有启动,当我尝试在heroku上运行我的应用程序时,开始抛出错误""SECRET_KEY setting not be empty“”。
目前,我从heroku中删除了配置变量"DJANGO_SETTINGS_MODULE“,应用程序正在运行,但没有任何后台工作进程。
另外,如果使用Redis to go比使用芹菜或任何其他更好和更简单的替代方案更好,也请告知。
发布于 2018-02-12 15:14:03
如下所示设置您的配置变量:
heroku config:set DJANGO_SETTINGS_MODULE=<value> 这会为你的整个应用设置一个config var。
你用"heroku run“做的任何事情都只会影响一个临时的one-off dyno,而不是整个应用程序。
https://stackoverflow.com/questions/48740556
复制相似问题