Ansible常用模块之文件操作博文中,我们介绍了一些常用的文件类操作的模块,这篇文章中我们会介绍一些常用的命令类操作的模块。
一、command模块
command模块可以帮助我们在远程主机上执行命令!
注意:使用command模块在远程主机中执行命令时,不会经过远程主机的shell处理,在使用command模块时,如果需要执行的命令中含有重定向、管道符等操作时,这些符号也会失效,比如<
, >
, |
, ;
和 &
这些符号,如果你需要这些功能,可以参考后面介绍的shell模块,还有一点需要注意,如果远程节点是windows操作系统,则需要使用win_command模块。
此处我们介绍一些command模块的常用参数,你可以先对这些参数有一个大概了解,然后再看小示例:
- free_form参数 :必须参数,指定需要远程执行的命令,需要说明一点,
free_form
参数与其他参数并不相同,在之前的模块示例中,如果想要使用一个参数,那么则需要为这个参数赋值,举个例子,之前的示例模块中,大多都有path
参数,当我们需要指定要操作的文件时,通常需要对path
参数赋值,比如,path=/testdir/test
,表示我们想要操作/testdir/test
文件,但是free_form
参数则不同,free_form
并不是一个”实际存在”的参数名,比如,当我们想要在远程主机上执行ls
命令时,我们并不需要写成free_form=ls
,这样写反而是错误的,因为并没有任何参数的名字是free_form
,当我们想要在远程主机中执行ls命令时,直接写成ls
即可,这就是free_form
参数的含义,因为command模块的作用是执行命令,所以,任何一个可以在远程主机上执行的命令都可以被称为free_form
,如果你还是不明白,看下面的小示例就行了; - chdir参数 : 此参数的作用就是指定一个目录,在执行对应的命令之前,会先进入到
chdir
参数指定的目录中; - creates参数 :看到
creates
,你可能会从字面上理解这个参数,但是使用这个参数并不会帮助我们创建文件,它的作用是当指定的文件存在时,就不执行对应命令,比如,如果/testdir/test
文件存在,就不执行我们指定的命令; - removes参数 :与creates参数的作用正好相反,它的作用是当指定的文件不存在时,就不执行对应命令,比如,如果
/testdir/tests
文件不存在,就不执行我们指定的命令,此参数并不会帮助我们删除文件;
1.1 示例命令
使用如下命令,表示在test181
主机上执行ls
命令,因为我使用的是root用户,所以默认情况下,ls
的结果是test181
主机中root
用户家目录中的文件列表;
$ ansible test181 -m command -a "ls"
chdir
参数表示执行命令之前,会先进入到指定的目录中,所以如下命令表示查看test181
主机上/testdir
目录中的文件列表;
$ ansible test181 -m command -a "chdir=/testdir ls"
如下命令表示/testdir/test
文件如果存在于远程主机中,则不执行对应命令,如果不存在,才执行echo test
命令;
$ ansible test181 -m command -a "creates=/testdir/test echo test"
如下命令表示/testdir/test
文件如果不存在于远程主机中,则不执行对应命令,如果存在,才执行echo test
命令;
$ ansible test181 -m command -a "removes=/testdir/test echo test"
二、shell模块
shell模块可以帮助我们在远程主机上执行命令,与command模块不同的是,shell模块在远程主机中执行命令时,会经过远程主机上的/bin/sh
程序处理。
学习此模块之前,请先参考本文中的command模块。
此处我们介绍一些shell模块的常用参数:
- free_form参数 :必须参数,指定需要远程执行的命令,但是并没有具体的一个参数名叫
free_form
,具体解释参考command模块; - chdir参数 : 此参数的作用就是指定一个目录,在执行对应的命令之前,会先进入到
chdir
参数指定的目录中; - creates参数 :使用此参数指定一个文件,当指定的文件存在时,就不执行对应命令,可参考command模块中的解释;
- removes参数 :使用此参数指定一个文件,当指定的文件不存在时,就不执行对应命令,可参考command模块中的解释;
- executable参数:默认情况下,shell模块会调用远程主机中的
/bin/sh
去执行对应的命令,通常情况下,远程主机中的默认shell都是bash,如果你想要使用其他类型的shell执行命令,则可以使用此参数指定某种类型的shell去执行对应的命令,指定shell文件时,需要使用绝对路径。
shell模块中chdir
、creates
、removes
参数的作用与command模块中的作用都是相同的,此处不再举例。
2.1 示例命令
使用shell模块可以在远程服务器上执行命令,它支持管道与重定向等符号。
$ ansible test181 -m shell -a "chdir=/testdir echo test > test"
如果你想要执行的命令需要csh解析,那么可以指定使用csh在远程主机上执行对应的命令,比如在如下示例中,我们使用csh的语法定义了一个数字类型的变量TestNum
,然后将TestNum
变量的值重定向到了/testdir/TestNumFile
,在bash中,@
符号不能用于定义变量,所以,可以使用executable
指定需要的shell类型。
$ ansible test181 -m shell -a 'executable=/bin/csh @ TestNum=666 ; echo $TestNum > /testdir/TestNumFile'
三、script模块
script模块可以帮助我们在远程主机上执行ansible主机上的脚本,也就是说,脚本一直存在于ansible主机本地,不需要手动拷贝到远程主机后再执行。
学习此模块之前,请先参考本文中的command模块。
此处我们介绍一些script模块的常用参数,你可以先对这些参数有一个大概了解,然后再看小示例:
- free_form参数 :必须参数,指定需要执行的脚本,脚本位于ansible主机本地,并没有具体的一个参数名叫
free_form
,具体解释参考command模块; - chdir参数 : 此参数的作用就是指定一个远程主机中的目录,在执行对应的脚本之前,会先进入到
chdir
参数指定的目录中; - creates参数 :使用此参数指定一个远程主机中的文件,当指定的文件存在时,就不执行对应脚本,可参考command模块中的解释;
- removes参数 :使用此参数指定一个远程主机中的文件,当指定的文件不存在时,就不执行对应脚本,可参考command模块中的解释;
3.1 示例命令
如下命令表示ansible主机中的/testdir/atest.sh
脚本将在test181主机中执行,执行此脚本之前,会先进入到test181主机中的/opt
目录。
$ ansible test181 -m script -a "chdir=/opt /testdir/atest.sh"
如下命令表示,如果test181主机中的/opt/testfile
文件已经存在,ansible主机中的/testdir/atest.sh
脚本将不会在test181主机中执行,反之则执行。
$ ansible test181 -m script -a "creates=/opt/testfile /testdir/atest.sh"
如下命令表示,如果test181主机中的/opt/testfile
文件不存在,ansible主机中的/testdir/atest.sh
脚本将不会在test181主机中执行,反之则执行。
$ ansible test181 -m script -a "removes=/opt/testfile /testdir/atest.sh"