Fabric是一个Python库,可以通过SSH在多个host上批量执行任务。
可以通过编写任务脚本,然后通过Fabric在本地就可以使用SSH在大量远程服务器上自动运行。
这些功能非常适合应用的自动化部署,或者执行系统管理任务。

Fabric官方文档:

1、安装

(1)easy_install

如果没有easy_install,使用
yum install python-setuptools
进行安装。

若安装失败,其余安装方法:
wget -q http://peak.telecommunity.com/dist/ez_setup.py
python ez_setup.py

(2)安装Fabric

在所有机器上使用
easy_install fabric
进行安装。

若出现错误:缺少Python.h文件等
解决方法:yum  install python-devel  -y

2、测试过程

简单的使用教程请看:

任一机器上项目建立git仓库,push到远程库。

Fabric执行机制为通过ssh远程操作服务器,使用python编写脚本文件。
使用详情请看代码注释。

新建fabfile.py文件,文件名为固定格式:

from fabric.api import *
from fabric.colors import * #服务器主机列表
#env.hosts=['username1@host1:port','username2@host2:port']
#如果多个服务器密码相同直接使用
#env.password='password'
#可以使用ssh密钥来代替密码访问远程主机(更安全),前提是需要将公钥保存在远程主机的authorized_keys文件中
#env.key_filename=‘~/.ssh/id_rsa' #若服务器之间密码不同,使用passwords变量存储键值对
#env.passwords = {'username1@host1:port':'password1','username2@host2:port':'password2'} #使用roledefs进行服务器角色分组
#env.roledefs = {
# 'role1': ['username1@host1:port'],['username2@host2:port']
# 'role2': ['['username3@host3:port']']
#} #称为任务函数,可在命令行使用fab local_update:msg=msg 直接调用
def local_update(msg):
#打印红色字体
print red('local host:ali_ibignose')
#打印绿色字体
print green('local git pushing...')
#lcd为本地的cd操作
with lcd('/home/omniREST/'):
#如果当前没有新的更改直接使用commit会终止任务进行,所以将此中断设置仅为输出警告信息
with settings(warn_only=True):
#local为在本地执行命令
local('git add *')
local('git commit -m "%s"' % msg)
local('git push -u origin master')
print green('local git push complete!') #parallel注解的作用是可以使函数并行执行,可用在多个服务器同时进行同一个任务函数
#@parallel
def local_docker_restart():
print red('local host:ali_ibignose')
print green('local docker restarting...')
local('docker restart omniREST ./root/run.sh')
print green('local docker restart complete!') #设置角色使用roles注解,那么该任务函数将会在所有角色为role1的机器上执行
#@roles('role1')
def remote1_update():
#也可直接在任务函数中指明连接主机的信息
env.user='username'
env.host_string='username@host:port'
env.password='password'
print red('remote host:nc_test')
print green('remote git pulling...')
#cd为远程cd操作
with cd('/home/omniREST/tomcat/webapps/ROOT'):
#run为远程执行命令操作
run('git pull origin master')
print green('remote git pull complete!')
print ''
print green('remote tomcat restarting...')
with cd('/home/omniREST/tomcat/bin'):
run('./shutdown.sh')
run('nohup ./startup.sh')
print green('remote tomcat restart complete!') def remote2_update():
print red('remote host:ibignose')
print green('remote git pulling...')
with cd('/data2/usr/ibignose/tomcat/webapps/ROOT'):
run('git pull origin master')
print green('remote git pull complete!')
print ''
print green('remote tomcat restarting...')
with cd('/data2/usr/ibignose/tomcat/bin'):
run('./shutdown.sh')
run('nohup ./startup.sh')
print green('remote tomcat restart complete!') #可以在命令行直接使用fab update:msg=msg 来调用所有任务函数
#执行流程为从上到下,一旦遇到终止性的错误将不会继续执行
def update(msg):
local_update(msg)
print ''
local_docker_restart
print ''
remote1_update()
print ''
remote2_update()
#遍历字典方式操作多服务器
dict_host={'ibignose':'root@42.62.50.218:22','nc_test':'root@54.223.196.153:22'}
dict_user={'ibignose':'root','nc_test':'root'}
dict_pwd={'ibignose':'richardg@b83a6fa8','nc_test':'T6yuj&hg'}
dict_path={'ibignose':'/data2/usr/ibignose/tomcat','nc_test':'/home/omniREST/tomcat'} def remote_update():
for hostname,host in dict_host.iteritems():
env.user='%s' % dict_user[hostname]
env.host_string='%s' % host
env.password='%s' % dict_pwd[hostname]
print red('remote hostname:%s' % hostname)
print green('remote git pulling...')
with cd('%s/webapps/ROOT' % dict_path[hostname]):
run('git pull origin master')
print green('remote git pull complete!')
print ''
print green('remote tomcat restarting...')
with cd('%s/bin' % dict_path[hostname]):
run('./shutdown.sh')
run('nohup ./startup.sh')
print green('remote tomcat restart complete!')


3、遇到的问题

(1)多账号环境下使用远程git仓库。

具体流程请参考:

注意:
(a)~/.ssh/config中的Host不要相同,并且如果有Host值为*的,将其移动至最后。
(b)要使用ssh-add id_rsa_work将私钥添加入ssh-agent缓存中。
(c)git remote add添加远程库的时候记得使用"git@config中Host的值”。

(2)不同的任务如何在不同的服务器上并行执行。

未解决,待继续研究。




使用Faric+Git进行分布式代码管理的更多相关文章

  1. 分布式代码管理 tortoisehg mercurial

    下载客户端:            https://bitbucket.org/tortoisehg/files/downloads mercurial客户端下载:http://mercurial.s ...

  2. [Git] 谷歌的代码管理

    copy from : http://www.ruanyifeng.com/blog/2016/07/google-monolithic-source-repository.html https:// ...

  3. Go语言在线培训哪里好?Git操作和代码管理

    在实际的项目开发过程中,多人进行项目开发,需要涉及到代码管理和协同管理.这就需要使用到代码协同管理工具.在过去,大家都熟悉使用的是SVN软件,而现在Git代码仓库管理软件的使用更为广泛.在本系列实战项 ...

  4. 关于分布式代码管理工具git

    一.安装 Step1  进入官网https://www.git-scm.com/download/下载,然后安装,一直“下一步”即可 Step2  验证是否安装成功,在任意地方右键,菜单中含有Git ...

  5. git是一种分布式代码管理工具,git通过树的形式记录文件的更改历史,比如: base'<--base<--A<--A' ^ | --- B<--B' 小米工程师常常需要寻找两个分支最近的分割点,即base.假设git 树是多叉树,请实现一个算法,计算git树上任意两点的最近分割点。 (假设git树节点数为n,用邻接矩阵的形式表示git树:字符串数组matrix包含n个字符串,每个字符串由字符'0

    // ConsoleApplication10.cpp : 定义控制台应用程序的入口点. // #include "stdafx.h" #include <iostream& ...

  6. GIt如何进行代码管理

    一:Git账号设置(仅第一次需设置): 1.首先打开GIt  Bash  界面

  7. 分布式代码管理github

    Git是世界上最先进的分布式版本的控制系统,特点是:简单大气上档次. Linus在1991年创建了开源的Linux,从此,Linux系统不断发展,已经成为最大的服务器系统软件了.

  8. git subtree模块化代码管理

    Git Subtree 的原理 首先,你有两个伟大的项目——我们叫他P1项目.P2项目,还有一个牛逼的要被多个项目共用的项目——我们叫他S项目.我们通过简要讲解使用Subtree来同步代码的过程来解释 ...

  9. 使用Git Bash进行代码管理

    前提是已经安装了GitBash,这个稍后再出教程 1.新建一个目录,存放下载下来的项目,我在D盘新建了一个“gitspace”文件夹,用来存放下载下来的项目 2.进入刚刚新建的文件夹,即进入“gits ...

随机推荐

  1. POJ3466(01背包变形)

    Proud Merchants Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 131072/65536 K (Java/Others) ...

  2. 2.shell变量

    shell的变量的介绍 shell的变量分为系统变量和用户自定义变量系统变量:$HOME, $PWD, $SHELL, $USER等等,这些变量系统已经定义好了,我们可以直接拿来用用户自定义变量:我们 ...

  3. jquery 的combobox 处理级联

    随笔---jquery 的combobox 处理级联 ------------------------html------------- <select id="groupId&quo ...

  4. python中的三元表达式

    if B = True: return A else: return C 用三元表达式可以写成: return A if B else C

  5. docker从零开始 存储(四)tmpfs挂载

    使用tmpfs挂载 volume和bind mounts允许您在主机和容器之间共享文件,以便即使在容器停止后也可以保留数据. 如果你在Linux上运行Docker,你有第三个选择:tmpfs moun ...

  6. 安装配置GitLab

    在 CentOS 6 安装 使用国内镜像安装,新建 /etc/yum.repos.d/gitlab-ce.repo,添加以下内容 [gitlab-ce] name=gitlab-ce baseurl= ...

  7. (十)while和until循环

    (1)while循环 语法:当条件测试成立(真),执行循环体 while 条件测试 do 循环体 done 1)while批量创建用户1 从user.txt读取到的行数据赋予给变量user值 #!/b ...

  8. 51nod 1459 迷宫游戏【最短路拓展】

    1459 迷宫游戏 基准时间限制:1 秒 空间限制:131072 KB   你来到一个迷宫前.该迷宫由若干个房间组成,每个房间都有一个得分,第一次进入这个房间,你就可以得到这个分数.还有若干双向道路连 ...

  9. HDU 1166 敌兵布阵 <线段树 单点修改 区间查询>

    敌兵布阵 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Submis ...

  10. Spoj Query on a tree III

    题目描述 给出N个点的一棵树(N-1条边),节点有白有黑,初始全为白 有两种操作: 0 i : 改变某点的颜色(原来是黑的变白,原来是白的变黑) 1 v : 询问1到v的路径上的第一个黑点,若无,输出 ...