使用Faric+Git进行分布式代码管理
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!')
使用Faric+Git进行分布式代码管理的更多相关文章
- 分布式代码管理 tortoisehg mercurial
下载客户端: https://bitbucket.org/tortoisehg/files/downloads mercurial客户端下载:http://mercurial.s ...
- [Git] 谷歌的代码管理
copy from : http://www.ruanyifeng.com/blog/2016/07/google-monolithic-source-repository.html https:// ...
- Go语言在线培训哪里好?Git操作和代码管理
在实际的项目开发过程中,多人进行项目开发,需要涉及到代码管理和协同管理.这就需要使用到代码协同管理工具.在过去,大家都熟悉使用的是SVN软件,而现在Git代码仓库管理软件的使用更为广泛.在本系列实战项 ...
- 关于分布式代码管理工具git
一.安装 Step1 进入官网https://www.git-scm.com/download/下载,然后安装,一直“下一步”即可 Step2 验证是否安装成功,在任意地方右键,菜单中含有Git ...
- git是一种分布式代码管理工具,git通过树的形式记录文件的更改历史,比如: base'<--base<--A<--A' ^ | --- B<--B' 小米工程师常常需要寻找两个分支最近的分割点,即base.假设git 树是多叉树,请实现一个算法,计算git树上任意两点的最近分割点。 (假设git树节点数为n,用邻接矩阵的形式表示git树:字符串数组matrix包含n个字符串,每个字符串由字符'0
// ConsoleApplication10.cpp : 定义控制台应用程序的入口点. // #include "stdafx.h" #include <iostream& ...
- GIt如何进行代码管理
一:Git账号设置(仅第一次需设置): 1.首先打开GIt Bash 界面
- 分布式代码管理github
Git是世界上最先进的分布式版本的控制系统,特点是:简单大气上档次. Linus在1991年创建了开源的Linux,从此,Linux系统不断发展,已经成为最大的服务器系统软件了.
- git subtree模块化代码管理
Git Subtree 的原理 首先,你有两个伟大的项目——我们叫他P1项目.P2项目,还有一个牛逼的要被多个项目共用的项目——我们叫他S项目.我们通过简要讲解使用Subtree来同步代码的过程来解释 ...
- 使用Git Bash进行代码管理
前提是已经安装了GitBash,这个稍后再出教程 1.新建一个目录,存放下载下来的项目,我在D盘新建了一个“gitspace”文件夹,用来存放下载下来的项目 2.进入刚刚新建的文件夹,即进入“gits ...
随机推荐
- 【转】使用者角度看bionic pthread_mutex和linux futex实现
使用者角度看bionic pthread_mutex和linux futex实现 本文所大篇幅引用的参考文章主要描述针对glibc和pthread实现:而本文的考察代码主要是android的bioni ...
- 【linux】kill ;杀死某一用户下的所有进程
[linux]kill :杀死某一用户下的所有进程 https://my.oschina.net/u/347414/blog/600854
- Linux下f命令配置
一.工具 f 的配置 使用 ========== ========== ========== ========== ========== ========== ==== 一.配置方法: 首先在lin ...
- 2.flume架构以及核心组件
flume组件主要包含三部分 source:从各个地方收集数据 channel:聚集,相当于临时数据存放的地方.因为数据来的时候,不可能来一条便写一次,那样效率太低,而是先把数据放在通道里,等通道满了 ...
- vue + vue-router + vue-resource 基于vue-cli脚手架 --->笔记
ps: 基于Vue2.0 npm的vue-cli脚手架 在vue-router中路由路径的简写代码: 点击打开项目 > build > webpack.base.conf.js 找到web ...
- MMSEG 中文分词算法 翻译
算法原文位于:http://technology.chtsai.org/mmseg/ http://www.360doc.com/content/13/0217/15/11619026_2661428 ...
- eclipse中的project 和classpath文件的具体作用
项目->右键 Properties-> java Build Path -> source: xxx/data xxx/src 体现在 .classpath文件中: .classpa ...
- 提取windows用户明文密码
前段时间mimikatz热传,主要是因为可以直接提取当前登录用户明文密码. 其实,有个更厉害的神器,无需那么多命令操作,一个命令搞定: C:\>wce -w WCE v1.3beta (Wind ...
- 16.RDD实战
第16课:RDD实战 由于RDD的不可修改的特性,导致RDD的操作与正常面向对象的操作不同,RDD的操作基本分为3大类:transformation,action,contoller 1. Tra ...
- 训练指南 UVA - 11324(双连通分量 + 缩点+ 基础DP)
layout: post title: 训练指南 UVA - 11324(双连通分量 + 缩点+ 基础DP) author: "luowentaoaa" catalog: true ...