模块介绍:

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. 关于兼容性——百分比对于IE浏览器的影响

    之前为了适应页面放大或者缩小,很多宽度都是写的百分比,后来发现有产生换行现象 总结一下: 如果页面是满占位的,我想百分比在谷歌.火狐都应该没什么问题,在IE 就会产生换行  因为IE浏览器存在一个四舍 ...

  2. JavaWeb 学习007-4个页面,5条sql语句(添加、查看、修改、删除)2016-12-2

    需要复习的知识: 关联查询 =================================================================================班级模块学 ...

  3. [刘阳Java]_MyBatis_动态SQL标签用法_第7讲

    1.MyBatis的动态SQL是基于OGNL表达式的,它可以帮助我们方便的在SQL语句中实现某些逻辑. 2.MyBatis中用于实现动态SQL的元素主要有 if choose(when,otherwi ...

  4. Java(异常处理)动手动脑

    1>请阅读并运行AboutException.java示例,然后通过后面的几页PPT了解Java中实现异常处理的基础知识. import javax.swing.*; class AboutEx ...

  5. Jquery动态在td中添加checkbox

    如图:想要在这个id为headId的<td>中,用jquery动态添加checkbox 代码如下 : data是我用ajax 从后台获取的数据,里面含有若干个user类,我想把所有的人名字 ...

  6. liunx打开指定端口

    1.切换为root用户 2.切换路径至:/etc/sysconfig 3.vi编辑添加一行: -A INPUT -m state --state NEW -m tcp -p tcp --dport 3 ...

  7. (转)selenuim-webdriver注解之@FindBy、@FindBys、@FindAll的区别

    selenium-webdriver中获取页面元素的方式有很多,使用注解获取页面元素是其中一种途径, 方式有3种:@FindBy.@FindBys.@FindAll.下文对3中类型的区别和使用场景进行 ...

  8. Java GC工作原理以及Minor GC、Major GC、Full GC简单总结

    名词解释: GC:垃圾收集器 Minor GC:新生代GC,指发生在新生代的垃圾收集动作,所有的Minor GC都会触发全世界的暂停(stop-the-world),停止应用程序的线程,不过这个过程非 ...

  9. cassandra-replication_factor 和 consistency level

    参考 replication_factor 决定了数据会被写到多少个节点.为2表示要写到两个节点. consistency level决定客户端要等待多少个节点被写成功.为1表示只要第一个节点被写成功 ...

  10. [09]APUE:进程关系

    [a] getpgid / setpgid #include <unistd.h> pid_t getpgid(pid_t pid) //成功返回进程组 ID,出错返回 -1 int se ...