最初にdjangoを使用し、次にdjango-webhooksを使用して、サーバーを再起動するシェルスクリプトを呼び出そうとしました。djangoがリロードされるため、サーバーの再起動が呼び出されたときにWebページがハングするため、これは機能しませんでした。
次に、fastcgiとpythonだけを使用して、シェルスクリプトを呼び出すURLを作成しました。Pythonスクリプトをサーバーで実行すると機能することはわかっていますが、URLから実行すると機能しません。
Apacheは次のように設定されています。
<VirtualHost *:80>
ServerName webhooks.myserver.com
DocumentRoot /home/ubuntu/web/common/www
<Directory />
Options FollowSymLinks +ExecCGI
AllowOverride All
</Directory>
<Files post.py>
SetHandler fastcgi-script
</Files>
FastCgiServer /home/ubuntu/web/common/www/post.py -processes 2 -socket /tmp/fcgi.sock
</VirtualHost>
apacheによって呼び出されるPythonコードは次のとおりです。
#!/usr/bin/python
import fcgi, warnings, os, subprocess
BASE_DIR = os.getcwd()
def app(environ, start_response):
cmd = "sudo %s/../deploy/postwebhook.sh >> /var/log/votizen/webhooks_run.log 2>> /var/log/votizen/webhooks_error.log &" % BASE_DIR
warnings.warn("Running cmd=%s" % cmd)
bufsize = -1
PIPE = subprocess.PIPE
subprocess.Popen(cmd, shell=isinstance(cmd, basestring),
bufsize=bufsize, stdin=PIPE, stdout=PIPE,
stderr=PIPE, close_fds=True)
warnings.warn("Post deployment webhook completed")
start_response('200 OK', [('Content-Type', 'text/html')])
return('Hello World!')
fcgi.WSGIServer(app, bindAddress = '/tmp/fcgi.sock').run()
そして、シェルスクリプトは次のとおりです。
#!/bin/bash
# restart the apache server
echo ' '
echo 'post webhooks started'
date '+%H:%M:%S %d-%m-%y'
apache2ctl -t; sudo /etc/init.d/apache2 stop; sudo /etc/init.d/apache2 start
# todo: check if apache failed
# copy media files for apps
echo "moving SC to S3"
python /home/ubuntu/web/corporate/manage.py sync_media_s3 -p sc
date '+%H:%M:%S %d-%m-%y'
echo 'post webhooks completed'
apacheログにエラーは表示されません。アクセスログには、トリガーURLが呼び出されていることが示されます。ただし、再起動後にURLが最初に呼び出されたときにのみ、Pythonの警告が表示され、実際にサーバーが再起動されることはありません。