一、ansible运行模块的两种方式
Ad-Hoc方式 ##利用ansible命令直接完成管理,主要用于临时命令使用场景

playbook方式 ##ansible脚本,主要用于大型项目场景,需要前期的规划,相当于shell当中的脚本
 

二、如何查看模块帮助
ansible-doc ##显示模块帮助的指令
命令格式
 ansible-doc [参数] [模块…]
#常用参数
 -l ##列出可用模块
 -s ##显示指定模块的playbook片段
 
 
三、ansible命令的常用执行参数
命令格式:
 ansible 清单 -m 模块 -a 模块参数
常用参数
| –version | 显示版本 | 
|---|---|
| -m module | 指定模块,默认为command模块 | 
| -v | 详细过程 -vv -vvv更详细过程 | 
| –list | 显示主机列表,也可以用–list-hosts | 
| -k | 提示输入ssh连接密码,默认key认证 | 
| -C | 预执行检测 | 
| -T | 执行命令的超时时间,默认10s | 
| -u | 指定远程执行的用户 | 
| -b | 执行sudo切换身份操作 | 
| -become-user=USERNAME | 指定sudo的用户 | 
| -K | 提示输入sudo密码 | 
ansible的颜色的代表
| 绿色 | 执行成功但为对远程主机做任何改变 | 
|---|---|
| 黄色 | 执行成功并对远程主机做改变 | 
| 红色 | 执行失败 | 
四、command模块的使用方法
command
 #功能: 在远程主机执行命令,此模块为默认模块
 
 #常用参数
| chdir | 执行命令前先进入到指定目录 | 
|---|---|
| cmd | 运行命令指定 | 
| creates | 如果文件存在将不运行 | 
| removes | 如果文件存在在将运行 | 
| free_form | 在远程主机中执行的命令,此参数不需要加 | 

五、shell模块的使用方法
#功能:
 #和command功能类似
#常用参数
| chdir | 执行命令前先进入到指定目录 | 
|---|---|
| cmd | 运行命令指定 | 
| creates | 如果文件存在将不运行 | 
| removes | 如果文件存在在将运行 | 
| free_form | 在远程主机中执行的命令,此参数不需要加 | 
| executable | 指定执行环境,默认为sh | 

 
六、scrip模块的使用方法
功能:
 在ansible主机中写好的脚本在受控主机中执行
 编写一个脚本
vim clean.sh
 
 ansible all -m script -a “/mnt/westos.sh”
 远程执行脚本
七、copy模块的使用
#功能
 从ansible主机复制文件到受控主机,或者指定建立文件
#常用参数
| src | 源文件 | 
|---|---|
| dest | 目的地文件 | 
| owner | 指定目的地文件所有人 | 
| group | 指定目的地文件所有组 | 
| mode | 指定目的地文件权限 | 
| backup=yes | 当受控主机中存在文件时备份原文件 | 
| content 指定文本内容直接在受控主机中生成文件 | 

八、fetch模块的使用方法
#功能
 从受控主机把文件复制到ansible主机,但不支持目录
#常用参数
| src | 受控主机的源文件 | 
|---|---|
| dest | 本机目录 | 
| flat | 基本名称功能 | 
九、file模块的使用方法
#功能
 设置文件的属性
#常用参数#
| path | 指定文件名称 | 
|---|---|
| state | 指定操作状态 | 
| mode | 设定权限 | 
| owner | 设定文件用户 | 
| group | 设定文件组 | 
| src | 源文件 | 
| dest | 目标文件 | 
| recurse=yes | 递归更改 | 
state ##指定操作状态
 ##touch 建立
 ##absent 删除
 ##directory 递归
 ##link 建立链接
十、.archive模块
功能:压缩
#常用参数
| path | 打包目录名称 | 
|---|---|
| dest | 声称打包文件名称 | 
| format | 打包格式 | 
| owner | 指定文件所属人 | 
| mode | 指定文件权限 | 
ansible all -m archive -a ‘path=/etc dest=/opt/etc.tar.gz format=gz owner=lee mode=700’ -k
十一、hostname模块
#作用
 管理主机名称
常用参数
 name 指定主机名称


十二、cron模块
#作用
 计划任务,定时任务设定
#常用参数
| minute | 分钟 | 
|---|---|
| hour | 小时 | 
| day | 天 | 
| month | 月 | 
| weekday | 周 | 
| name | 任务名称 | 
| job | 任务脚本或命令 | 
| disabled | yes 禁用计划任务,no 启动计划任务 | 
| state | absent 删除计划任务 | 

十三、软件仓库配置模块
##yum_repository##
 #作用
 配置系统软件仓库源文件
#常用参数
| name | 指定仓库名称 | 
|---|---|
| baseurl | 指定源路径 | 
| description | 指定仓库描述 | 
| file | 指定仓库文件名称 | 
| enabled | 仓库是否启用 | 
| gpgcheck | 仓库是否检测gpgkey | 
| state | 默认值present 建立,absent 为删除 | 

十四、利用dnf模块管理软件
作用
 管理系统中的dnf仓库及管理软件
| name | 指定包 | 
|---|---|
| state | 指定动作,present 安装,latest 更新,absent 删除 | 
| list | 列出指定信息 | 
| disable_gpg_check | 禁用gpgkey检测 | 
| enablerepo | 指定安装包来源 | 
| disablerepo | 禁用安装包来源 | 
十五、service服务管理模块
作用
 管理系统服务状态
#常用参数
| name | 指定服务名称 | 
|---|---|
| state | 指定对服务的动作,started启动,stoped关闭,restarted重启,reloaded重新加载 | 
| enabled | 设定服务开机是否启动,yes开启启动,no开机不启动 | 

十六、firewalld火枪控制模块
#常用参数
| zone | 火墙的域 | 
|---|---|
| service | 服务名称 | 
| permanent | 永久生效 | 
| state= | enabled 允许,disabled 拒绝,immediate 立即生效 | 

十八、利用group模块管理组
作用
 group 模块可以帮助我们管理远程主机上的组
#常用参数
| name | 用于指定要操作的组名称。 | 
|---|---|
| state | 用于指定组的状态=present 建立,absent 删除 | 
| gid | 用于指定组的gid。 | 

十九、文件关键行替换
lineinfile:替换一整行文本
path :指定要操作的文件。
line :指定文本内容。 “|+” 表示格式化输入
regexp:使用正则表达式匹配对应的行当替换文本时。
 如果有多行文本都能被匹配。
 则只有最后面被匹配到的那行文本才会被替换。
 当删除文本时,如果有多行文本都能被匹配。
 这么这些行都会被删除。
state :当想要删除对应的文本时需要将state参数的值设置为absent
 state的默认值为present。
backrefs:当内容无匹配规则时不对文件做任何更改,默认值为no
 向后引用regexp变量信息
insertafter :借助insertafter参数可以将文本插入到“指定的行”之后
 insertafter参数的值可以设置为EOF或者正则表达式
insertbefore:借助insertbefore参数可以将文本插入到“指定的行”之前
 insertbefore参数的值可以设置为BOF或者正则表达式
backup:是否在修改文件之前对文件进行备份。
create:当要操作的文件并不存在时,是否创建对应的文件。
二十、替换文件当中的关键字
replace
 作用
 replace 模块可以根据我们指定的正则表达式替换文件中的字符串,文件中所有被匹配到的字符串都会被替换
#常用参数
| path | 指定要操作的文件 | 
|---|---|
| regexp | 指定一个正则表达式,文件中与正则匹配的字符串将会被替换。 | 
| replace | 指定最终要替换成的字符串。 | 
| backup | 是否在修改文件之前对文件进行备份,最好设置为yes。 |