Ansible-命令和模块

发布于 2021-07-20  26 次阅读


ansible 系列命令

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

1、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段能基于密钥认证的方式联系各被管理节点

2、ansible<host-pattern>[-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切换

3、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

4、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退出

5、执行状态

    绿色:执行成功并且不需要做改变的操作

    黄色:执行成功并且对目标主机做变更

    红色:执行失败

6、示例

ansible all -m ping -u wang -k

ansible all -m ping -u wang -b -k

ansible all -m ping -u wang -b -k  --become-user mage

ansible all -m command -u wang --becomer-user=root -a 'ls /root' -b -k -K