ansible playbook实践(二)-基础相关命令

ansible相关的命令:

ansible  用来执行ansible管理命令

ansible-doc 用来获取模块的帮助文档

ansible-playbook 当有众多任务时,可编写成playbook来运行

 

ansible的简单使用格式:

ansible HOST-PATTERN -m MOD_NAME -a MOD_ARGS

 

获取模块列表

ansible-doc -l 里面有众多模块,掌握一些常用的即可满足日常工作

ansible-doc -s modulename # 获取模块简要使用说明

示例:

[root@localhost ~]# ansible-doc -s shell
- name: Execute commands in nodes.
shell:
chdir: # cd into this directory before running the command
creates: # a filename, when it already exists, this step will *not* be run.
executable: # change the shell used to execute the command. Should be an absolute path to the executable.
free_form: # (required) The shell module takes a free form command to run, as a string. There's not an actual option named "free form". See the examples!
removes: # a filename, when it does not exist, this step will *not* be run.
stdin: # Set the stdin of the command directly to the specified value.
warn: # if command warnings are on in ansible.cfg, do not warn about this particular line if set to no/false.

里面标明了各个参数的含义,如果你想更详细的解释,可以把命令行中的-s去掉。

 

[root@localhost ~]# ansible all -m shell -a "chdir=/tmp date"
192.168.40.72 | SUCCESS | rc=0 >>
Thu Feb 8 10:46:45 CST 2018

192.168.40.73 | SUCCESS | rc=0 >>
Thu Feb 8 10:46:45 CST 2018

 

对于执行单个简单的模块,我们还可以这样用命令行来编写,但是当我们需要连接执行多个模块时,就得需要用到ansible-playbook命令了。我们可以把需要执行的任务写在一个文件中,然后依次执行。

 

[root@localhost playbook]# cat first_play.yml
---
- hosts: all
  remote_user: root
  gather_facts: no
  tasks:
    - name: ping test
      ping: 

    - name: execute remote shell
      shell: ps -eo pcpu,user,args | sort -r -k1 | head -n3
      register: ret
 
    - name: output msg
      debug: var=ret.stdout_lines

执行如下,加上-v(-vv -vvv)参数可以有更详细的信息输出:

[root@localhost playbook]# ansible-playbook -v first_play.yml 
Using /etc/ansible/ansible.cfg as config file

PLAY [all] ********************************************************************************

TASK [ping test] **************************************************************************
ok: [192.168.40.72] => {"changed": false, "ping": "pong"}
ok: [192.168.40.73] => {"changed": false, "ping": "pong"}

TASK [execute remote shell] ***************************************************************
changed: [192.168.40.73] => {"changed": true, "cmd": "ps -eo pcpu,user,args | sort -r -k1 | head -n3", "delta": "0:00:00.010615", "end": "2018-02-08 11:04:19.939640", "rc": 0, "start": "2018-02-08 11:04:19.929025", "stderr": "", "stderr_lines": [], "stdout": "%CPU USER     COMMAND\n 2.0 root     sshd: root@pts/0\n 0.6 root     /usr/bin/vmtoolsd", "stdout_lines": ["%CPU USER     COMMAND", " 2.0 root     sshd: root@pts/0", " 0.6 root     /usr/bin/vmtoolsd"]}
changed: [192.168.40.72] => {"changed": true, "cmd": "ps -eo pcpu,user,args | sort -r -k1 | head -n3", "delta": "0:00:00.013069", "end": "2018-02-08 11:04:19.943902", "rc": 0, "start": "2018-02-08 11:04:19.930833", "stderr": "", "stderr_lines": [], "stdout": "%CPU USER     COMMAND\n 1.0 root     sshd: root@pts/1\n 0.5 root     /usr/bin/vmtoolsd", "stdout_lines": ["%CPU USER     COMMAND", " 1.0 root     sshd: root@pts/1", " 0.5 root     /usr/bin/vmtoolsd"]}

TASK [output msg] *************************************************************************
ok: [192.168.40.72] => {
    "ret.stdout_lines": [
        "%CPU USER     COMMAND", 
        " 1.0 root     sshd: root@pts/1", 
        " 0.5 root     /usr/bin/vmtoolsd"
    ]
}
ok: [192.168.40.73] => {
    "ret.stdout_lines": [
        "%CPU USER     COMMAND", 
        " 2.0 root     sshd: root@pts/0", 
        " 0.6 root     /usr/bin/vmtoolsd"
    ]
}

PLAY RECAP ********************************************************************************
192.168.40.72              : ok=3    changed=1    unreachable=0    failed=0   
192.168.40.73              : ok=3    changed=1    unreachable=0    failed=0   

 

playbook采用yaml语法来编写,下一篇我们就来讲如何编写yaml文件。

 

 

 

 

 

posted @ 2018-02-08 11:07  泽锦  阅读(1601)  评论(0编辑  收藏  举报