【发布时间】:2020-08-04 04:29:46
【问题描述】:
我正在使用 Docker 处理 Django Cookiecutter 样板。在本地一切正常,所以现在我尝试按照本指南将应用程序部署到 Heroku:Deployment on Heroku。我正在使用 Django 3 和 Rest 框架。用于开发的 Docker。
运行配置命令后,我推送到 Heroku master 并收到此错误:
Error while running '$ python manage.py collectstatic --noinput'.
这是踪迹:
remote: -----> $ python manage.py collectstatic --noinput
remote: Traceback (most recent call last):
remote: File "/app/.heroku/python/lib/python3.7/site-packages/environ/environ.py", line 273, in get_value
remote: value = self.ENVIRON[var]
remote: File "/app/.heroku/python/lib/python3.7/os.py", line 679, in __getitem__
remote: raise KeyError(key) from None
remote: KeyError: 'SENDGRID_API_KEY'
remote: During handling of the above exception, another exception occurred:
remote: Traceback (most recent call last):
remote: File "manage.py", line 31, in <module>
remote: execute_from_command_line(sys.argv)
remote: File "/app/.heroku/python/lib/python3.7/site-packages/django/core/management/__init__.py", line 401, in execute_from_command_line
remote: utility.execute()
remote: File "/app/.heroku/python/lib/python3.7/site-packages/django/core/management/__init__.py", line 395, in execute
remote: self.fetch_command(subcommand).run_from_argv(self.argv)
remote: File "/app/.heroku/python/lib/python3.7/site-packages/django/core/management/__init__.py", line 231, in fetch_command
remote: settings.INSTALLED_APPS
remote: File "/app/.heroku/python/lib/python3.7/site-packages/django/conf/__init__.py", line 76, in __getattr__
remote: self._setup(name)
remote: File "/app/.heroku/python/lib/python3.7/site-packages/django/conf/__init__.py", line 63, in _setup
remote: self._wrapped = Settings(settings_module)
remote: File "/app/.heroku/python/lib/python3.7/site-packages/django/conf/__init__.py", line 142, in __init__
remote: mod = importlib.import_module(self.SETTINGS_MODULE)
remote: File "/app/.heroku/python/lib/python3.7/importlib/__init__.py", line 127, in import_module
remote: return _bootstrap._gcd_import(name[level:], package, level)
remote: File "<frozen importlib._bootstrap>", line 1006, in _gcd_import
remote: File "<frozen importlib._bootstrap>", line 983, in _find_and_load
remote: File "<frozen importlib._bootstrap>", line 967, in _find_and_load_unlocked
remote: File "<frozen importlib._bootstrap>", line 677, in _load_unlocked
remote: File "<frozen importlib._bootstrap_external>", line 728, in exec_module
remote: File "<frozen importlib._bootstrap>", line 219, in _call_with_frames_removed
remote: File "/tmp/build_027dd19e3113d3ba2634e63f0f93e673/config/settings/production.py", line 128, in <module>
remote: "SENDGRID_API_KEY": env("SENDGRID_API_KEY"),
remote: File "/app/.heroku/python/lib/python3.7/site-packages/environ/environ.py", line 123, in __call__
remote: return self.get_value(var, cast=cast, default=default, parse_default=parse_default)
remote: File "/app/.heroku/python/lib/python3.7/site-packages/environ/environ.py", line 277, in get_value
remote: raise ImproperlyConfigured(error_msg)
remote: django.core.exceptions.ImproperlyConfigured: Set the SENDGRID_API_KEY environment variable
在错误下方,我收到使用此命令禁用收集静态的消息:
$ heroku config:set DISABLE_COLLECTSTATIC=1
我运行上面的命令并继续,但是下一个命令不起作用,因为 Heroku 找不到 manage.py 文件
heroku run python manage.py createsuperuser
我在网上搜索了各种部署指南,但似乎在 Heroku 上部署 Django 应用程序并不像在 Rails 上那样简单。
【问题讨论】:
标签: django docker heroku django-3.0 cookiecutter-django