ansible常用模块介绍
ansible查看模块用法
例子 查看shell 模块使用方法
[root@xuegod100 opt]# ansible-doc -s shell
注: -i 指定配置文件 tomcatserver自己定义的工作组 -m 指定模块
file模块
file模块包含如下选项:
force:需要在两种情况下强制创建软链接,一种是源文件不存在但之后会建立的情况下;另一种是目标软链接已存在,需要先取消之前的软链,然后创建新的软链,有两个选项:yes|no
group:定义文件/目录的属组
mode:定义文件/目录的权限
owner:定义文件/目录的属主
path:必选项,定义文件/目录的路径
recurse:递归的设置文件的属性,只对目录有效
src:要被链接的源文件的路径,只应用于state=link的情况
dest:被链接到的路径,只应用于state=link的情况
state:
directory:如果目录不存在,创建目录
file:即使文件不存在,也不会被创建
link:创建软链接
hard:创建硬链接
touch:如果文件不存在,则会创建一个新的文件,如果文件或目录已存在,则更新其最后修改时间
absent:删除目录、文件或者取消链接文件
1.创建file1文件
[root@xuegod100 opt]# ansible -i hosts tomcatserver -m file -a 'path=/tmp/file1 state=touch'
2.删除file1 文件
ansible常用语句
[root@xuegod100 opt]# ansible -i hosts tomcatserver -m file -a 'path=/tmp/file1 state=absent'
3.创建d1目录
[root@xuegod100 opt]# ansible -i hosts tomcatserver -m file -a 'path=/tmp/d1 state=directory owner=root group=root mode=777'
copy模块
copy模块包含如下选项:
backup:在覆盖之前将原文件备份,备份文件包含时间信息。有两个选项:yes|no
content:用于替代"src",可以直接设定指定文件的值
dest:必选项。要将源文件复制到的远程主机的绝对路径,如果源文件是一个目录,那么该路径也必须是个目录
directory_mode:递归的设定目录的权限,默认为系统默认权限
force:如果目标主机包含该文件,但内容不同,如果设置为yes,则强制覆盖,如果为no,则只有当目标主机的目标位置不存在该文件时,才复制。默认为yes
others:所有的file模块里的选项都可以在这里使用
src:要复制到远程主机的文件在本地的地址,可以是绝对路径,也可以是相对路径。如果路径是一个目录,它将递归复制。在这种情况下,如果路径使用"/"来结尾,则只复制目录里的内容,如果没有使用"/"来结尾,则包含目录在内的整个内容全部复制,类似于rsync。
1.拷贝yum.log文件到root下的file2
[root@xuegod100 opt]# ansible -i hosts tomcatserver -m copy -a 'src=/tmp/yum.log dest=/root/file2 mode=755 owner=root group=root'
2.cretes模块执行的时候 会做一个判断 前面的参数存在 后面的命令才不会继续执行下去
[root@xuegod100 opt]# ansible -i hosts tomcatserver -a 'creates=/root/file2 ls /home'
command模块
command模块包含如下选项:
creates:一个文件名,当该文件存在,则该命令不执行
free_form:要执行的Linux指令
chdir:在执行指令之前,先切换到该指定的目录
removes:一个文件名,当该文件不存在,则该选项不执行
executable:切换shell来执行指令,该执行路径必须是一个绝对路径
1.查看硬盘使用情况 里面可以使用一些命令
[root@xuegod100 opt]# ansible -i hosts tomcatserver -m command -a 'df -hT'
2.查看文件内容
[root@xuegod100 opt]# ansible -i hotst tomcatserver -m command -a 'cat /var/www/helloword'
chdir模块
.chdir 进入到指定的目录然后进行操作
进入到tmp 用户下面将passwd 文件压缩成 bbb.tar 文件
[root@xuegod100 opt]# ansible -i hosts tomcatserver -a 'chdir=/tmp/ tar zcf bbb.tar.gz passwd'
shell 模块
1.shell 模块使用
与command模块使用相似 但是shell支持管道
[root@xuegod100 opt]# ansible -i hosts tomcatserver -m shell -a 'ps -ef | grep httpd'
2.raw模块 与上面shell 相似
[root@xuegod100 opt]# ansible -i hosts tomcatserver -m raw -a 'ps -ef | grep httpd'
server模块
该模块包含如下选项:
arguments:给命令行提供一些选项
enabled:是否开机启动 yes|no
name:必选项,服务名称
pattern:定义一个模式,如果通过status指令来查看服务的状态时,没有响应,就会通过ps指令在进程中根据该模式进行查找,如果匹配到,则认为该服务依然在运行
runlevel:运行级别
sleep:如果执行了restarted,在则stop和start之间沉睡几秒钟
state:对当前服务执行启动,停止、重启、重新加载等操作(started,stopped,restarted,reloaded)
1.启动httpd服务 并且开机启动
[root@xuegod100 opt]# ansible -i hosts tomcatserver -m service -a 'name=httpd state=started enabled=yes'
2.关闭httpd服务
[root@xuegod100 opt]# ansible -i hosts tomcatserver -m service -a 'name=httpd state=stop'
3.重启httpd服务 并且沉睡3秒钟
[root@xuegod100 opt]# ansible -i hosts tomcatserver -m service -a 'name=httpd state=restarted sleep=3'
4.重启network 只重启eth0 网卡
[root@xuegod100 opt]# ansible -i hosts tomcatserver -m service -a 'name=network state=restarted args=eth0'
corn模块
包含如下选项:
backup:对远程主机上的原任务计划内容修改之前做备份
cron_file:如果指定该选项,则用该文件替换远程主机上的cron.d目录下的用户的任务计划
day:日(1-31,*,*/2,……)
hour:小时(0-23,*,*/2,……)
minute:分钟(0-59,*,*/2,……)
month:月(1-12,*,*/2,……)
weekday:周(0-7,*,……)
job:要执行的任务,依赖于state=present
name:该任务的描述
special_time:指定什么时候执行,参数:reboot,yearly,annually,monthly,weekly,daily,hourly
state:确认该任务计划是创建还是删除
user:以哪个用户的身份执行
1.root用户下 重启系统计划任务 每天的两点进行重启系统
[root@xuegod100 opt]# ansible -i hosts tomcatserver -m cron -a 'name="reboot system" hour=2 user=root job="/sbin/reboot"'
2.删除计划任务 使用state=sbsent
[root@xuegod100 opt]# ansible -i hosts tomcatserver -m cron -a 'name="reboot system" hour=2 user=root job="/sbin/reboot" state=absent'
3.每三分钟检查一下home下的文件
[root@xuegod100 opt]# ansible -i hosts tomcatserver -m command -a "crontab -l"
4.special_time指定什么时候执行
[root@xuegod100 opt]# ansible -i hosts tomcatserver -m command -a "crontab -l"
5.删除计划任务(name 指定计划任务名称)
[root@xuegod100 opt]# ansible -i hosts tomcatserver -m cron -a 'name="list dir" state=absent'
yum 模块
选项:
config_file:yum的配置文件
disable_gpg_check:关闭gpg_check
disablerepo:不启用某个源
enablerepo:启用某个源
list
name:要进行操作的软件包的名字,也可以传递一个url或者一个本地的rpm包的路径
state:状态(present,absent,latest)
1.安装mysql服务
[root@xuegod100 opt]# ansible -i hosts tomcatserver -m yum -a 'name=mysql state=installed'
2.卸载mysql服务
[root@xuegod100 opt]# ansible -i hosts tomcatserver -m yum -a 'name=mysql state=absent'
user模块
home:指定用户的家目录,需要与createhome配合使用
groups:指定用户的属组
uid:指定用的uid
password:指定用户的密码
name:指定用户名
createhome:是否创建家目录 yes|no
system:是否为系统用户
remove:当state=absent时,remove=yes则表示连同家目录一起删除,等价于userdel -r
state:是创建还是删除
shell:指定用户的shell环境
1.创建用户
[root@xuegod100 opt]# ansible -i hosts tomcatserver -m command -a 'useradd -s /sbin/nologine -M user1'
2.使用user模块创建模块
createhome 是否创建家目录 指定home 指定密码 指定用户 指定shell 状态创建
[root@xuegod100 opt]# ansible -i hosts tomcatserver -m user -a 'createhome=yes home=/home/user2 password=123456 name=user2 shell=/bin/bash state=present'
3.删除用户
[root@xuegod100 opt]# ansible -i hosts tomcatserver -m user -a 'remove=yes name=user2 state=absent'
synchronize模块(同步文件)
使用rsync同步文件
archive #镜像rsync存档标志,支持递归、链接、perms、times、owner、group flags和- d,选项都为yes 默认该项为开启。
owner、group、-D选项都为yes ,默认该项为开启
checksum: 跳过检测sum值,默认关闭
compress:是否开启压缩
copy_links:复制链接文件,默认为no ,注意后面还有一个links参数
delete: 删除不存在的文件,默认no
dest:目录路径
dest_port:默认目录主机上的端口 ,默认是22,走的ssh协议
dirs:传速目录不进行递归,默认为no,即进行目录递归
rsync_opts:rsync参数部分
set_remote_user:主要用于/etc/ansible/hosts中定义或默认使用的用户与rsync使用的用户不同的情况
mode: push或pull 模块,push模的话,一般用于从本机向远程主机上传文件,pull 模式用于从远程主机上取文件
1.同步文件,将、tmp下的helloword文件复制到、var、www 的目录里面 src 指定原地址 dest 目标地址
[root@xuegod100 opt]# ansible -i hosts tomcatserver -m synchronize -a 'src=/tmp/helloword dest=/var/www/'
2.查看文件内容
[root@xuegod100 opt]# ansible -i hotst tomcatserver -m command -a 'cat /var/www/helloword'
3.同步目录
同步/var/log/下面所有的日志 mode 指定模式 rsync_path 指定远程主机的sync命令 sync_opts 指定额外的rsync选项
[root@xuegod100 opt]# ansible -i hosts tomcatserver -m synchronize -a 'src=/var/log/ dest=/var/www/ mode=push rsync_path=/usr/bin/rsync rsync_opts="-avz,--exclude=.git"'
filesystem模块
设置文件的属性
file模块包含如下选项:
force:需要在两种情况下强制创建软链接,一种是源文件不存在但之后会建立的情况下;另一种是目标软链接已存在,需要先取消之前的软链,然后创建新的软链,有两个选项:yes|no
group:定义文件/目录的属组
mode:定义文件/目录的权限
owner:定义文件/目录的属主
path:必选项,定义文件/目录的路径
recurse:递归的设置文件的属性,只对目录有效
src:要被链接的源文件的路径,只应用于state=link的情况
dest:被链接到的路径,只应用于state=link的情况
state:
directory:如果目录不存在,创建目录
file:即使文件不存在,也不会被创建
link:创建软链接
hard:创建硬链接
touch:如果文件不存在,则会创建一个新的文件,如果文件或目录已存在,则更新其最后修改时间
absent:删除目录、文件或者取消链接文件
在块设备上创建文件系统
1.创建一个4M 的文件系统
[root@xuegod100 opt]# ansible -i hosts tomcatserver -a 'dd if=/dev/zero of=/disk.img bs=4k count=1024'
2.把disk.img作为loop设备从而可以进行分区格式化
[root@xuegod100 opt]# ansible -i hosts tomcatserver -m command -a 'losetup /dev/loop0 /disk.img'
3.格式化硬盘分区
-F额外的参数 对照mkfs /dev/disk.img -F 强制格式化
[root@xuegod100 opt]# ansible -i hosts tomcatserver -m filesystem -a 'dev=/disk.img fstype=ext4 opts=-F'
mount挂载模块
选项:
dump
fstype:必选项,挂载文件的类型
name:必选项,挂载点
opts:传递给mount命令的参数
passno
src:必选项,要挂载的文件
state:必选项
present:只处理fstab中的配置
absent:删除挂载点
mounted:自动创建挂载点并挂载之
umounted:卸载
1.挂载设备/dev/loop0 到aaa state=mounted 挂载并且创建挂载点
[root@xuegod100 opt]# ansible -i hosts tomcatserver -m mount -a 'fstype=ext4 name=/aaa src=/dev/loop0 state=mounted'
2.查看硬盘挂载情况
[root@xuegod100 opt]# ansible -i hosts tomcatserver -m command -a 'df -hT'
3.在挂载的设备上面创建文件测试
[root@xuegod100 opt]# ansible -i hosts tomcatserver -m file -a 'path=/aaa/test state=touch'