copy
copy 模块是将 ansible 管理主机上的文件拷贝上远程主机中,与 fetch 相反,如果目标路径不存在,则自动创建,如果 src 的目录带“/” 则
复制该目录下的所有东西,如果 src 的目录不带“/”则连同该目录一起复制到目标路径;
常用模块
src参数 :用于指定需要copy的文件或目录。
[root@controller home]# ansible test2 -m copy -a "src=/home/kkk dest=/home/"
172.20.10.8 | SUCCESS => {
"changed": true,
dest参数 :用于指定文件将被拷贝到远程主机的哪个目录中,dest为必须参数,如果有同名文件直接覆盖目标同名文件
content参数 :当不使用src指定拷贝的文件时,可以使用content直接往目标文件内指定文件内容,src与content两个参数必有其一,否则会报错。如果目标文件有内容,则直接覆盖,
[root@localhost home]# cat kkk
234
fkdsh
[root@controller home]# ansible test -m copy -a 'content="ni\nda\nye\n" dest=/home/kkk'
[root@localhost home]# cat kkk
ni
da
yee force参数 : 当远程主机的目标路径中已经存在同名文件,并且与ansible主机中的文件内容不同时,是否强制覆盖,可选值有yes和no,默认值为yes,表示覆盖,如果设置为no,则不会执行覆盖拷贝操作,远程主机中的文件保持不变。
[root@controller home]# ansible test2 -m copy -a "src=/home/ dest=/home/ force=no"
backup参数 : 当远程主机的目标路径中已经存在同名文件,并且与ansible主机中的文件内容不同时,是否对远程主机的文件进行备份,可选值有yes和no,当设置为yes时,会先备份远程主机中的文件,然后再将ansible主机中的文件拷贝到远程主机。以当前时间为后缀,如果为no时,直接覆盖目标同名文件,默认为NO
[root@controller home]# ansible test -m copy -a "backup=yes src=/home/kkk dest=/home/"
owner参数 : 指定文件拷贝到远程主机后的属主,但是远程主机上必须有对应的用户,否则会报错。
group参数 : 指定文件拷贝到远程主机后的属组,但是远程主机上必须有对应的组,否则会报错。
mode参数 : 指定文件拷贝到远程主机后的权限,如果你想将权限设置为”rw-r--r--“,则可以使用mode=0644表示,如果你想要在user对应的权限位上添加执行权限,则可以使用mode=u+x表示。
[root@controller home]# ansible test -m copy -a "src=/home/kkk dest=/home/ mode=644"