Fabric 简单使用

最近公司组织压测系统,要在多台机子上部署代码,可是机子上的代码与生产环境不一样,需要修改代码,还有有问题的地方要修改,然后再发代码。这边一共有7台服务务器,重新发代码,要一台一台 ssh 上去,输入用户名和密码,然后切换目录,再 git pullpm2 restart ***, (是的我司使用 node),一两次还可以手动,随着修改的次数多了,这个事情变的麻烦的事情,发一次代码要开 7个ssh,手指都打断了。

终于受不了之后,决定找工具自动化解决这个问题。(我们线上是可以自动化的部署的,只是测试环境没有运维来支持,只能自己弄)。

node 做运维这块工作不是擅常的, 找了一会发现一个 python 的运维工具 fabric 。这下这个工作就简单了,学下 python 代码 10 分钟,看了fabric文档 30 分种,折腾环境 30 分钟, 到写出工具加调试 50 分钟,二个小时,把能用的工具做出来,不得不说,python 是非常强大的。

fabric 介绍

fabric 是一个使用 ssh 执行命令的工具,它是一款运维工具。用我的理场就是使用ssh自动化执行你的命令的工具。使用环境env, 你就能指定目标(user, password, hosts), 然后运行 run 命令。理解这个些概念,就可以做一款非常基础的工具了。

from fabric.api import *

env.user = 'root'
env.password = '123456'
env.hosts = [
'192.168.104.37',
'192.168.104.50',
'192.168.104.65',
'192.168.104.73',
'192.168.104.77',
'192.168.104.78',
'192.168.104.82',
] pc_dir = '/home/test/test-node'
h5_dir = '/home/test/testwap-node' pc_app = 'testnode'
h5_app = testwap-node' src_dir = h5_dir if env.has_key('p') else pc_dir
app = h5_app if env.has_key('p') else pc_app @task
@parallel
def name():
run('hostname') @task
@parallel
def pull():
with cd(src_dir):
run('git pull') @task
@parallel
def install():
with cd(src_dir):
run('npm i') @task
@parallel
def deploy():
with cd(src_dir):
run('git pull')
run('pm2 restart %s' % (app)) @task
@parallel
def branch():
with cd(src_dir):
run('git branch') @task
@parallel
def fetch():
with cd(src_dir):
run('git fetch -p') @task
@parallel
def checkout():
with cd(src_dir):
run('git checkout feature/qps') @task
@parallel
def start():
with cd(src_dir):
run('pm2 start process.json') @task
@parallel
def restart():
with cd(src_dir):
run('pm2 restart %s' % (app)) @task
@parallel
def list():
with cd(src_dir):
run('pm2 list') @task
@parallel
def log():
with cd(src_dir):
run('pm2 logs %s' % (app)) @task
@parallel
def env():
run('cat /etc/profile | grep TEST')

注意:

  1. fabric 可以在 windows 上使用,只是不能使用 @parallel
  2. fabric 要求 python 2.7 以上, 但是不能在 python 3.X 上使用。
  3. 我在 windows 上使用,用的 conda 安装配置多个python 环境。

项目代码: github

相关链接

fabric中文版

Fabric 简单使用的更多相关文章

  1. fabric简单案例

    1  执行一个简单的task任务,显示两台机器的/home/guol/目录下的文件 from fabric.api import * env.users='root' env.port=22 env. ...

  2. fabric 安装及简单使用 (centos6)

    fabric 是一个python的库,fabric可以通过ssh批量管理服务器. 第一步安装依赖包 安装epel源 1 wget -O /etc/yum.repos.d/epel.repo http: ...

  3. 系统批量运维管理器Fabric详解

    系统批量运维管理器Fabric详解 Fabrici 是基于python现实的SSH命令行工具,简化了SSH的应用程序部署及系统管理任务,它提供了系统基础的操作组件,可以实现本地或远程shell命令,包 ...

  4. fabric 安装

    fabric 是一个python的库,fabric可以通过ssh批量管理服务器. 第一步安装依赖包 安装fabric依赖及pip yum install -y python-pip gcc pytho ...

  5. 拥抱Service Fabric —— 目录

    理解分布式 经典分布式系统设计 云时代分布式系统演进 Service Fabric基础概念 Node, Application, Service, Partition/Replicas Partiti ...

  6. 批量执行命令:fabric

    Fabric 可以通过 SSH 在多台客户端主机上批量执行任务,是基于 paramiko 封装开发的,paramiko 更底层一些,安装方法如下: [root@localhost ~]$ yum in ...

  7. python 各种开源库

    测试开发 来源:https://www.jianshu.com/p/ea6f7fb69501 Web UI测试自动化 splinter - web UI测试工具,基于selnium封装. 链接 sel ...

  8. Python测试 ——开发工具库

    Web UI测试自动化 splinter - web UI测试工具,基于selnium封装. selenium - web UI自动化测试. mechanize- Python中有状态的程序化Web浏 ...

  9. 第10章:深入浅出Ansible

    1.Ansible介绍 1).Ansible的优点 Ansible是一个简单的自动化引擎,可完成配置管理.引用部署.服务编排以及其他各种IT需求 Ansible是Python开发并实现的开源软件,其依 ...

随机推荐

  1. configure: error: APR not found. Please read the documentation

    本以为Apache的编译安装很简单,其实不然: 以前的环境下编译报错很少 ,但这次不行了 提示configure: error: APR not found. Please read the docu ...

  2. 不能访问tomcat中的项目

    tomcat在eclipse里面能正常启动,而在浏览器中访问http://localhost:8080/不能访问,且报404错误.同时其他项目页面也不能访问. 关闭eclipse里面的tomcat,在 ...

  3. win10 下安装linux子系统

    一.开发人员选项 打开控制面板->程序与功能->启用或关闭windows功能 勾选    [适用于linux的windows子系统]    选项 打开win10设置 找到更新与安全 启动开 ...

  4. TX1 ssh配置

    执行: sudo apt-get install openssh-server 验证: sudo ps -e |grep ssh 回车-->有sshd,说明ssh服务已经启,如果没有则输入命令s ...

  5. PID736(rqnoj)

    题目描述 n个小伙伴(编号从 0 到 n-1)围坐一圈玩游戏.按照顺时针方向给 n个位置编号,从 0 到 n-1.最初,第 0 号小伙伴在第0号位置,第1号小伙伴在第1号位置,依此类推. 游戏规则如下 ...

  6. 计时器 vb

    十分钟 我们寒假就是这么长!! vb 执行cmd   :              shell "cmd /c DOS命令" vb 取系统日期: Print Date; " ...

  7. Product it again

    题意:求解 $$\prod_{1 \leq i \leq n} \prod_{1 \leq j \leq m} {(i,j)}$$ 解法: 满脑子的反演 考虑对于第一个质数 $p$ 的贡献为 $p^{ ...

  8. java web 工程找不到tomcat类 java.lang.ClassNotFoundException: com.mysql.jdbc.Driver

    ava.lang.ClassNotFoundException: com.mysql.jdbc.Driverat org.apache.catalina.loader.WebappClassLoade ...

  9. PYTHON3中 类的继承

    继承 1:什么是继承 继承是一种创建新类的方式,在python中,新建的类可以继承一个或多个父类,也就是说在python中支持一个儿子继承多个爹. 新建的类成为子类或者派生类. 父类又可以成为基类或者 ...

  10. Java简单的数组用法尝试,和C语言很不一样

    public class Main { static int ARRY_LONGTH=100; static int[] getRandomArr(int n){ int[] randomArr; r ...