设为首页 收藏本站
查看: 1074|回复: 0

[经验分享] ansible模块介绍

[复制链接]

尚未签到

发表于 2018-7-30 09:57:38 | 显示全部楼层 |阅读模式
  命令模块:
  1:command模块在远程节点上执行命令:
  command模块后面紧跟要执行的命令,命令的参数以空格隔开。指定的命令会在所选的节点上执行。命令并不是通过shell执行的,所以并不能使用$HOME等环境变量和一些操作符(<,>,|,&).shell模块可以使用。
  1》chdir 在运行命令之前,先切换到指定的目录。
[root@master ansible]# ansible testhosts -m command -a "ls -l chdir=/tmp"  
127.0.0.1 | success | rc=0 >>
  
total 4
  
drwx------ 2 root root 4096 Apr  5 21:27 pymp-eBJbzL
  

  
192.168.1.112 | success | rc=0 >>
  
total 4
  
drwxr-xr-x 2 root root 4096 Apr  2 02:04 rsync
  
/先切换到/tmp目录下,然后再执行命令!
  2》creates 后边可以直接指定一个文件名(目录名),或者是以正则模式匹配一系列文件名。如果所指定的文件存在的话,则不执行指定的命令。
[root@master ansible]# ansible 192.168.1.112 -m command -a "ls -l /tmp creates=/tmp/test"  
192.168.1.112 | success | rc=0 >>
  
total 4
  
drwxr-xr-x 2 root root 4096 Apr  2 02:04 rsync
  

  
/tmp/test不存在,所以执行命令
  

  
[root@master ansible]# ansible 192.168.1.112 -m command -a "ls -l /tmp creates=/tmp/rsync"
  
192.168.1.112 | success | rc=0 >>
  
skipped, since /tmp/rsync exists
  

  

  
/tmp/rsync文件存在,所以不执行命令
  3》removes 后边可以直接指定一个文件名(或目录名),或者是以正则模式匹配一系列文件名。如果所指定的文件不存在的话,则不运行命令。(注意与creates的对比)
[root@master ~]# ansible 192.168.1.112 -m command -a "ls -l /tmp removes=/tmp/test"  
192.168.1.112 | success | rc=0 >>
  
skipped, since /tmp/test does not exist
  

  
[root@master ~]# ansible 192.168.1.112 -m command -a "ls -l /tmp removes=/tmp/rsync"
  
192.168.1.112 | success | rc=0 >>
  
total 4
  
drwxr-xr-x 2 root root 4096 Apr  2 02:04 rsync
  

  
[root@master ~]#
  

  
/注意与creates的对比
  2.script模块在远程机器上运行本地脚本。
  script模块的-a选项直接跟一个本地脚本的绝对路径,脚本的参数以空格隔开。该模块首先将指定的脚本传到远程节点上,然后在远程节点的shell环境下执行该脚本。
[root@master ~]# ansible 192.168.1.112 -m script -a "/root/test.sh"  
192.168.1.112 | success >> {
  
    "changed": true,
  
    "rc": 0,
  
    "stderr": "",
  
    "stdout": "ok\n"
  
}
  

  
/注意的是,这是本地的脚本在远程执行,这样执行的时候,脚本文件必须得有可执行权限/
  3.shell模块,在远程节点执行命令
  shell模块的参数为命令名称,命令本身的参数以空格隔开。像command模块那样在远程节点执行命令,但shell模块再远程节点是通过shell环境(/bin/bash)执行命令的,该模块也可以执行一个shell脚本,但该脚本必须在远程节点上存在。
  chdir、creates、removes参数与command模块的参数一样。
[root@master ~]# ansible 192.168.1.112 -m shell -a " echo $HOME"  
192.168.1.112 | success | rc=0 >>
  
/root
  

  

  
shell执行脚本文件
  
[root@master ~]# ansible 192.168.1.112 -m command  -a " echo $HOME"
  
192.168.1.112 | success | rc=0 >>
  
/root
  

  
[root@master ~]# ansible 192.168.1.112 -m shell -a "/bin/bash /root/test1.sh"
  
192.168.1.112 | FAILED | rc=127 >>
  
/bin/bash: /root/test1.sh: No such file or directory
  

  
[root@client ~]# vim test1.sh   /在远程节点上创建脚本文件
  
[root@client ~]# cat test1.sh
  
#!/bin/bash
  
echo oK
  
[root@client ~]#
  

  
[root@master ~]# ansible 192.168.1.112 -m shell -a "/bin/bash /root/test1.sh"
  
192.168.1.112 | success | rc=0 >>
  
oK
  

  
/sehll执行脚本文件,脚本文件必须在远程节点上存在
  看一个简单的playbook文件:
[root@master ansible]# vim test.yml  

  
---
  
- hosts: 192.168.1.112
  
  remote_user: root
  

  
  tasks:
  
   - name: lianxi module 1
  
#file on the remote
  
     shell: /bin/bash /root/test1.sh
  

  
/playbook脚本是以.yml为后缀的!下面为执行结果
  
[root@master ~]# cd /etc/ansible
  
[root@master ansible]# ansible-playbook test.yml
  

  
PLAY [192.168.1.112] **********************************************************
  

  
GATHERING FACTS ***************************************************************
  
ok: [192.168.1.112]
  

  
TASK: [lianxi module 1] *******************************************************
  
changed: [192.168.1.112]
  

  
PLAY RECAP ********************************************************************
  
192.168.1.112              : ok=2    changed=1    unreachable=0    failed=0
  4.文件相关模块:
  copy 复制本地文件到远程路径下
  copy模块将本地文件复制到远程路径下。fetch模块将远程文件复制到本地。
  copy的选项:
  dest 必选参数,为目标文件指定远程节点上的一个绝对路径。如果src是一个目录,那么该参数也必须是个目录。
  src 本地文件的绝对路径,或者相对路径。如果是个路径则会递归复制,路径是以/结尾的话,只复制目录里面的内容,如果不以/几位的话会复制目
  录本身和里面的内容。类似Rsync那样。
  backup 可选参数,为源文件创建一个备份文件,被给备份文件添加一个时间戳信息。值为:yes/no,默认为no。
[root@master ~]# ansible 192.168.1.112 -m copy -a "src=/root/test  dest=/root/ backup=yes"  
192.168.1.112 | success >> {
  
    "changed": true,
  
    "checksum": "4e1243bd22c66e76c2ba9eddc1f91394e57f9f83",
  
    "dest": "/root/test",
  
    "gid": 0,
  
    "group": "root",
  
    "md5sum": "d8e8fca2dc0f896fd7cb4cb0031ba249",
  
    "mode": "0644",
  
    "owner": "root",
  
    "size": 5,
  
    "src": "/root/.ansible/tmp/ansible-tmp-1459869115.84-179543827108657/source",
  
    "state": "file",
  
    "uid": 0
  
}
  content 可选参数,当使用该参数来代替src的时候,会将内容直接写入到目标文件中。
[root@master ~]# ansible 192.168.1.112 -m copy -a "content='test test' dest=/root/test"  
192.168.1.112 | success >> {
  
    "changed": true,
  
    "checksum": "abedc47a5ede3fab13390898c5160ec9afbb6ec3",
  
    "dest": "/root/test",
  
    "gid": 0,
  
    "group": "root",
  
    "md5sum": "4f4acc5d8c71f5fbf04dace00b5360c8",
  
    "mode": "0644",
  
    "owner": "root",
  
    "size": 9,
  
    "src": "/root/.ansible/tmp/ansible-tmp-1459869735.21-149102614709149/source",
  
    "state": "file",
  
    "uid": 0
  
}
  

  

  
查看一下:
  
[root@client ~]# cat test
  
test test[root@client ~]#
  directory_mode 可选参数,当递归复制的时候,为所创建的目录设置权限,如果没有指定则使用系统的默认权限。该参数只影响新创建的目录,不会影响已经存在的目录。
[root@web1 ~]# ansible webservers -m copy -a "src=/root/test/ dest=/root/ directory_mode=0777"  force ,该参数默认值为yes,当远程文件与本地文件内容不一致的时候会替换远程文件。只有当远程目标文件不存在的时候才会传输文件。
  group 文件或目录的所属组.
[root@web1 ~]# ansible webservers -m copy -a "src=/root/test/testgroup dest=/root/test1/testgroup group=liuzhenwei"  mode 文件或目录的权限,如0644。
[root@web1 ~]# ansible webservers -m copy -a "src=/root/test/testgroup dest=/root/test1/testgroup mode=0755"  看一下copy模块的返回值,各代表的意思:
  src 要复制到远程节点的源文件路径
  backup_file 远程节点上的备份文件路径,backup=yes的时候才有
  uid 文件的所有者ID
  dest 目标文件在远程节点上的绝对路径,/root/file.txt
  checksum 校验值
  md5sum md5校验值
  state 状态,如 file
  gid 文件的所属组ID
  mode 文件的权限
  owner 文件所有者
  group 文件所属组
  size 文件大小

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-543414-1-1.html 上篇帖子: ansible文档 下篇帖子: 3.1-ansible安装以及配置认证
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表