[ansible]常用内置模块
前言
ansible内置了很多模块,常用的并不多,可以通过ansible -l命令列出所有模块,使用 ansible-doc module-name 查看指定模块的帮助文档,例如:ansible-doc command
ping模块
主要作用
判断远程客户端是否在线。没有参数
示例
ansible all -m ping
command模块
主要作用
执行Linux基础命令
使用详解
- chdir:执行命令前,则不执行该步骤
- creates:当该文件存在时,则不执行该步骤
- executable:换用shell环境执行命令
- free_form:需要执行的脚本
- removes:当该文加不存在时,则不执行该步骤
- warn:若在Ansible.cfg中存在告警。如果false,则不会警告此行。
- 可以使用-a加要执行的命令直接执行,不过命令中如果带特殊字符,执行则会失败。
示例
ansible -k -i /etc/ansible/hosts all -m command -a "date"
ansible -k all -m command -a "ping -c www.baidu.com"
ansible zxserver -a "whoami"
ansible zxserver -a "chdir=/tmp/ ls"
ansible zxserver -a "creates=/tmp/testansible.txt date"
copy模块
主要作用
文件或目录复制
参数选项
- src:本地源文件或目录的路径,空文件夹不复制
- content:可替代src,用于将指定文件的内容复制到远程文件内
- dest:客户端目标目录或者文件,需要绝对路径
- backup:复制之前,先备份远程节点上的原始文件。- backup=yes可以在覆盖之前对文件自动备份
- directory_mode:用于复制文件夹,新建的文件会被复制,而老旧的不会被复制
- follow:支持link文件复制
- force:覆盖远程主机不一致的内容
- group:设定远程主机文件夹的组名
- mode:指定远程主机文件及文件夹的权限
- owner:设定远程主机文件夹的用户名
示例
ansible -k all -m copy -a 'src=/etc/passwd dest=/tmp/ mode=755 owner=root'
ansible -k all -m copy -a 'content="Hello World" dest=/tmp/test.txt mode=755 owner=root'
ansible zxserver -m copy -a "src=/etc/odbc.ini dest=/etc/odbc.ini backup=yes"
YUM模块
主要作用
软件的安装、升级、卸载
使用详解
- name:需要安装的软件名,支持软件组安装
- update_cache:安装前更新缓存
- state:软件包状态,是否安装或卸载
- installed: 安装
- removed: 卸载
 
示例
ansible all -m yum -a "name=screen state=installed"
file模块
主要作用
用于对文件的创建、删除、修改、权限、属性的维护和管理
参数选项
- path:必选项,定义文件/目录的路径
- state:
- directory:表示目录,如果目录不存在则创建目录
- link:创建软链接
- hard:创建硬链接
- touch:如果文件不存在则创建,如果存在则更新修改时间。
- absent:删除目录、文件或者取消链接文件
- mode:定义文件权限
- owner:定义属主
- group:定义属组
- recurse:递归设置文件属性,只对目录有效
- src:被链接的源文件路径,只应用于- state=link的情况
- dest:要链接到的目标路径,只应用于- state=link的情况
示例
- 示例1:创建一个不存在的目录并进行递归授权
ansible zxserver -m file -a "path=/tmp/abc123 state=directory"
ansible zxserver -m file -a "path=/tmp/abc123 owner=nobody group=nobody mode=0644 recurse=yes" 
ansible zxserver -m file -a "path=/tmp/abc1234 owner=sshd group=sshd mode=0644 state=directory"
- 示例2:创建一个文件
ansible zxserver -m file -a "path=/tmp/zhangsan.txt mode=0644"
# 或者
ansible zxserver -m file -a "path=/tmp/zhangsan.txt state=touch"
- 示例3:创建一个软链接
ansible zxserver -m file -a "src=/usr/local/freeswitch/bin/fs_bin dest=/usr/bin/fs_cli state=link"
- 示例4:删除一个文件
ansible zxserver -m file -a "path=/tmp/zhangsan.txt state=absent"
user模块
主要作用
用户管理
示例
# 新增用户
ansible grp1 -m user -a "name=zhangsan password=lisi"
# 删除用户
ansible grp1 -m user -a "name=zhangsan state=absent"
cron模块
主要作用
管理定时任务
使用详解
- day、- hour、- minute、- month、- weekday
- state:- present:创建定时任务
- absent:删除定时任务
 
- job:要执行的任务,依赖于- state=present
- special_time:特殊的时间范围。参数:
- reboot:重启时
- annually:每年
- monthly:每月
- weekly:每周
- daily:每天
- hourly:每小时
- user:指定用户身份
示例
- 示例1:系统重启时执行/data/bootservice.sh脚本
ansible zxserver -m cron -a 'name="jobForReboot" special_time=reboot job="/data/bootservice.sh"'
- 示例2:每周六的1:20分执行yum -y update操作
ansible zxserver -m cron -a 'name="yumUpdate" weekday="6" minute="20" hourly="1" user="root" job="yum -y update"'
synchronize模块
主要作用
同步目录、文件,基于rsync
使用详解
- compress:开启压缩
- archive:是否采用归档模式同步,保证源和目标文件属性一致
- checksum:是否校验
- dirs:以非递归的方式传输目录
- links:同步链接文件
- recursive:是否递归yes/no
- rsync_opts:使用rsync的参数
- delete:删除源中没有而目标存在的文件
- src:源目录及文件
- dest:目标目录及文件
- set_remote_user:设置远程用户名
- dest_port:目标接受的端口
- mode:同步的模式。默认为push,还有pull选项
- --exclude=.log:忽略同步.log结尾的文件
示例
foo
shell模块
主要作用
远程客户端执行各种shell命令或者运行脚本。其用法和command模块一样,不过shell模块执行命令的时候使用的是/bin/sh,所以shell模块可以执行任何命令
示例
ansible zxserver -m shell -a "touch /tmp/testansible.txt;ls -l /tmp/testansible.txt"
service模块
主要作用
用于远程客户端各种服务管理,包括启动、停止、重启、重新加载
使用详解
- enable:是否开机自启yes/no
- name:必选项,服务名称
- parttern:定义一个模式。如果status没有响应,则通过ps在进程中查找,匹配到就认为该服务依然在运行。
- state:对服务执行启动、停止、重启、重加载等操作(started、stopped、restarted、reloaded)
- sleep:如果指定了重启,则在stop和start之间沉睡几秒钟。
示例
ansible zxserver -m service -a "name=httpd state=started enable=yes"
get_url模块
主要作用
从web下载文件,类似wget
示例
- 示例1:下载文件到远程主机的/tmp目录下。
ansible zxserver -m get_url -a "url=http://192.168.10.101/download/test.txt dest=/tmp"
本文来自博客园,作者:花酒锄作田,转载请注明原文链接:https://www.cnblogs.com/XY-Heruo/p/16610252.html
 
                    
                     
                    
                 
                    
                
 
                
            
         
         浙公网安备 33010602011771号
浙公网安备 33010602011771号