ansible查看帮助方法

ansible-doc copy:查询指定某个模块参数用法信息
ansible-doc -l:查看所有模块说明信息
官网查询帮助:https://docs.ansible.com/
注:参数上带required表示这个参数必须要有 调试,打印出所有任务:ansible-playbook 剧本名 --list-tasks
从指定任务执行:ansible-playbook 剧本名 --start-at-task=mkdir

1、command(命令模块)----默认模块,可以省略
[root@m01 ~]# ansible oldboy -m command -a 'hostname'
172.16.1.31 | CHANGED | rc=0 >>
nfs01
172.16.1.7 | CHANGED | rc=0 >>
web01
172.16.1.41 | CHANGED | rc=0 >>
backup
2、shell(命令模块):支持特殊符号、支持脚本
\\\批量更新backup、web01、nfs01三台主机的时间
[root@m01 ~]# ansible all -m shell -a 'ntpdate ntp1.aliyun.com'
172.16.1.41 | CHANGED | rc=0 >>
28 May 20:29:20 ntpdate[10115]: step time server 120.25.115.20 offset 2.786290 sec
172.16.1.31 | CHANGED | rc=0 >>
28 May 20:29:20 ntpdate[9550]: step time server 120.25.115.20 offset 2.787557 sec
172.16.1.7 | CHANGED | rc=0 >>
28 May 20:29:21 ntpdate[9685]: step time server 120.25.115.20 offset 2.787166 sec
[root@m01 ~]# 

\\\检查backup、web01、nfs01三台主机的时间
[root@m01 ~]# ansible all -m shell -a 'date'
172.16.1.31 | CHANGED | rc=0 >>
Tue May 28 20:30:38 CST 2019
172.16.1.7 | CHANGED | rc=0 >>
Tue May 28 20:30:38 CST 2019
172.16.1.41 | CHANGED | rc=0 >>
Tue May 28 20:30:38 CST 2019
[root@m01 ~]#
3、copy(复制模块)

参数:
 src:源,文件从哪里来
 dest:目标,复制到远程哪里去
 owner:所有者
 group:用户组
 mode:权限
 backup:是否备份,对远端已有的数据
 content:向被批量推送的文件中添加内容,与src冲突,只能二选一

\\将管理机/etc/hostname推送到backup、web01、nfs01三台主机的/tmp/下
[root@m01 ~]# ansible all -m copy -a 'src=/etc/hostname dest=/tmp/hostname'

\\检查是否成功
[root@m01 ~]# ansible all -m shell -a 'cat /tmp/hostname'
172.16.1.41 | CHANGED | rc=0 >>
m01
172.16.1.7 | CHANGED | rc=0 >>
m01
172.16.1.31 | CHANGED | rc=0 >>
m01
[root@m01 ~]#
4、scripts(脚本模块):先把脚本传输到服务器,然后执行
[root@m01 ~]# #ansible all  -m script  -a "/server/scripts/yum.sh"
[root@m01 ~]# ansible all -a 'rpm -qa ipvsadm'
 [WARNING]: Consider using the yum, dnf or zypper module rather than running 'rpm'.  If you need to use command because
yum, dnf or zypper is insufficient you can add 'warn: false' to this command task or set 'command_warnings=False' in
ansible.cfg to get rid of this message. \\就是告诉你安装命令yum也可以支持

172.16.1.41 | CHANGED | rc=0 >>
ipvsadm-1.27-7.el7.x86_64

172.16.1.7 | CHANGED | rc=0 >>
ipvsadm-1.27-7.el7.x86_64
5、yum(软件安装模块)

参数
 name:指定要安装的软件包名称
 state:指定使用yum的方法
   present:安装
   absent:关闭或删除
   latest:更新

\\\批量更新backup、web01、nfs01这三台机器的tree命令
[root@m01 ~]# ansible all -m yum -a "name=tree state=latest"
6、file(文件配置模块):相当于touch、mkdir、ln、rm,不支持通配符

参数:
 path:指定路径或文件名**
 state:指定文件创建的类型
   directory:在远端创建目录
   touch:在远端创建文件**
   link:link或hard表示创建链接文件
   absent:删除文件或目录
 mode:设置文件或目录权限
 owner:设置文件或目录属主信息
 group:设置文件或目录属组信息

\\\批量创建目录
[root@m01 ~]# ansible all -m file  -a 'path=/tmp/a   state=directory mode=555 owner=root group=root '
\\\批量创建文件
[root@m01 ~]# ansible all -m file -a "path=/data/a/b/c/oldboy.txt state=touch"
7、serivce(服务模块):关闭、开启、重启

参数
name:指定要启动服务的名称
state:指定服务启动状态
  started:启动服务
  stopped:停止服务
  restarted:重启服务
  reloaded:重载服务
enabled:开机自启(yes或no)

ansible all -m service -a 'name=crond state=started enabled=yes'
8、group(组模块)

name:指定创建的组名
gid:指定组的gid
state
  absent:移除远端主机的组
  present:创建远端主机的组(默认)

\\\创建oldgirl的用户组
[root@m01 ~]# ansible all -m group -a 'name=oldgirl gid=888'
9、user(用户模块)

参数
 name
 uid
 group
 shell:指定命令解释器
 create_home:是否创建家目录

\\\创建用户oldgirl指定uid和gid 888,不创建家目录也不允许登陆
ansible all -m user -a 'name=oldgirl uid=888 group=oldgirl shell=/sbin/nologin create_home=no '

\\\检查
[root@m01 ~]# ansible all -m shell -a 'grep "oldgirl" /etc/passwd'
172.16.1.41 | CHANGED | rc=0 >>
oldgirl:x:888:888::/home/oldgirl:/sbin/nologin
172.16.1.31 | CHANGED | rc=0 >>
oldgirl:x:888:888::/home/oldgirl:/sbin/nologin
172.16.1.7 | CHANGED | rc=0 >>
oldgirl:x:888:888::/home/oldgirl:/sbin/nologin
[root@m01 ~]#
10、cron(定时任务模块)

参数:
name:指定定时任务的注释
minute:分钟(0-59,/2)
month:月份(1-12,/2)
job:指定定时任务的命令或脚本
hour:小时(0-23,/2)
day:天(0-31,/2)
weekday:分钟(0-6,*)
state:
  present:添加定时任务
  absent:删除定时任务

#在backup和nfs01机器中添加一个定时任务每5分钟同步系统时间

\\正常定时任务格式:
*/5 * * * * /sbin/ntpdate ntp1.aliyun.com>/dev/null 2>&1

\\ansible定时任务模块格式:
ansible oldboy -m cron -a 'name="sync time" minute="*/5" job="/usr/sbin/ntpdate ntp1.aliyun.com >/dev/null  2>&1" state=present'
11、mount(挂载模块)

注:测试这个挂载模块之前,一定要先在nfs01上配置好nfs

参数:
 fstype:文件系统类型
 src:source 源
 path:挂载点
 opts:挂载参数,defaults(默认)
 state:状态(临时、永久)
   present:开机挂载,仅将挂载设备写入/etc/fstab
   mounted:挂载设备,并将配置写入/etc/fstab
   unmounted:卸载设备,不会清除/etc/fstab写入的配置
   absent:卸载设备,会清除/etc/fstab写入的配置

#将nfs01机器上的共享目录/nfs挂载到web01机器上的/upload

\\正常mount挂载命令:
mount -t nfs 172.16.1.31:/data /web01

\\ansible中mount模块命令
ansible 172.16.1.7 -m mount -a 'src=172.16.1.31:/nfs path=/upload fstype=nfs state=mounted'
12、archive(打包压缩模块)

参数:
 path:要打包的文件或目录(绝对路径)
 dest:打包到哪里

- name: tar /etc
      archive:
        path: /etc
        dest: "{{ dirs }}/{{ ipaddr.stdout }}/etc-{{ time.stdout }}.tar.gz"

后续遇到在补充……