X-Git-Url: https://git.mdrn.pl/wolnelektury.git/blobdiff_plain/87e084d47c335cd6f0b3e91d614999f55d148044..ea221b2bc448ce22dfda4f1ead2968fa7de31771:/fabfile.py diff --git a/fabfile.py b/fabfile.py index e614e9ce5..11442c7ea 100644 --- a/fabfile.py +++ b/fabfile.py @@ -1,4 +1,6 @@ -from fnpdjango.deploy import * +# -*- coding: utf-8 -*- +from fnpdeploy import * + try: from fabfile_local import * except ImportError: @@ -8,14 +10,42 @@ except ImportError: env.project_name = 'wolnelektury' +class ManageTask(Task): + def __init__(self, name, params='', **kwargs): + super(ManageTask, self).__init__(**kwargs) + self.name = name + self.params = params + + def run(self): + require('app_path', 'project_name') + with cd(get_django_root_path('current')): + run('source %(ve)s/bin/activate && python manage.py %(task)s %(params)s' % { + 've': env.ve, + 'task': self.name, + 'params': self.params, + }, pty=True) + + +class Memcached(Service): + def run(self): + print '>>> memcached: restart' + sudo('/etc/init.d/memcached restart', shell=False) + + @task def production(): env.hosts = ['giewont.icm.edu.pl'] env.user = 'lektury' env.app_path = '/srv/wolnelektury.pl' + env.django_root_path = 'src' + env.requirements_file = 'requirements/requirements.txt' + env.pre_collectstatic = [ + ManageTask('update_counters'), + ] env.services = [ Supervisord('wolnelektury'), Supervisord('wolnelektury.celery'), + Memcached(), ] @@ -24,7 +54,15 @@ def beta(): env.hosts = ['giewont.icm.edu.pl'] env.user = 'lektury' env.app_path = '/srv/wolnelektury.pl/beta' - env.services = [] + env.ve = '/srv/wolnelektury.pl/ve' + env.django_root_path = 'src' + env.requirements_file = 'requirements/requirements.txt' + env.pre_collectstatic = [ + ManageTask('update_counters'), + ] + env.services = [ + Supervisord('beta'), + ] @task