我正在尝试使用Keroku部署Django 2.2项目,以查看生产过程中的外观,但是它似乎无法正常工作,并且由于静态文件上没有明确的说明,因此我很难调试该问题设置。
要了解我的文件和文件结构,这是一棵树:
.
├── apps
│ ├── __pycache__
│ ├── cart
│ │ ├── __pycache__
│ │ ├── migrations
│ │ │ └── __pycache__
│ │ ├── static
│ │ │ └── cart
│ │ │ ├── css
│ │ │ ├── img
│ │ │ ├── js
│ │ │ └── scss
│ │ └── templates
│ │ └── cart
│ ├── products
│ │ ├── __pycache__
│ │ ├── migrations
│ │ │ └── __pycache__
│ │ ├── static
│ │ │ └── products
│ │ │ ├── css
│ │ │ ├── img
│ │ │ ├── js
│ │ │ │ └── tools
│ │ │ └── scss
│ │ │ ├── mixins
│ │ │ ├── utilities
│ │ │ └── vendor
│ │ └── templates
│ │ └── products
│ └── users
│ ├── __pycache__
│ ├── migrations
│ │ └── __pycache__
│ ├── static
│ │ └── users
│ │ ├── css
│ │ ├── img
│ │ ├── js
│ │ └── scss
│ └── templates
│ └── users
├── docs
└── fancyfetish
├── __pycache__
├── settings
│ └── __pycache__
└── static
└── fancyfetish
为使这一点更容易理解,基本上,我有一个标准的Django 2.2设置,但是我的设置分为三种不同的类型:
在主要项目目录中的“设置”目录中提供帮助。
我有三个“应用”,分别是:
它们存储在自己的名为“ apps”的目录中。
由于静态文件,我目前在部署此项目时遇到问题。当前,在涉及静态方面,我的部署设置如下:
STATIC_URL ='/ static /'
STATICFILES_DIRS = [ os.path.join(BASE_DIR,“静态”), ]
STATIC_ROOT = os.path.join(BASE_DIR,'staticfiles')
首先,我不确定这是否正确。其次,每当我推送到heroku进行部署时,我都会得到相同的错误回溯:
remote: FileNotFoundError: [Errno 2] No such file or directory: '/tmp/build_621274608c645b29c99cac8fc9e3a341/fancyfetish/static'
remote:
remote: ! Error while running '$ python manage.py collectstatic --noinput'.
remote: See traceback above for details.
完整的追溯在这里:
Enumerating objects: 347, done.
Counting objects: 100% (347/347), done.
Delta compression using up to 8 threads
Compressing objects: 100% (325/325), done.
Writing objects: 100% (347/347), 569.74 KiB | 11.63 MiB/s, done.
Total 347 (delta 130), reused 0 (delta 0)
remote: Compressing source files... done.
remote: Building source:
remote:
remote: -----> Python app detected
remote: -----> Installing python-3.6.9
remote: -----> Installing pip
remote: -----> Installing SQLite3
remote: -----> Installing requirements with pip
remote: Collecting beautifulsoup4==4.8.1 (from -r /tmp/build_621274608c645b29c99cac8fc9e3a341/requirements.txt (line 1))
remote: Downloading https://files.pythonhosted.org/packages/3b/c8/a55eb6ea11cd7e5ac4bacdf92bac4693b90d3ba79268be16527555e186f0/beautifulsoup4-4.
8.1-py3-none-any.whl (101kB)
remote: Collecting Django==2.2.6 (from -r /tmp/build_621274608c645b29c99cac8fc9e3a341/requirements.txt (line 2))
remote: Downloading https://files.pythonhosted.org/packages/b2/79/df0ffea7bf1e02c073c2633702c90f4384645c40a1dd09a308e02ef0c817/Django-2.2.6-py3-none-any.whl (7.5MB)
remote: Collecting django-appconf==1.0.3 (from -r /tmp/build_621274608c645b29c99cac8fc9e3a341/requirements.txt (line 3))
remote: Downloading https://files.pythonhosted.org/packages/f6/b3/fcec63afcf323581c4919f21e90ef8c8200034108a6a0ab47a6bf6a9327b/django_appconf-1.0.3-py2.py3-none-any.whl
remote: Collecting django-bootstrap4==1.0.1 (from -r /tmp/build_621274608c645b29c99cac8fc9e3a341/requirements.txt (line 4))
remote: Downloading https://files.pythonhosted.org/packages/3a/01/af39712da23fb3a1f1b41787dc150c255bd60f70324a6ec14be90d1576f2/django-bootstrap4-1.0.1.tar.gz (6.8MB)
remote: Collecting django-compressor==2.3 (from -r /tmp/build_621274608c645b29c99cac8fc9e3a341/requirements.txt (line 5))
remote: Downloading https://files.pythonhosted.org/packages/43/e2/50e21afd7e13b522f7d1a29cf0a6dd65e19835950dce3be3c5928e668846/django_compressor-2.3-py2.py3-none-any.whl (124kB)
remote: Collecting django-libsass==0.7 (from -r /tmp/build_621274608c645b29c99cac8fc9e3a341/requirements.txt (line 6))
remote: Downloading https://files.pythonhosted.org/packages/96/1a/0ebcb4e90b41f27d2b96adba01c62a590942686c6dbc7371ab89be044066/django-libsass-0.7.tar.gz
remote: Collecting django-sass-processor==0.7.4 (from -r /tmp/build_621274608c645b29c99cac8fc9e3a341/requirements.txt (line 7))
remote: Downloading https://files.pythonhosted.org/packages/6d/38/4d607938386244bc755dafa37e5dac6a222f6c3f1985d77b80c3e3712321/django-sass-processor-0.7.4.tar.gz
remote: Collecting libsass==0.19.3 (from -r /tmp/build_621274608c645b29c99cac8fc9e3a341/requirements.txt (line 8))
remote: Downloading https://files.pythonhosted.org/packages/88/51/1ea20121e4022d3f6ef7a87a0ed1063c83ba885cd22ae24516991a4e7b6b/libsass-0.19.3-cp36-cp36m-manylinux1_x86_64.whl (9.1MB)
remote: Collecting mysql-connector-python==8.0.18 (from -r /tmp/build_621274608c645b29c99cac8fc9e3a341/requirements.txt (line 9))
remote: Downloading https://files.pythonhosted.org/packages/f7/59/c2220c52d747da492f2aed108cdf99b640b88cf89dbbe2ea13a8c04201aa/mysql_connector_python-8.0.18-cp36-cp36m-manylinux1_x86_64.whl (16.1MB)
remote: Collecting Pillow==6.2.1 (from -r /tmp/build_621274608c645b29c99cac8fc9e3a341/requirements.txt (line 10))
remote: Downloading https://files.pythonhosted.org/packages/10/5c/0e94e689de2476c4c5e644a3bd223a1c1b9e2bdb7c510191750be74fa786/Pillow-6.2.1-cp36-cp36m-manylinux1_x86_64.whl (2.1MB)
remote: Collecting protobuf==3.10.0 (from -r /tmp/build_621274608c645b29c99cac8fc9e3a341/requirements.txt (line 11))
remote: Downloading https://files.pythonhosted.org/packages/a8/52/d8d2dbff74b8bf517c42db8d44c3f9ef6555e6f5d6caddfa3f207b9143df/protobuf-3.10.0-cp36-cp36m-manylinux1_x86_64.whl (1.3MB)
remote: Collecting pytz==2019.3 (from -r /tmp/build_621274608c645b29c99cac8fc9e3a341/requirements.txt (line 12))
remote: Downloading https://files.pythonhosted.org/packages/e7/f9/f0b53f88060247251bf481fa6ea62cd0d25bf1b11a87888e53ce5b7c8ad2/pytz-2019.3-py2.py3-none-any.whl (509kB)
remote: Collecting rcssmin==1.0.6 (from -r /tmp/build_621274608c645b29c99cac8fc9e3a341/requirements.txt (line 13))
remote: Downloading https://files.pythonhosted.org/packages/e2/5f/852be8aa80d1c24de9b030cdb6532bc7e7a1c8461554f6edbe14335ba890/rcssmin-1.0.6.tar.gz (582kB)
remote: Collecting rjsmin==1.1.0 (from -r /tmp/build_621274608c645b29c99cac8fc9e3a341/requirements.txt (line 14))
remote: Downloading https://files.pythonhosted.org/packages/62/ee/574b170bbe7a059314e7239305cb829379232a408901585019e012e71170/rjsmin-1.1.0-cp36-cp36m-manylinux1_x86_64.whl
remote: Collecting six==1.12.0 (from -r /tmp/build_621274608c645b29c99cac8fc9e3a341/requirements.txt (line 15))
remote: Downloading https://files.pythonhosted.org/packages/73/fb/00a976f728d0d1fecfe898238ce23f502a721c0ac0ecfedb80e0d88c64e9/six-1.12.0-py2.py3-none-any.whl
remote: Collecting soupsieve==1.9.5 (from -r /tmp/build_621274608c645b29c99cac8fc9e3a341/requirements.txt (line 16))
remote: Downloading https://files.pythonhosted.org/packages/81/94/03c0f04471fc245d08d0a99f7946ac228ca98da4fa75796c507f61e688c2/soupsieve-1.9.5-py2.py3-none-any.whl
remote: Collecting sqlparse==0.3.0 (from -r /tmp/build_621274608c645b29c99cac8fc9e3a341/requirements.txt (line 17))
remote: Downloading https://files.pythonhosted.org/packages/ef/53/900f7d2a54557c6a37886585a91336520e5539e3ae2423ff1102daf4f3a7/sqlparse-0.3.0-py2.py3-none-any.whl
remote: Installing collected packages: soupsieve, beautifulsoup4, sqlparse, pytz, Django, six, django-appconf, django-bootstrap4, rcssmin, rjsmin, django-compressor, libsass, django-libsass, django-sass-processor, protobuf, mysql-connector-python, Pillow
remote: Running setup.py install for django-bootstrap4: started
remote: Running setup.py install for django-bootstrap4: finished with status 'done'
remote: Running setup.py install for rcssmin: started
remote: Running setup.py install for rcssmin: finished with status 'done'
remote: Running setup.py install for django-libsass: started
remote: Running setup.py install for django-libsass: finished with status 'done'
remote: Running setup.py install for django-sass-processor: started
remote: Running setup.py install for django-sass-processor: finished with status 'done'
remote: Successfully installed Django-2.2.6 Pillow-6.2.1 beautifulsoup4-4.8.1 django-appconf-1.0.3 django-bootstrap4-1.0.1 django-compressor-2.3 django-libsass-0.7 django-sass-processor-0.7.4 libsass-0.19.3 mysql-connector-python-8.0.18 protobuf-3.10.0 pytz-2019.3 rcssmin-1.0.6 rjsmin-1.1.0 six-1.12.0 soupsieve-1.9.5 sqlparse-0.3.0
remote:
remote: -----> $ python manage.py collectstatic --noinput
remote: Traceback (most recent call last):
remote: File "manage.py", line 21, in <module>
remote: main()
remote: File "manage.py", line 17, in main
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 375, in execute
remote: self.fetch_command(subcommand).run_from_argv(self.argv)
remote: File "/app/.heroku/python/lib/python3.6/site-packages/django/core/management/base.py", line 323, in run_from_argv
remote: self.execute(*args, **cmd_options)
remote: File "/app/.heroku/python/lib/python3.6/site-packages/django/core/management/base.py", line 364, in execute
remote: output = self.handle(*args, **options)
remote: File "/app/.heroku/python/lib/python3.6/site-packages/django/contrib/staticfiles/management/commands/collectstatic.py", line 188, in handle
remote: collected = self.collect()
remote: File "/app/.heroku/python/lib/python3.6/site-packages/django/contrib/staticfiles/management/commands/collectstatic.py", line 105, in collect
remote: for path, storage in finder.list(self.ignore_patterns):
remote: File "/app/.heroku/python/lib/python3.6/site-packages/django/contrib/staticfiles/finders.py", line 131, in list
remote: for path in utils.get_files(storage, ignore_patterns):
remote: File "/app/.heroku/python/lib/python3.6/site-packages/django/contrib/staticfiles/utils.py", line 23, in get_files
remote: directories, files = storage.listdir(location)
remote: File "/app/.heroku/python/lib/python3.6/site-packages/django/core/files/storage.py", line 315, in listdir
remote: for entry in os.scandir(path):
remote: FileNotFoundError: [Errno 2] No such file or directory: '/tmp/build_621274608c645b29c99cac8fc9e3a341/fancyfetish/static'
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
很明显,我认为这主要与“找不到文件”部分有关,但是我不确定如何解决此问题。
我的主项目目录中没有任何静态文件,但是添加了一个空的静态目录,以防万一它正在那里搜索不存在的静态文件,但是它没有帮助。
在此先感谢您提供任何帮助,特别是在静态文件设置方面
答案 0 :(得分:1)
此设置STATICFILES_DIRS = [ os.path.join(BASE_DIR, "static"), ]
告诉Django在BASE_DIR
的名为static的目录中查找静态文件
通过将BASE_DIR
放在settings.py中并运行它,您可以轻松找到自己的print(BASE_DIR)
。
然后只需在该位置创建一个staic文件夹,然后将所有静态文件放在此处。
此外,除非您希望以这种方式管理静态文件夹,否则没有必要为每个应用程序创建静态文件夹。