Fabric和Django部署方案

时间:2014-07-21 14:51:07

标签: django fabric

我的部署方案涉及典型的Django设置,但在多个服务器上运行。基本上,我上传源代码,执行几个构建步骤(编译.pyc文件,collectstatic等),然后运行syncdbmigrate,最后重新加载apache2。

我的问题是我将代码部署到4-5台服务器,未来计划更多,部署需要很长时间(每台服务器超过一分钟)。除syncdb / migrate之外,部署过程中的几乎所有步骤都可以并行完成。有没有办法使用Fabric只在其中一台机器上运行它们(数据库服务器与其余机器分开),并且并行运行其余的任务?

1 个答案:

答案 0 :(得分:0)

您是否尝试为每个任务创建一个函数,并尝试另一个任务来调用它们?

示例:

@task
@parallel
copy_files():
    run('cp *')
    ...

@task
@parallel
restart_apache():
    run('/etc/init.d/httpd restart')
    ...

@task
syncdb_app():
    run('python manage.py syncdb')
    ...

@task
deploy():
    copy_files()
    restart_apache()
    syncdb_app()
    ...