Я використовую git push для розгортання у виробництві та налаштування git hooks для запуску сценарію. Перевага такого підходу полягає в тому, що ви також можете одночасно виконати міграцію та встановлення пакунків. https://mikeeverhart.net/2013/01/using-git-to-deploy-code/
mkdir -p /home/git/project_name.git
cd /home/git/project_name.git
git init --bare
Потім створіть сценарій /home/git/project_name.git/hooks/post-receive
.
#!/bin/bash
GIT_WORK_TREE=/path/to/project git checkout -f
source /path/to/virtualenv/activate
pip install -r /path/to/project/requirements.txt
python /path/to/project/manage.py migrate
sudo supervisorctl restart project_name
Переконайтеся в цьому chmod u+x post-receive
і додайте користувача до судорів. Дозвольте йому працювати sudo supervisorctl
без пароля. https://www.cyberciti.biz/faq/linux-unix-running-sudo-command-without-a-password/
На своєму локальному сервері / сервері розробки я налаштував, git remote
що дозволяє мені перейти на виробничий сервер
git remote add production ssh://user_name@production-server/home/git/project_name.git
# initial push
git push production +master:refs/heads/master
# subsequent push
git push production master
Як бонус, ви побачите всі підказки під час виконання сценарію. Тож ви побачите, чи є якась проблема з перезапуском міграції / встановлення пакета / супервізора.
kill -HUP
PID, а використовував натомість supervisorctl. Не думаю, що це сильно зміниться.