ansible是一款自动化运维工具,基于Python开发,集合了众多运维工具(puppet、cfengine、chef、func、fabric)的优点,实现了批量系统配置,批量程序部署,批量运行命令等功能。

  ansible是基于模块工作的,本事没有批量部署的能力。真正具有批量部署的是ansible所运行的模块,ansible只是提供一种框架。主要包括:

   1、连接插件connection plugins:负责和被监控端进行通信

   2、host inventory:指定操作的主机,是一个配置文件里卖弄定义监控的主机

   3、各种核心模块、command模块、自定义模块

   4、借助于插件完成记录日志邮件等功能

   5、playbook:可让slave节点一次执行多个任务


  ansible的特性:

   1、模块化:调用特定的模块,完成特定任务

   2、基于python语言实现,有Paramiko,PyYAML和jinja2三个关键模块

   3、部署简单

   4、支持自定义模块

   5、支持playbook

   


准备环境

           主机名              IP
          localhost(ansiblemaster)           10.10.86.56
           node1(ansibleslave)           10.10.73.148
           bogon(ansibleslave)           10.10.73.149


一、ansible的安装

[root@localhost ~]# yum install ansible
##配置文件:/etc/ansible/ansible.cfg
##主机清单:/etc/ansible/hosts
##主程序:ansible、ansible-doc、ansible-playbook


二、ansible免秘钥ssh登陆

root@localhost ~]# ssh-keygen -t rsa -P ''
[root@localhost ~]# ssh-copy-id -i [email protected]
/usr/bin/ssh-copy-id: INFO: attempting to log in with the new key(s), to filter out any that are already installed

/usr/bin/ssh-copy-id: WARNING: All keys were skipped because they already exist on the remote system.

[root@localhost ~]# ssh-copy-id -i [email protected]
/usr/bin/ssh-copy-id: INFO: attempting to log in with the new key(s), to filter out any that are already installed

/usr/bin/ssh-copy-id: WARNING: All keys were skipped because they already exist on the remote system.
##将生产的秘钥推送给slave节点,第一次交互需要(yes/no)


三、主机组自定义

[root@localhost ~]# vim /etc/ansible/hosts
[ansible_agent]

10.10.73.148  ##port  

10.10.73.149  ##port
##如果slave的ssh端口不是默认的22,则可在主机后面相应的端口


四、简单测试

 获取ansible的常用模块列表

[root@localhost ~]# ansible-doc -l

 获取某个模块的用法

[root@localhost ~]# ansible-doc -s COMMAND
##COMMAND:yum、cron、shell、setup、copy......


 1、ping

[root@localhost ~]# ansible ansible_agent -m ping    ##用来测试远程主机的运行状态
10.10.73.149 | SUCCESS => { 
    "changed": false, 
    "ping": "pong"
}
10.10.73.148 | SUCCESS => {
    "changed": false, 
    "ping": "pong"
}

 2、setup模块

[root@localhost ~]# ansible ansible_agent -m "setup"   ##获取远程主机的详情信息


 3、command模块

[root@localhost ~]# ansible ansible_agent -m shell -a "ls /tmp"
10.10.73.149 | SUCCESS | rc=0 >>
ansible_Z1xG26
wtc

10.10.73.148 | SUCCESS | rc=0 >>
ansible_6SQ3_D
report.sh
wtc.txt


 4、shell模块

[root@localhost ~]# ansible ansible_agent -m shell -a "echo wxpp | passwd --stdin wtc"
10.10.73.148 | SUCCESS | rc=0 >>
Changing password for user wtc.
passwd: all authentication tokens updated successfully.

10.10.73.149 | SUCCESS | rc=0 >>
更改用户 wtc 的密码 。
passwd: 所有的身份验证令牌已经成功更新。

###ansible是要支持管道命令,必须要使用shell模块;同时想要支持shell特性,必须要使用shell模块


 5、copy模块

  (1)src=  dest=

  (2)content=  dest=

  (3)owner:指明属主

  (4)group:指明数组

  (5)mode:指明权限

[root@localhost tmp]# ansible ansible_agent -m copy -a "src=/tmp/wxpp.txt  dest=/tmp mode=665"  ##复制本地的"wxpp.txt"文件至远程主机上
10.10.73.148 | SUCCESS => {
    "changed": true, 
    "checksum": "7641dc777dc18a1c2dfa3429aa8009c12c566913", 
    "dest": "/tmp/wxpp.txt", 
    "gid": 0, 
    "group": "root", 
    "mode": "0665", 
    "owner": "root", 
    "path": "/tmp/wxpp.txt", 
    "size": 36, 
    "state": "file", 
    "uid": 0
}
10.10.73.149 | SUCCESS => {
    "changed": true, 
    "checksum": "7641dc777dc18a1c2dfa3429aa8009c12c566913", 
    "dest": "/tmp/wxpp.txt", 
    "gid": 0, 
    "group": "root", 
    "mode": "0665", 
    "owner": "root", 
    "path": "/tmp/wxpp.txt", 
    "size": 36, 
    "state": "file", 
    "uid": 0
}
[root@localhost tmp]# ansible ansible_agent -m shell -a "cat /tmp/wxpp.txt"   ##追加指定的文本至远程主机中
10.10.73.149 | SUCCESS | rc=0 >>
wtc sent a bouquet of roses to wxpp

10.10.73.148 | SUCCESS | rc=0 >>
wtc sent a bouquet of roses to wxpp
[root@localhost tmp]# ansible ansible_agent -m copy -a "content='\nHello World' dest=/tmp/wxpp.txt"
10.10.73.149 | SUCCESS => {
    "changed": true, }
10.10.73.148 | SUCCESS => {
    "changed": true, }
 [root@localhost tmp]# ansible ansible_agent -m shell -a "cat /tmp/wxpp.txt"
10.10.73.149 | SUCCESS | rc=0 >>

Hello World

10.10.73.148 | SUCCESS | rc=0 >>

Hello World
##content是覆盖文件源内容,使用时注意


 6、cron模块

  (1)month= 

  (2)day=

  (3)hour=

  (4)weekday=

  (5)minute=

  (6)job=   ##指明运行的命令是什么

  (7)name=  ##指明定时任务描述

  (8)state  ##指定状态,prsent表示添加定时任务,也是默认值。absent表示删除定时任务

  (9)user   ##指明以那个用户的身份执行

[root@localhost ~]# ansible ansible_agent -m shell -a "ls /var/spool/cron/"
10.10.73.149 | SUCCESS | rc=0 >>
root

10.10.73.148 | SUCCESS | rc=0 >>
root
[root@localhost ~]# ansible ansible_agent -m cron -a "minute='*/1' job='/usr/sbin/ntpdate 10.10.86.56 &> /dev/null' user=wtc name='Wtc Job'"
10.10.73.149 | SUCCESS => {
    "changed": true, 
    "envs": [], 
    "jobs": [
        "Wtc Job"
    ]
}
10.10.73.148 | SUCCESS => {
    "changed": true, 
    "envs": [], 
    "jobs": [
        "Wtc Job"
    ]
}
[root@localhost ~]# ansible ansible_agent -m shell -a "cat /var/spool/cron/wtc"
10.10.73.149 | SUCCESS | rc=0 >>
#Ansible: Wtc Job
*/1 * * * * /usr/sbin/ntpdate 10.10.86.56 &> /dev/null

10.10.73.148 | SUCCESS | rc=0 >>
#Ansible: Wtc Job
*/1 * * * * /usr/sbin/ntpdate 10.10.86.56 &> /dev/null


 7、file模块:

  (1)创建链接文件:src=、path=、state=

  (2)修改文件属性:path=、owner=、mode=、group=

  (3)创建目录:path=、state=

  (4)state

     directory:如果目录不存在,则会创建

     link:创建软链接

     hard:创建硬链接

     touch:如果文件不存在,则会创建。如果文件存在,则修改mtime

     absent:删除目录、文件、取消链接

[root@localhost ~]# ansible ansible_agent -m file -a "src=/etc/fstab path=/tmp/fstab.link state=link"
10.10.73.148 | SUCCESS => {
    "changed": true, 
    "dest": "/tmp/fstab.link", 
    "gid": 0, 
    "group": "root", 
    "mode": "0777", 
    "owner": "root", 
    "size": 10, 
    "src": "/etc/fstab", 
    "state": "link", 
    "uid": 0
}
10.10.73.149 | SUCCESS => {
    "changed": true, 
    "dest": "/tmp/fstab.link", 
    "gid": 0, 
    "group": "root", 
    "mode": "0777", 
    "owner": "root", 
    "size": 10, 
    "src": "/etc/fstab", 
    "state": "link", 
    "uid": 0
}
[root@localhost ~]# ansible ansible_agent -m shell -a "ls /tmp"
10.10.73.149 | SUCCESS | rc=0 >>
ansible_TdmFaK
fstab.link
wtc
wxpp.txt

10.10.73.148 | SUCCESS | rc=0 >>
ansible_1oUVuk
fstab.link
report.sh
wtc.txt
wxpp.txt
[root@localhost ~]# ansible ansible_agent -m file -a "path=/tmp/fstab.link state=absent"
10.10.73.149 | SUCCESS => {
    "changed": true, 
    "path": "/tmp/fstab.link", 
    "state": "absent"
}
10.10.73.148 | SUCCESS => {
    "changed": true, 
    "path": "/tmp/fstab.link", 
    "state": "absent"
}
[root@localhost ~]# ansible ansible_agent -m shell -a "ls /tmp"
10.10.73.148 | SUCCESS | rc=0 >>
ansible_jTgQOI
report.sh
wtc.txt
wxpp.txt

10.10.73.149 | SUCCESS | rc=0 >>
ansible_CuFRGA
wtc
wxpp.txt


 8、更多模块(ansible-doc -l)

    fetch模块:拉取远程主机的文件到本地(拉取的只能是文件,但是拉取到本地之后是目录,以"hosts"文件中名字命名

    hostname模块:管理主机名

    yum模块:给远程主机安装应用、卸载程序

     service模块:管理远程主机上的服务

    user模块:管理用户的账号、密码

    group模块:管理系统用户组

 

总结:

1、ansible是基于ssh无密钥登陆的,只限于当前用户。如果是"wtc"用户创建ansible秘钥并推送至远程主机,则使用"root"用户推送命令则需使用密码

2、对于"shell"模块,个人认为它可以实现多数模块的功能,只要能用命令表达式表达出来即可,例如:

ansible ansible_agent -m shell -a "yum install httpd"  
ansible ansible_agent -m shell -a "service httpd start"
ansible ansible_agent -m shell -a "echo 'wtc sent a bouquet of roses to wxpp' &>> /tmp/wxpp.txt"
ansible ansible_agent -m shell -a "ln -sv /etc/fstab /tmp/fstab.link"