首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >Fabric和Django部署方案

Fabric和Django部署方案
EN

Stack Overflow用户
提问于 2014-07-21 22:51:07
回答 1查看 74关注 0票数 1

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

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

EN

回答 1

Stack Overflow用户

发布于 2015-07-29 09:23:29

你有没有尝试过为每个任务创建一个函数,然后让另一个任务调用所有任务?

示例:

代码语言:javascript
运行
复制
@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()
    ...
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/24868145

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档