Решил поделиться с вами тем, как поставить проект написаный на Python/Django на сервер heroku. Heroku — это бесплатный хостинг для тестирования своих проектов. Если вам нужно посмотреть как действует проект в боевом режиме — вперед!
1. Надо пройти регистрацию на heroku. В этом нет ничего сложного, просто вводите данные, подтверждаете на почте аккаунт, и вперед.
2. Установка командной строки heroku., слева-вверху видим burger меню, клацаем по нему и выбираем — Documentation -> Python, нажимаем Get Start With Python. Дальше слева нажимаем Set Up и выбираем установку heroku console на вашу операционную систему, тут нет ничего сложного, просто устанавливаем как вам удобно и все.
3. Закрываем пока что браузер и заходим в командную строку или bash. Переходим в папку с нашим django-проектом и открываем проект в текстовом редакторе (в моем случае Pycharm). Дальше нам придется работать с системой контроля версий git. Если у вас нет данной утилиты, то вы ее можете скачать по адресу — git-scm.com/downloads. Пройдите простую установку и возвращайтесь к данной статье.
4. В нашей консоли прописываем команду:
После чего создаем в каталоге проекта файл .gitignore. В нем мы можем записать все файлы которые мы хотим проигнорировать при загрузке на сервер. Допустим на сервере я буду использовать базу данных MySQL, по этому файл db.sqlite3 мне не нужен.
Пишем этот код:
После пишем в bush 3 команды
1-ая отвечает за добавление всех фалов в git.
2-ая за сохранение данных файлов на компьютере локально с сообщением GIT init.
5. Теперь входим в наш heroku через консоль. Пишем:
Дальше вводим сначало E-mail, нажимаем Enter. Потом пароль и опять же Enter.
Вот мы и вошли. Дальше создаем приложение, мы это будем делать через консоль так что вводим в нее следующее:
Команда создает приложение. После этой команды через пробел можно написать имя приложения. В противном случае heroku с генерирует его автоматически и выведет в консоль.
6. Дальше создаем несколько файлов, для того что бы heroku понял что мы загружаем и как:
Procfile
runtime.txt
Дальше устанавливаем сам gunicorn для обслуживания django через wsgi:
Сразу же устанавливаем whitenoise для работы со статическими файлами:
7. Теперь переходим в settings.py и делаем следующие изменения:
Добавляем static_root если у вас его нет:
8. Настраиваем работу с базой данных. Устанавливаем утилиту для более удобной работы:
переходим опять в настройки и пишем:
9. Последний файл который нам нужен — requirements.txt, в нем будут все установленные библиотеки:
У нас создался файл со всеми пакетами. Можете записать в него различные пакеты с их версиями. Обязательно надо записать эту строчку:
Если при дальнейших действиях у вас возникнут ошибки, посмотрите, может вам надо добавить сюда какой либо пакет.
10. Ну и финал, загружаем на сервер.
Переходим в консоль и пишем такие команды:
Если у вас не получилось с main, попробуйте:
И пошел процесс загрузки нашего проекта на heroku. Дальше вам в консоль напишет ссылку на наш проект. По ней мы будем переходить потом, а сейчас выполним все миграции:
И создадим super user-а:
Переходим по раннее полученной ссылке, и видим наш проект. Вот так за 10 шагов мы загрузили наш проект на heroku и настроили базу данных. Всем спасибо за внимание.
1. Надо пройти регистрацию на heroku. В этом нет ничего сложного, просто вводите данные, подтверждаете на почте аккаунт, и вперед.
2. Установка командной строки heroku., слева-вверху видим burger меню, клацаем по нему и выбираем — Documentation -> Python, нажимаем Get Start With Python. Дальше слева нажимаем Set Up и выбираем установку heroku console на вашу операционную систему, тут нет ничего сложного, просто устанавливаем как вам удобно и все.
3. Закрываем пока что браузер и заходим в командную строку или bash. Переходим в папку с нашим django-проектом и открываем проект в текстовом редакторе (в моем случае Pycharm). Дальше нам придется работать с системой контроля версий git. Если у вас нет данной утилиты, то вы ее можете скачать по адресу — git-scm.com/downloads. Пройдите простую установку и возвращайтесь к данной статье.
4. В нашей консоли прописываем команду:
git init
После чего создаем в каталоге проекта файл .gitignore. В нем мы можем записать все файлы которые мы хотим проигнорировать при загрузке на сервер. Допустим на сервере я буду использовать базу данных MySQL, по этому файл db.sqlite3 мне не нужен.
Пишем этот код:
__pychache__/
*.pyc
db.sqlite3
После пишем в bush 3 команды
git add .
git commit -m "GIT init"
1-ая отвечает за добавление всех фалов в git.
2-ая за сохранение данных файлов на компьютере локально с сообщением GIT init.
5. Теперь входим в наш heroku через консоль. Пишем:
heroku login
Дальше вводим сначало E-mail, нажимаем Enter. Потом пароль и опять же Enter.
Вот мы и вошли. Дальше создаем приложение, мы это будем делать через консоль так что вводим в нее следующее:
heroku create
Команда создает приложение. После этой команды через пробел можно написать имя приложения. В противном случае heroku с генерирует его автоматически и выведет в консоль.
6. Дальше создаем несколько файлов, для того что бы heroku понял что мы загружаем и как:
Procfile
runtime.txt
- В runtime сразу пишем этот код:
python-3.8.5
После python-, пишите вашу версию python.
- Procfile:
web: gunicorn appname.wsgi --log-file -
Вместо appname пишите название своего проекта.
Дальше устанавливаем сам gunicorn для обслуживания django через wsgi:
pip install gunicorn
Сразу же устанавливаем whitenoise для работы со статическими файлами:
pip install witenoise
7. Теперь переходим в settings.py и делаем следующие изменения:
ALLOWED_HOSTS = ['*']
Добавляем static_root если у вас его нет:
import os
STATIC_ROOT = os.path.join(BASE_DIR, 'static')
8. Настраиваем работу с базой данных. Устанавливаем утилиту для более удобной работы:
pip install dj-database-url
переходим опять в настройки и пишем:
import dj-database-url
db_from_env = dj-database-url.config()
DATABASE['default'].update(db_from_env)
9. Последний файл который нам нужен — requirements.txt, в нем будут все установленные библиотеки:
pip freeze -> requirements.txt
У нас создался файл со всеми пакетами. Можете записать в него различные пакеты с их версиями. Обязательно надо записать эту строчку:
psycopg2==2.8.6
Если при дальнейших действиях у вас возникнут ошибки, посмотрите, может вам надо добавить сюда какой либо пакет.
10. Ну и финал, загружаем на сервер.
Переходим в консоль и пишем такие команды:
git add .
git commit -m "Diploy"
git push heroku main
Если у вас не получилось с main, попробуйте:
git push heroku master
И пошел процесс загрузки нашего проекта на heroku. Дальше вам в консоль напишет ссылку на наш проект. По ней мы будем переходить потом, а сейчас выполним все миграции:
heroku run python manage.py migrate
И создадим super user-а:
heroku run python manage.py createsuperuser
Переходим по раннее полученной ссылке, и видим наш проект. Вот так за 10 шагов мы загрузили наш проект на heroku и настроили базу данных. Всем спасибо за внимание.
maxzhurkin
Хабр, который мы заслужили:
тем не менее с учётом того, что ?почему если
Shtucer
Ctrl-A Ctrl-Enter
Потому что "гладиулос" и diploy на bush.
И статью вычитывать — это не модно.
maxzhurkin
Про Ctrl-Enter знаю.
С Ctrl-A не сработает.
Не вижу смысла использовать Ctrl-Enter для статьи, которой здесь быть не должно.
Shtucer
Это был намёк на то, что всю статью следует отправить в переработку.
PashaPodolsky
Пф, это ещё что...