Evgenii Legotckoi
23 апреля 2019 г. 14:10

Django - Урок 044. Установка и настройка Django на Mac OS

Предлагаю рассмотреть процесс установки и настройки проекта Django на Mac OS X на основе существующего проекта.

Некоторые шаги будут аналогичны тем, которые уже были выполнены в [статье по установке Django для Ubuntu] (https://evileg.com/en/post/3/).


Настройка виртуальной среды

  1. Установка python 3
    1. brew install python3
  2. InstУстановкаall pip
    1. sudo easy_install pip
  3. Установка virtualenv и создание виртуальной среды
    1. sudo pip3 install virtualenv
  4. Настройка виртуальной среды для проекта
    1. virtualenv project_env --python=python3
  5. Перейдите в каталог виртуальной среды проекта и клонируйте репозиторий.
    1. cd project_env
    2. git clone git@bitbucket.org:MyUser/project.git
  6. Мы также клонируем подмодули, если ваш проект использует подмодуль git.
    1. cd project
    2. git submodule init
    3. git submodule update
  7. Я надеюсь, что вы используете файл requirements.txt, потому что пришло время установить все необходимые пакеты в проект
    1. pip install -r requirements.txt

Установите необходимую версию Python

Если вам нужна определенная версия python, например, если в репозиториях вашего рабочего сервера нет последней версии, вам необходимо настроить Mac OS X специально для работы с требуемой версией.

  1. brew install pyenv
  2. echo 'eval "$(pyenv init -)"' >> ~/.bash_profile
  3. source ~/.bash_profile
  4. brew install zlib
  5. pyenv install 3.6.7

Если вы не можете установить python и возникает следующая ошибка

  1. BUILD FAILED (OS X 10.14.4 using python-build 20180424)
  2.  
  3. Inspect or clean up the working tree at /var/folders/qk/l3vyb_653ksb55yt5r54rt380000gn/T/python-build.20190421214232.40274
  4. Results logged to /var/folders/qk/l3vyb_653ksb55yt5r54rt380000gn/T/python-build.20190421214232.40274.log
  5.  
  6. Last 10 log lines:
  7. File "/private/var/folders/qk/l3vyb_653ksb55yt5r54rt380000gn/T/python-build.20190421214232.40274/Python-3.6.7/Lib/ensurepip/__main__.py", line 5, in <module>
  8. sys.exit(ensurepip._main())
  9. File "/private/var/folders/qk/l3vyb_653ksb55yt5r54rt380000gn/T/python-build.20190421214232.40274/Python-3.6.7/Lib/ensurepip/__init__.py", line 204, in _main
  10. default_pip=args.default_pip,
  11. File "/private/var/folders/qk/l3vyb_653ksb55yt5r54rt380000gn/T/python-build.20190421214232.40274/Python-3.6.7/Lib/ensurepip/__init__.py", line 117, in _bootstrap
  12. return _run_pip(args + [p[0] for p in _PROJECTS], additional_paths)
  13. File "/private/var/folders/qk/l3vyb_653ksb55yt5r54rt380000gn/T/python-build.20190421214232.40274/Python-3.6.7/Lib/ensurepip/__init__.py", line 27, in _run_pip
  14. import pip._internal
  15. zipimport.ZipImportError: can't decompress data; zlib not available
  16. make: *** [install] Error 1

затем создайте файл .zshrc со следующим содержимым

  1. # For compilers to find zlib you may need to set:
  2. export LDFLAGS="${LDFLAGS} -L/usr/local/opt/zlib/lib"
  3. export CPPFLAGS="${CPPFLAGS} -I/usr/local/opt/zlib/include"
  4.  
  5. # For pkg-config to find zlib you may need to set:
  6. export PKG_CONFIG_PATH="${PKG_CONFIG_PATH} /usr/local/opt/zlib/lib/pkgconfig"

Далее выполните остальные действия.

  1. source .zshrc
  2. pyenv install 3.6.7

Проверить доступные версии python

  1. pyenv versions

Установите необходимую версию python

  1. pyenv local 3.6.7
  2. pyenv global 3.6.7

Проверьте версию Python, которая сейчас используется в вашей Mac OS X.

  1. python --version

После этого вам нужно будет повторить все шаги из настроек виртуального окружения, начиная с шага 4, если вы уже установили virtualenv. Или полностью повторить все эти шаги.

Установите и настройте PostgreSQL

  1. Удаление предыдущей версии Postgres
    1. brew uninstall --force postgresql
  2. Удалить все файлы Postgres
    1. rm -rf /usr/local/var/postgres
  3. Установка Postgres с помощью Homebrew
    1. brew install postgres
  4. Установка PostGIS с помощью Homebrew
    1. brew install postgis
  5. Запустите сервер PostgreSQL. Вам может понадобиться запускать эту команду каждый раз, когда вы разрабатываете сайт.
    1. pg_ctl -D /usr/local/var/postgres start
  6. Создание базы данных проекта. Многие из этих шагов были описаны в самой первой статье по настройке Django на компьютере под управлением ОС.
    1. psql postgres
    2. CREATE DATABASE myproject;
    3. CREATE USER myprojectuser WITH PASSWORD 'password';
    4. ALTER ROLE myprojectuser SET client_encoding TO 'utf8';
    5. ALTER ROLE myprojectuser SET default_transaction_isolation TO 'read committed';
    6. ALTER ROLE myprojectuser SET timezone TO 'UTC';
    7. GRANT ALL PRIVILEGES ON DATABASE myproject TO myprojectuser;
    8. \q

Установить и настроить Nginx.

Я использую Nginx для распространения статического контента, поэтому мы также установим Nginx на машину для разработки.

  1. brew install nginx
  2. sudo brew services start nginx

Настройка конфигурации Nginx

На этом этапе вам необходимо настроить сервер Nginx. Для чего вам необходимо отредактировать файл nginx.conf, а так же создать файл настроек вашего сервера в каталоге серверов.

  1. nano /usr/local/etc/nginx/nginx.conf

Удалите содержимое файла и добавьте следующую информацию.

  1. worker_processes 1;
  2.  
  3. events {
  4. worker_connections 1024;
  5. }
  6.  
  7.  
  8. http {
  9. include mime.types;
  10. default_type application/octet-stream;
  11.  
  12. sendfile on;
  13. keepalive_timeout 65;
  14. include servers/*;
  15. }

Затем создайте файл myproject

  1. touch /usr/local/etc/nginx/servers/myproject

И добавьте контент, который будет выглядеть так.

  1. server {
  2. listen 80;
  3. server_name 111.222.333.44; # здесь прописать или IP-адрес или доменное имя сервера
  4.  
  5. location /static/ {
  6. root /Users/<user>/myprojectenv/myproject/myproject/;
  7. expires 30d;
  8. }
  9.  
  10. location /media/ {
  11. root /Users/<user>/myprojectenv/myproject/myproject/;
  12. expires 30d;
  13. }
  14.  
  15. location / {
  16. proxy_pass http://127.0.0.1:8000;
  17. proxy_set_header Host $server_name;
  18. proxy_set_header X-Real-IP $remote_addr;
  19. proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
  20. }
  21. }
  22.  

Затем перезапустите сервер Nginx

  1. sudo brew services restart nginx

Вывод

А потом не забываем выполнить миграцию базы, сбор статических файлов через collectstatic и другие необходимые в вашем проекте процедуры.

For Django, I recommend Timeweb VDS-server .

Рекомендуемые статьи по этой тематике

По статье задано0вопрос(ов)

1

Вам это нравится? Поделитесь в социальных сетях!

Комментарии

Только авторизованные пользователи могут публиковать комментарии.
Пожалуйста, авторизуйтесь или зарегистрируйтесь