ansible get_url将文件从HTTP,HTTPS或FTP下载到节点
参数 | 是否必须 |
默认 | 选项 | 说明 |
attributes | no | None | yes no |
文件或目录的属性应该是。要获得支持的标志,请查看taget系统上chattr的手册页. |
backup | no | no | 创建一个包括时间戳信息的备份文件,这样你可以得到原始文件,如果你不正确地弄错了。 |
|
checksum | no | 如果将校验和传递给此参数,则将在下载目标文件的摘要后计算摘要,以确保其完整性,并验证传输是否成功完成。格式: |
||
dest | yes | 将文件下载到的绝对路径。 如果dest是目录,则服务器提供的文件名,如果没有提供,则将使用远程服务器上的URL的基本名称。如果一个目录,force没有效果。如果dest是一个目录,文件将总是被下载(不管force选项),但是只有当内容改变时才被替换。 |
||
force | no | no | yes no |
如果是的,dest不是目录,将每次下载文件,如果内容改变,替换文件。如果否,则只有在目标不存在时才会下载该文件。一般应该是只对小的本地文件。在0.6之前,此模块的行为好像是默认值。 |
force_basic_auth | no | no | yes no |
httplib2,uri模块使用的库只会在webservice以401状态响应初始请求时发送身份验证信息。由于一些基本的auth服务没有正确发送401,登录将失败。此选项强制在初始请求时发送Basic认证头。 |
group | no | 应该拥有文件/目录的组的名称,将被发送到chown。 |
||
headers | no | 以格式“key:value,key:value”向请求添加自定义HTTP标头 | ||
mode | no | 模式文件或目录应该是。对于那些用于/ usr / bin / chmod的记住,模式实际上是八进制数字(如0644)。离开领先的零可能会有意想不到的结果。从版本1.8起,模式可以被指定为符号模式(例如,u + rwx或u = rw,g = r,o = r)。 | ||
others | no | 文件模块接受的所有参数也在这里工作 | ||
owner | no | 应该拥有文件/目录的用户的名称,将被发送到chown。 |
||
selevel | no | s0 | SELinux文件上下文的级别部分。这是MLS / MCS属性,有时称为范围。 _default功能与seuser相同。 | |
serole | no | SELinux文件上下文的角色部分,_default功能与seuser一样。 |
||
setype | no | 键入SELinux文件上下文的一部分,_default功能与seuser一样工作. |
||
sha256sum | no | 如果将SHA-256校验和传递给此参数,则将在下载目标文件的摘要后计算摘要,以确保其完整性,并验证传输是否成功完成。此选项已弃用。使用'校验和'。 | ||
timeout | no | 网址请求的超时(以秒为单位) | ||
tmp_dest | no | 临时文件下载到的绝对路径。 默认为TMPDIR,TEMP或TMP env变量或特定于平台的值 https://docs.python.org/2/library/tempfile.html#tempfile.tempdir |
||
unsafe_writes | no | 通常,此模块使用原子操作来防止数据损坏或从目标文件读取不一致,有时系统配置或只是破坏以防止这种情况。一个例子是docker挂载的文件,它们不能被原子地更新,并且只能以不安全的方式完成。 这个布尔选项允许ansible回退到不安全的更新文件的方法,在那些没有任何其他选择的情况下。请注意,这是受种族条件的制约,可能导致数据损坏。 |
||
url | yes | HTTP, HTTPS, or FTP URL in the form | ||
url_password | no | 用于HTTP基本认证的密码。如果未指定url_username参数,则不会使用url_password参数。 | ||
url_username | no | 用于HTTP基本认证的用户名。对于允许空密码的站点,可以在不使用url_password的情况下使用此参数。 | ||
use_proxy | no | yes | yes no |
如果没有,它将不使用代理,即使在目标主机上的环境变量中定义了一个代理。 |
validate_certs | no | yes | yes no |
如果否,SSL证书将不会验证。这只应在使用自签名证书的个人控制站点上使用。 |
下载文件
# ansible webserver -m get_url -a "url=http://muzhi.baidu.com/question/13193725.html dest=/tmp/" 172.16.110.47 | SUCCESS => { "changed": true, "checksum_dest": null, "checksum_src": "a6b0a0327865daba2b920fb4678545bd2c212963", "dest": "/tmp/13193725.html", "gid": 0, "group": "root", "md5sum": "888dc8c9883f8f9468fb9a6e83ba36fe", "mode": "0644", "msg": "OK (unknown bytes)", "owner": "root", "size": 20637, "src": "/tmp/tmpQlWqAU", "state": "file", "uid": 0, "url": "http://muzhi.baidu.com/question/13193725.html" } 172.16.110.48 | SUCCESS => { "changed": true, "checksum_dest": null, "checksum_src": "c22386c304380819fa9407097d21c0bd942819ad", "dest": "/tmp/13193725.html", "gid": 0, "group": "root", "md5sum": "29c8669695e64e134a3e93a646653536", "mode": "0644", "msg": "OK (unknown bytes)", "owner": "root", "size": 20637, "src": "/tmp/tmppkHcOz", "state": "file", "uid": 0, "url": "http://muzhi.baidu.com/question/13193725.html" }
2.下载nginx包,权限为740,属主为ckl属组为ckl,并制定校验码
# ansible webserver -m get_url -a "url=http://nginx.org/download/nginx-1.11.8.zip dest=/tmp/ group=ckl owner=ckl mode=740 checksum='sha256:0f06c91e86322a7658fcd4c210e1af69512ae9ff974df5e2beb4e4952e678016'" 172.16.110.47 | SUCCESS => { "changed": true, "checksum_dest": null, "checksum_src": "fa31bdfaead51dbe94b9de6958021038ce9a779e", "dest": "/tmp/nginx-1.11.8.zip", "gid": 1000, "group": "ckl", "md5sum": "cedc1474bfe20e43fe67907664b6741a", "mode": "0740", "msg": "OK (1398628 bytes)", "owner": "ckl", "size": 1398628, "src": "/tmp/tmpqBcnhn", "state": "file", "uid": 1000, "url": "http://nginx.org/download/nginx-1.11.8.zip" } 172.16.110.48 | SUCCESS => { "changed": true, "checksum_dest": null, "checksum_src": "fa31bdfaead51dbe94b9de6958021038ce9a779e", "dest": "/tmp/nginx-1.11.8.zip", "gid": 1000, "group": "ckl", "md5sum": "cedc1474bfe20e43fe67907664b6741a", "mode": "0740", "msg": "OK (1398628 bytes)", "owner": "ckl", "size": 1398628, "src": "/tmp/tmpdny5Fq", "state": "file", "uid": 1000, "url": "http://nginx.org/download/nginx-1.11.8.zip" }
查看文件:
# ll nginx-1.11.8.zip -rwxr----- 1 ckl ckl 1398628 Dec 29 15:29 nginx-1.11.8.zip
3.下载文件指定用户名和密码
ansible webserver -m get_url -a 'url=http://redistat.quanmin.tv dest=/tmp/ url_username='ckl' url_password="hh!123"' 172.16.110.47 | SUCCESS => { "changed": true, "checksum_dest": null, "checksum_src": "5eb6b5401bdbf69556e0a83e6b02590f25704e24", "dest": "/tmp/index.html", "gid": 0, "group": "root", "md5sum": "23b07c0e7c4d143f3f877a7d0ed63099", "mode": "0644", "msg": "OK (33395 bytes)", "owner": "root", "size": 33395, "src": "/tmp/tmpk3Scw3", "state": "file", "uid": 0, "url": "http://redistat.quanmin.tv" } 172.16.110.48 | SUCCESS => { "changed": true, "checksum_dest": null, "checksum_src": "5eb6b5401bdbf69556e0a83e6b02590f25704e24", "dest": "/tmp/index.html", "gid": 0, "group": "root", "md5sum": "23b07c0e7c4d143f3f877a7d0ed63099", "mode": "0644", "msg": "OK (33395 bytes)", "owner": "root", "size": 33395, "src": "/tmp/tmpxjpA9e", "state": "file", "uid": 0, "url": "http://redistat.quanmin.tv" }