copy模块:
指定节点上
    命令:ansible 10.1.1.113 -m copy -a 'src=/root/a.sh dest=/tmp/'

file模块:
指定节点上/tmp/t.sh的权限为755,属主和属组为root

    命令:ansible all -m file -a "dest=/tmp/t.sh mode=755 owner=root group=root"

cron模块:
指定节点上定义一个计划任务,每隔3分钟到主控端更新一次时间

    命令:ansible all -m cron -a 'name="custom job" minute=*/3 hour=* day=* month=* weekday=* job="/usr/sbin/ntpdate 172.16.254.139"'

group模块:
    目的:在所有节点上创建一个组名为nolinux,gid为2014的组

    命令:ansible all -m group -a 'gid=2014 name=nolinux'

user模块:
指定节点上创建一个用户名为nolinux,组为nolinux的用户

    命令:ansible 10.1.1.113 -m user -a 'name=nolinux groups=nolinux state=present'

yum模块:
指定节点上安装 lrzsz 服务

    命令:ansible all -m yum -a "state=present name=httpd"

service模块:
指定节点上的 puppet 服务,并让其开机自启动
    命令:ansible 10.1.1.113 -m service -a 'name=puppet state=restarted enabled=yes'

script模块:
指定节点上执行/root/a.sh脚本(该脚本是在ansible控制节点上的)

    命令:ansible 10.1.1.113 -m script -a '/root/a.sh'

ping模块:
    目的:检查指定节点机器是否还能连通

    命令:ansible 10.1.1.113 -m ping

command模块:
指定节点上运行hostname命令

    命令:ansible 10.1.1.113 -m command -a 'hostname'

raw模块:
    目的:在10.1.1.113节点上运行hostname命令

    命令:ansible 10.1.1.113 -m raw-a 'hostname|tee'

get_url模块:
    目的:将http://10.1.1.116/favicon.ico文件下载到指定节点的/tmp目录下

    命令:ansible 10.1.1.113 -m get_url -a 'url=http://10.1.1.116/favicon.ico dest=/tmp'


synchronize模块:
指定节点的/tmp目录下
    命令:ansible 10.1.1.113 -m synchronize -a 'src=/root/a dest=/tmp/ compress=yes'
    执行效果:
delete=yes   使两边的内容一样(即以推送方为主)
compress=yes  开启压缩,默认为开启
--exclude=.Git  忽略同步.git结尾的文件

ansible 指定host file_ico

由于模块,默认都是推送push。因此,如果你在使用拉取pull功能的时候,可以参考如下来实现

mode=pull   更改推送模式为拉取模式

    目的:将10.1.1.113节点的/tmp/a目录拉取到主控节点的/root目录下

    命令:ansible 10.1.1.113 -m synchronize -a 'mode=pull src=/tmp/a dest=/root/'

    执行效果:

ansible 指定host file_ico_02

       由于模块默认启用了archive参数,该参数默认开启了recursive, links, perms, times, owner,group和-D参数。如果你将该参数设置为no,那么你将停止很多参数,比如会导致如下目的递归失败,导致无法拉取


ansible 指定host file_ico_03



null


user:Felix mail:wudonghang@wudonghang.com If you have questions or suggestions, please contact the author.