Bootstrap

ansible shell 模块

文章目录

shell 模块

官网参考地址:https://docs.ansible.com/ansible/latest/collections/ansible/builtin/shell_module.html

切换到某个 shell 执行指定的指令,与 command 不同的是,此模块可以支持命令管道,同时还有另一个模块也具备此功能:raw

了解模块用法的渠道:

  • 使用 ansible-doc -s shell 查看帮助文档
  • 查看官网地址学习
  • 官网不好看,多去学习别人的文档
[root@master ~]# ansible-doc -s shell
- name: Execute shell commands on targets
  shell:
      chdir:                 # Change into this directory before running the command.
      cmd:                   # The command to run followed by optional arguments.
      creates:               # A filename, when it already exists, this step will *not* be run.
      executable:            # Change the shell used to execute the command. This expects an absolute path to the executable.
      free_form:             # The shell module takes a free form command to run, as a string. There is no actual parameter named 'free form'. See the examples on how to use this module.
      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.
      stdin_add_newline:     # Whether to append a newline to stdin data.
      warn:                  # Whether to enable task warnings.
      

参数解析:

参数说明
chdir在执行命令之前,通过 cd 进入到该参数指定的目录
creates在创建一个文件之前,先判断文件是否存在,如果存在则跳过前面的东西,如果不存在则执行前面的动作
free_form该参数即为输入的 linux 系统命令,实现远程执行和管理
removes判断一个文件是否存在,如果存在则执行前面的动作,如果不存在则跳过前面的内容(和上面的 creates 是相反的)
warn是否提供告警信息
  • 示例1:

查看被管理机器上的进程信息

[root@master ~]# ansible dong -m shell -a "ps -ef | grep ssh | grep -v grep"
192.168.169.162 | CHANGED | rc=0 >>
root        900      1  0 10:42 ?        00:00:00 /usr/sbin/sshd -D
root       1014    900  0 10:44 ?        00:00:00 sshd: root@pts/0
root       1021    900  0 10:44 ?        00:00:00 sshd: root@notty
root       1035   1021  0 10:44 ?        00:00:00 /usr/libexec/openssh/sftp-server
root      10856    900  3 14:05 ?        00:00:00 sshd: root@pts/1
192.168.169.161 | CHANGED | rc=0 >>
root        899      1  0 10:42 ?        00:00:00 /usr/sbin/sshd -D
root       1011    899  0 10:45 ?        00:00:00 sshd: root@pts/0
root       1014    899  0 10:45 ?        00:00:00 sshd: root@notty
root       1032   1014  0 10:45 ?        00:00:00 /usr/libexec/openssh/sftp-server
root      11454    899  0 14:05 ?        00:00:00 sshd: root@pts/1

  • 示例2:

批量远程执行脚本,需要执行的脚本要求必须在客户端存在,否则会报错文件不存在。这个是 shell 模块的特点,是因为还有另外一个专门执行脚本的 script 模块

操作步骤:
1.创建文件夹
2.创建 shell 脚本,写入内容
3.赋予脚本可执行权限
4.执行脚本
5.忽略 warning 信息
以上操作均需要在管理机器上操作,类似这种比较复杂的命令可以使用 playbook 剧本模式去编写

[root@master ~]# ansible dong -m shell -a "mkdir /data;echo 'hostname' > /data/hostname.sh;chmod u+x /data/hostname.sh;sh /data/hostname.sh warn=false creates=/data"
192.168.169.161 | CHANGED | rc=0 >>
node01
192.168.169.162 | CHANGED | rc=0 >>
node02

 
 
 
 
 

;