Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/python/327.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
&引用;运行时出错';$python manage.py collectstatic--noinput'&引用;在django上更改数据库后_Python_Django_Git_Heroku - Fatal编程技术网

&引用;运行时出错';$python manage.py collectstatic--noinput'&引用;在django上更改数据库后

&引用;运行时出错';$python manage.py collectstatic--noinput'&引用;在django上更改数据库后,python,django,git,heroku,Python,Django,Git,Heroku,我是Django的初学者,所以如果我遗漏了一些必要的信息,请原谅。我最近在settings.py上修改了数据库,在运行时不断出现错误 git push heroku master 错误块如下所示: Counting objects: 22, done. Delta compression using up to 8 threads. Compressing objects: 100% (22/22), done. Writing objects: 100% (22/22), 4

我是Django的初学者,所以如果我遗漏了一些必要的信息,请原谅。我最近在settings.py上修改了数据库,在运行时不断出现错误

    git push heroku master
错误块如下所示:

    Counting objects: 22, done.
Delta compression using up to 8 threads.
Compressing objects: 100% (22/22), done.
Writing objects: 100% (22/22), 4.84 KiB | 825.00 KiB/s, done.
Total 22 (delta 12), reused 0 (delta 0)
remote: Compressing source files... done.
remote: Building source:
remote: 
remote: -----> Python app detected
remote:  !     Python has released a security update! Please consider upgrading to python-3.6.8
remote:        Learn More: https://devcenter.heroku.com/articles/python-runtimes
remote: -----> Installing requirements with pip
remote: 
remote: -----> $ python manage.py collectstatic --noinput
remote:        Traceback (most recent call last):
remote:          File "/app/.heroku/python/lib/python3.6/site-packages/django/db/backends/postgresql/base.py", line 20, in <module>
remote:            import psycopg2 as Database
remote:        ModuleNotFoundError: No module named 'psycopg2'
remote:        During handling of the above exception, another exception occurred:
remote:        Traceback (most recent call last):
remote:          File "manage.py", line 15, in <module>
remote:            execute_from_command_line(sys.argv   )
remote:          File "/app/.heroku/python/lib/python3.6/site-packages/django/core/management/__init__.py", line 381, in execute_from_command_line  
remote:            utility.execute()
remote:          File "/app/.heroku/python/lib/python3.6/site-packages/django/core/management/__init__.py", line 357, in execute
remote:            django.setup()
remote:          File "/app/.heroku/python/lib/python3.6/site-packages/django/__init__.py", line 24, in setup
remote:            apps.populate(settings.INSTALLED_APPS)
remote:          File "/app/.heroku/python/lib/python3.6/site-packages/django/apps/registry.py", line 112, in populate
remote:            app_config.import_models()
remote:          File "/app/.heroku/python/lib/python3.6/site-packages/django/apps/config.py", line 198, in import_models
remote:            self.models_module = import_module(models_module_name)
remote:          File "/app/.heroku/python/lib/python3.6/importlib/__init__.py", line 126, in import_module
remote:            return _bootstrap._gcd_import(name[level:], package, level)
remote:          File "<frozen importlib._bootstrap>", line 994, in _gcd_import
remote:          File "<frozen importlib._bootstrap>", line 971, in _find_and_load
remote:          File "<frozen importlib._bootstrap>", line 955, in _find_and_load_unlocked
remote:          File "<frozen importlib._bootstrap>", line 665, in _load_unlocked
remote:          File "<frozen importlib._bootstrap_external>", line 678, in exec_module
remote:          File "<frozen importlib._bootstrap>", line 219, in _call_with_frames_removed
remote:          File "/app/.heroku/python/lib/python3.6/site-packages/django/contrib/auth/models.py", line 2, in <module>
remote:            from django.contrib.auth.base_user import AbstractBaseUser, BaseUserManager
remote:          File "/app/.heroku/python/lib/python3.6/site-packages/django/contrib/auth/base_user.py", line 47, in <module>
remote:            class AbstractBaseUser(models.Model):
remote:          File "/app/.heroku/python/lib/python3.6/site-packages/django/db/models/base.py", line 101, in __new__
remote:            new_class.add_to_class('_meta', Options(meta, app_label))
remote:          File "/app/.heroku/python/lib/python3.6/site-packages/django/db/models/base.py", line 305, in add_to_class
remote:            value.contribute_to_class(cls, name)
remote:          File "/app/.heroku/python/lib/python3.6/site-packages/django/db/models/options.py", line 203, in contribute_to_class
remote:            self.db_table = truncate_name(self.db_table, connection.ops.max_name_length())
remote:          File "/app/.heroku/python/lib/python3.6/site-packages/django/db/__init__.py", line 33, in __getattr__
remote:            return getattr(connections[DEFAULT_DB_ALIAS], item)
remote:          File "/app/.heroku/python/lib/python3.6/site-packages/django/db/utils.py", line 202, in __getitem__
remote:            backend = load_backend(db['ENGINE'])
remote:          File "/app/.heroku/python/lib/python3.6/site-packages/django/db/utils.py", line 110, in load_backend
remote:            return import_module('%s.base' % backend_name)
remote:          File "/app/.heroku/python/lib/python3.6/importlib/__init__.py", line 126, in import_module
remote:             return _bootstrap._gcd_import(name[level:], package, level)
remote:           File "/app/.heroku/python/lib/python3.6/site-packages/django/db/backends/postgresql/  base.py", line 24, in <module>
remote:            raise ImproperlyConfigured("Error loading psycopg2 module: %s" % e)
remote:        django.core.exceptions.ImproperlyConfigured: Error loading psycopg2 module: No module    named 'psycopg2'
remote: 
remote:  !     Error while running '$ python manage.py collectstatic --noinput'.
remote:        See traceback above for details.
remote: 
remote:        You may need to update application code to resolve this error.
remote:        Or, you can disable collectstatic for this application:
remote: 
remote:           $ heroku config:set DISABLE_COLLECTSTATIC=1
remote: 
remote:        https://devcenter.heroku.com/articles/django-assets
remote:  !     Push rejected, failed to compile Python app.
remote: 
remote:  !     Push failed
remote: Verifying deploy...
remote: 
remote: !   Push rejected to ewbunlv.
remote: 
To https://git.heroku.com/ewbunlv.git
 ! [remote rejected] master -> master (pre-receive hook declined)
error: failed to push some refs to 'https://git.heroku.com/ewbunlv.git'
my requirements.txt:

    awscli==1.16.91
boto==2.49.0
boto3==1.9.81
botocore==1.12.81
certifi==2018.11.29
chardet==3.0.4
colorama==0.3.9
dj-database-url==0.5.0
Django==2.1.4
django-cleanup==3.0.1
django-s3-folder-storage==0.5
django-storages==1.7.1
docutils==0.14
gunicorn==19.9.0
heroku==0.1.4
idna==2.8
jmespath==0.9.3
Pillow==5.3.0
pyasn1==0.4.5
python-dateutil==2.7.5
pytz==2018.7
PyYAML==3.13
requests==2.21.0
rsa==3.4.2
s3transfer==0.1.13
six==1.12.0
urllib3==1.24.1
whitenoise==4.1.2
我跑了

    heroku run python manage.py collectstatic --dry-run --noinput
它工作得非常好,没有任何错误。我已经在这方面工作了一段时间,但没有结果


它在本地也可以很好地工作,但是当我尝试将其转换为产品时,我得到了上面提到的错误。我遗漏了什么?

就像Chris、phd和Selcuk提到的那样,我似乎忽略了requirements.txt文件中的一些必要部分。我曾经

    pip freeze
并再次复制/粘贴到requirements.txt文件中,这一次成功了

  • 在部署期间禁用collectstatic
  • 部署
  • 使用bower运行静态
  • 为将来的部署启用collecstatic
  • 再次运行collectstatic

  • 您的
    settings.py
    中的那一部分准确吗?有一个明显的引号错误应该会阻止你的应用程序工作(看看语法突出显示)。而且,它看起来像
    psycopg2
    不包含在你的依赖项中。为什么不是呢?很明显,您正在尝试使用它。您是在本地使用PostgreSQL,还是仅在Heroku上使用?在所有环境(包括开发环境)中使用相同的数据库提供程序通常是一个非常好的主意。库不匹配是导致此问题的众多原因之一。您知道的可能重复项您可以执行
    pip freeze>requirements.txt
    将pip freeze的输出直接打印到requirements.txt中?
        pip freeze
    
    heroku config:set DISABLE_COLLECTSTATIC=1
    
    git push heroku master (or git push heroku <branch>:master if not on master)
    
    heroku run python manage.py migrate
    
    heroku run 'bower install --config.interactive=false;grunt prep;python manage.py collectstatic --noinput'
    
    heroku config:unset DISABLE_COLLECTSTATIC
    
    heroku run python manage.py collectstatic