ansible ansible-doc ansible-playbook ansible-vault ansible-console ansible-galaxy ansible-pull

ansible-doc 显示模块帮助

ansible-doc [options][module]
-a 显示所有模块文档
-l,—list 列出可用模块
-s,—snippet 显示指定模块的playbook片段
实例:
ansible-doc -l 列出所有模块
ansible-doc ping 查看指定模块的帮助用法
ansible-doc -s ping 查看指定模块的帮助用法
ansible通过ssh实现配置管理、应用部署,任务执行等功能,建议配置ansible段能基于密钥认证的方式联系各被管理节点

ansible[-m module_name] [-a args]

—version 显示版本
-m module 指定模块,默认为command
-v 详细过程 -vv -vvv 更详细
—list-host 显示主机列表,可简写—list
-k ,—ask-pass 提示输入ssh连接密码。默认key验证
-K, —ask-become-pass 提示输入sudo时的口令
-C,—check 检查不执行
-T —timeout=TIMEOUT 执行命令的超时时间,默认10s
-u —user=REMOTE——USER 执行远程执行的用户
-b, —become 代替旧版本的sudo切换

ansible的Host-pattern 匹配主机的列表

all:表示所有Inventory中的所有主机
:通配符
ansible “
” -m ping
ansible 192.168.1. -m ping
ansible “
srvs” -m ping
或关系
ansible “webserver:dbserver” -m ping
ansible “webserver:dbserver” -m ping #执行在web组并且在dbserver组中的主机(忽略重复的)
与关系
ansible “webserver:&dbserver” -m ping
只执行在web组并且也在dbserver组中的主机
逻辑非
ansible ‘webserver:!dbserver’ -m ping 【注意此处只能使用单引号!】
综合逻辑
ansible ‘webserver:dbserver:&webserver:!dbserver’ -m ping
正则表达式
ansible “webserver:&dbserver” -m ping
ansible “~(web|db).*.magedu.\com” -m ping

ansible命令执行过程

  1. 加载自己的配置文件 默认/etc/ansible/ansible.cfg
  2. 加载自己对应的模块 如command
  3. 通过ansible将模块或命令生成对应的临时py文件,并将改文件传输至远程服务器的对应执行用户SHOME/.ansible/tmp/ansible-tmp-数字/XXX.py文件
  4. 文件见+x执行
  5. 执行并返回结果
  6. 删除临时py文件,sleep 0退出

    执行状态

  • 绿色:执行成功并且不需要做改变的操作
  • 黄色:执行成功并且对目标主机做变更
  • 红色:执行失败