[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/noname
:必选项,服务名称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