模块介绍:

copy模块

使用copy模块,可以将本地文件一键复制到远程服务器;
-a后跟上参数,参数中指定本地文件和远端路径;

[root@ZABBIX ~]# ansible glq -m copy -a "src=~/fping-3.8.tar.gz dest=~/"
10.69.69.121 | success >> {
"changed": true,
"dest": "/root/fping-3.8.tar.gz",
"gid": 0,
"group": "root",
"md5sum": "1e36467cc96a4ca959925ac167ea19af",
"mode": "0644",
"owner": "root",
"size": 147448,
"src": "/root/.ansible/tmp/ansible-tmp-1482214561.7-273384209097162/source",
"state": "file",
"uid": 0
}
10.107.2.56 | success >> {
"changed": true,
"dest": "/root/fping-3.8.tar.gz",
"gid": 0,
"group": "root",
"md5sum": "1e36467cc96a4ca959925ac167ea19af",
"mode": "0644",
"owner": "root",
"size": 147448,
"src": "/root/.ansible/tmp/ansible-tmp-1482214563.87-235871924804761/source",
"state": "file",
"uid": 0
}
10.107.2.44 | success >> {
"changed": true,
"dest": "/root/fping-3.8.tar.gz",
"gid": 0,
"group": "root",
"md5sum": "1e36467cc96a4ca959925ac167ea19af",
"mode": "0644",
"owner": "root",
"size": 147448,
"src": "/root/.ansible/tmp/ansible-tmp-1482214563.94-108812671292926/source",
"state": "file",
"uid": 0
} 10.107.2.58 | success >> {
"changed": true,
"dest": "/root/fping-3.8.tar.gz",
"gid": 0,
"group": "root",
"md5sum": "1e36467cc96a4ca959925ac167ea19af",
"mode": "0644",
"owner": "root",
"size": 147448,
"src": "/root/.ansible/tmp/ansible-tmp-1482214563.92-185412226226660/source",
"state": "file",
"uid": 0
}
验证是否copy成功:
[root@ZABBIX ~]# ansible glq -m command -a 'ls -al /root/fping-3.8.tar.gz'
10.107.2.56 | success | rc=0 >>
-rw-r--r-- 1 root root 147448 Dec 20 14:15 /root/fping-3.8.tar.gz
10.107.2.44 | success | rc=0 >>
-rw-r--r-- 1 root root 147448 Dec 20 14:15 /root/fping-3.8.tar.gz
10.107.2.58 | success | rc=0 >>
-rw-r--r-- 1 root root 147448 Dec 20 14:15 /root/fping-3.8.tar.gz
10.69.69.121 | success | rc=0 >>
-rw-r--r-- 1 root root 147448 Dec 20 07:15 /root/fping-3.8.tar.gz
command模块:

command模块为ansible默认模块,不指定-m参数时,使用的就是command模块;
comand模块比较简单,常见的命令都可以使用,但其命令的执行不是通过shell执行的,所以,像这些 "<", ">", "|", and "&"操作都不可以,当然,也就不支持管道;

缺点是:不支持管道,就没法批量执行命令;

实例:

[root@ZABBIX ~]# ansible glq -m command -a 'pwd'
10.69.69.121 | success | rc=0 >>
/root
10.107.2.56 | success | rc=0 >>
/root
10.107.2.44 | success | rc=0 >>
/root
10.107.2.58 | success | rc=0 >>
/root
shell模块

使用shell模块,在远程命令通过/bin/sh来执行;所以,我们在终端输入的各种命令方式,都可以使用;
但是我们自己定义在.bashrc/.bash_profile中的环境变量shell模块由于没有加载,所以无法识别;如果需要使用自定义的环境变量,就需要在最开始,执行加载自定义脚本的语句;

对shell模块的使用可以分成两块:
1) 如果待执行的语句少,可以直接写在一句话中:

[root@ZABBIX ~]# ansible glq -a "ifconfig eth0 | grep -e "^10.";pwd" -m shell
10.69.69.121 | success | rc=0 >>
/root 10.107.2.44 | success | rc=0 >>
/rooteth0: error fetching interface information: Device not found 10.107.2.56 | success | rc=0 >>
/root 10.107.2.58 | success | rc=0 >>
/rooteth0: error fetching interface information: Device not found

2) 如果在远程待执行的语句比较多,可写成一个脚本,通过copy模块传到远端,然后再执行;但这样就又涉及到两次ansible调用;对于这种需求,ansible已经为我们考虑到了,script模块就是干这事的;

scripts模块

使用scripts模块可以在本地写一个脚本,在远程服务器上执行:

脚本如下:

[root@ZABBIX ~]# vim test.sh
#!/bin/bash
declare -i SUM=0
for ((i=1;i<=100;i+=1))
do
let SUM+=$i
done
echo $SUM

执行脚本:

[root@ZABBIX ~]# ansible glq -m script -a "/root/test.sh"
10.69.69.121 | success >> {
"changed": true,
"rc": 0,
"stderr": "",
"stdout": "5050\r\n"
}
10.107.2.44 | success >> {
"changed": true,
"rc": 0,
"stderr": "",
"stdout": "5050\r\n"
}
10.107.2.56 | success >> {
"changed": true,
"rc": 0,
"stderr": "",
"stdout": "5050\r\n"
}
10.107.2.58 | success >> {
"changed": true,
"rc": 0,
"stderr": "",
"stdout": "5050\r\n"
}

ansible 自动化(2)的更多相关文章

  1. Ansible自动化运维工具-上

    [Ansible特点] 1)Ansible与saltstack均是基于Python语言开发的 2)安装使用简单,基于不同插件和模块实现各种软件,平台,版本的管理以及支持虚拟容器多层级的部署 3)不需要 ...

  2. CentOS7系统 ansible自动化部署多台服务器部署

    CentOS7系统 ansible自动化部署多台服务器部署   Ansible工作机制  从图中可以看出ansible分为以下几个部份: 1> Control Node:控制机器2> In ...

  3. ansible 自动化运维

    Ansible 自动化运维 ansible安装epel #yum list all *ansible*#yum install *ansible*#yum info ansible#rpm -ql a ...

  4. ansible自动化工具安装和简单使用

    ansible自动化工具安装和简单使用 1.安装 ansible依赖于Python 2.6或更高的版本.paramiko.PyYAML及Jinja2. 2.1 编译安装 解决依赖关系 # yum -y ...

  5. Jenkins +svn +maven +tomcat+ ansible 自动化批量部署

    Jenkins +svn +maven +tomcat+ ansible 自动化批量部署 一.部署svn yum install subversion 先创建目录 mkdir /home/svn 创建 ...

  6. [k8s]kubespray(ansible)自动化安装k8s集群

    kubespray(ansible)自动化安装k8s集群 https://github.com/kubernetes-incubator/kubespray https://kubernetes.io ...

  7. Jenkins+Gitlab+Ansible自动化部署(五)

    Freestyle Job实现静态网站部署交付(接Jenkins+Gitlab+Ansible自动化部署(四)https://www.cnblogs.com/zd520pyx1314/p/102445 ...

  8. Jenkins+Gitlab+Ansible自动化部署(六)

    Pipeline Job实现Nginix+MySQL+PHP+Wordpress实现自动化部署交付(Jenkins+Gitlab+Ansible自动化部署(五)https://www.cnblogs. ...

  9. Jenkins+Gitlab+Ansible自动化部署(三)

    接Jenkins+Gitlab+Ansible自动化部署(一)https://www.cnblogs.com/zd520pyx1314/p/10210727.html 和(二)https://www. ...

  10. Jenkins+Gitlab+Ansible自动化部署(一)

    首先准备实验环境 虚拟机 主机名 IP地址 服务 系统版本 内核版本 Vmware Workstation 14 gitlab.example.com 192.168.244.130 gitlab  ...

随机推荐

  1. RedHat 6.7 Enterprise x64环境下使用RHCS部署Oracle 11g R2双机双实例HA

     环境 软硬件环境 硬件环境: 浪潮英信服务器NF570M3两台,华为OceanStor 18500存储一台,以太网交换机两台,光纤交换机两台. 软件环境: 操作系统:Redhat Enterpris ...

  2. hdu 2586 How far away ?(离线求最近公共祖先)

    #include<cstdio> #include<cstring> #include<algorithm> #include<iostream> #i ...

  3. WCF use ProtoBuf

    ProtoBuf, 比起xml和json, 传输的数据里面没有自描述标签, 而且是基于二进制的, 所以有着超高的传输效率, 据牛人张善友的描述, 可以替代WCF的自带的编码方案, 效率有极大的提升. ...

  4. css3的背景颜色渐变@线性渐变

    背景颜色渐变之线性渐变 语法形式: firefox浏览器 background:-moz-linear-gradient(position/deg,startColor,endColor); oper ...

  5. 我眼中的项目leader

    个人觉得项目leader应该具备一下基础: 1.技术能力 2.领导能力 3.过滤产品不合理需求能力 4.项目周期把控能力

  6. PHP正则表达式 /i, /is, /s, /isU等

    PHP正则表达式 /i, /is, /s, /isU等 都是些什么东西呢? i 匹配大小写 s 模式中的圆点元字符(.)匹配所有的字符,包括换行符 x 模式中的空白字符除了被转义的或在字符类中的以外完 ...

  7. ASP.NET 页生命周期

    ASP.NET 页运行时,此页将经历一个生命周期,在生命周期中将执行一系列处理步骤.这些步骤包括初始化.实例化控件.还原和维护状态.运行事件处理程序代码以及进行 呈现.了解页生命周期非常重要,因为这样 ...

  8. SQL Server 常用函数

    1.DATEADD 在向指定日期加上一段时间的基础上,返回新的 datetime 值. 语法 DATEADD ( datepart , number, date ) 参数 datepart 是规定应向 ...

  9. 【转】Crontab定时任务配置

    原文出处:http://www.cnblogs.com/kerrycode/p/3238346.html CRONTAB概念/介绍 crontab命令用于设置周期性被执行的指令.该命令从标准输入设备读 ...

  10. MongoDB基本管理命令

    MongoDB是一个NoSQL数据库系统:一个数据库可以包含多个集合(Collection),每个集合对应于关系数据库中的表:而每个集合中 可以存储一组由列标识的记录,列是可以自由定义的,非常灵活,由 ...