1
2
3
4
5
 _     _                   ____       __  __           
| |   (_)_ __  _   ___  __/ ___|___  / _|/ _| ___  ___ 
| |   | | '_ \| | | \ \/ / |   / _ \| |_| |_ / _ \/ _ \ 
| |___| | | | | |_| |>  <| |__| (_) |  _|  _|  __/  __/
|_____|_|_| |_|\__,_/_/\_\\____\___/|_| |_|  \___|\___|
Ansible,官方的解释是:Ansible is the simplest way to automate IT.http://www.paramiko.org/ 
关于Configuration management (CM) 配置管理工具 Ansible — Puppet — Chef — SaltStack 的几个工具的对比,参考 https://devopsu.com/books/taste-test-puppet-chef-salt-stack-ansible.html 
一些相关链接:http://www.ansible.com http://docs.ansible.com/index.html http://www.ansible.com/ansible-book 
一、安装 
安装也相当方便。目前已经发布了1.8 版本,但epel源中是1.7.2
Mac 
1
2
3
MacBookPro:~ hzchenkj$ brew install ansible 
MacBookPro:~ hzchenkj$ ansible --version
ansible 1.7 .2 
RedHat 
1
2
rpm –ivh http://dl.fedoraproject.org/pub/epel/6 /x86_64/epel-release-6 -8 .noarch.rpm
yum –y install ansible
二、使用 
定义主机配置文件,默认在/etc/ansible/hosts 下面,
1
ansible -i /usr/local/Cellar/ansible/1.7 .2 /ansible_hosts  webservers -a  'uptime'  -u root -k
该命令选项的作用分别为:
-i:指定 inventory 文件,使用当前目录下的 hosts
或者设置环境变量
1
2
export  ANSIBLE_HOSTS=/usr/local/Cellar/ansible/1.7 .2 /ansible_hosts 
ansible  webservers -a  'uptime'  -u root -k
编辑主机配置文件,支持嵌套。也可以支持别名,定义变量
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
[webservers]
10.223 .55.100 
10.223 .55.101 
10.223 .38.226 
[linux:children]
nginx
tomcat
[nginx]
10.223 .38.227 
[tomcat]
10.223 .39.216 
10.223 .25.123 
10.240 .162.11 [1 :9 ]:22 
[mysql]
mysql1 ansible_ssh_host=192.168 .22.11  ansible_ssh_port=65422  ansible_ssh_user=mysql 
mysql2 ansible_ssh_host=192.168 .22.12  ansible_ssh_port=65422  ansible_ssh_user=mysql
[webservers:vars]
ls-path=/bin/ls
liss=lisisi
配置ssh信任 
将ansible主控机上的ssh公钥拷贝到受控机器上
传输到受控远程服务器上:
1
cat  ~/.ssh/id_rsa.pub | ssh -p 65422  winupon@192.168 .22.11  "cat - >> ~/.ssh/authorized_keys" 
或者使用ssh-copy-id 命令
1
ssh-copy-id -i ~/.ssh/id_rsa.pub root@192.168 .22.11 
保证远程服务器上的authorized_keys 文件的权限为600
1
2
chmod  700    ~/.ssh
chmod  600    ~/.ssh/authorized_keys
使用ping模块进行测试所有的主机
1
2
3
4
5
ansible all -m ping
child1.dev | success >> {
    "changed" : false , 
    "ping" : "pong" 
}
三、常用模块使用 
以下列举Ansible自带的常用的模块:
1
ansible <pattern_goes_here> -m <module_name> -a  <arguments>
或者all #匹配所有主机 .com 当然也可以用正则
setup 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
MacBookPro:~ hzchenkj$ ansible docker -m setup|more
docker12 | success >> {
    "ansible_facts" : {
        "ansible_all_ipv4_addresses" : [
            "192.168.22.12" , 
            "172.17.42.1" 
        ], 
        "ansible_all_ipv6_addresses" : [
            "fe80::862b:2bff:fe49:96a6" , 
            "fe80::bc0c:f7ff:fea2:609c" , 
            "fe80::c429:89ff:fe7c:156a" , 
            "fe80::26:68ff:fe30:3f46" 
        ], 
        "ansible_architecture" : "x86_64" , 
        "ansible_bios_date" : "05/25/2010" , 
        "ansible_bios_version" : "1.4.7" , 
        "ansible_cmdline" : {
            "KEYBOARDTYPE" : "pc" , 
            "KEYTABLE" : "us" ,
2.ping
1
2
3
4
5
6
7
8
9
10
MacBookPro:~ hzchenkj$ ansible docker -m ping|more
docker12 | success >> {
    "changed" : false , 
    "ping" : "pong" 
}
docker11 | success >> {
    "changed" : false , 
    "ping" : "pong" 
}
changed  false 是指对服务器状态不会改变
1
2
3
ansible test -m file -a  "src=/etc/fstab dest=/tmp/fstab state=link" 
ansible test -m file -a  "path=/tmp/fstab state=absent"   删除文件
ansible test -m file -a  "path=/tmp/test state=touch" 
4.copy
示例:
1
2
3
ansible test -m copy -a  "src=/etc/ansible/ansible.cfg dest=/etc/foo.conf owner=foo group=foo mode=0644" 
ansible test -m copy -a  "src=/mine/ntp.conf dest=/etc/ntp.conf owner=root group=root mode=644 backup=yes" 
5.command
1
ansible test -a  "/sbin/reboot" 
6.shell
1
2
ansible test -m shell -a  "file.sh >> somelog.log" 
ansible test -m shell -a  "ps -ef|grep tomcat" 
7.service
1
2
3
ansible test -m service -a  "name=httpd state=started enabled=yes" 
ansible test -m service -a  "name=foo pattern=/usr/bin/foo state=started" 
ansible test -m service -a  "name=network state=restarted args=eth0" 
8.cron, /2,……), /2,……), /2,……), /2,……)
1
2
3
4
ansible test -m cron -a  'name="check dirs" hour="5,2" job="ls -alh > /dev/null"' 
ansible test -m cron -a  'name="a job for reboot" special_time=reboot job="/some/job.sh"' 
ansible test -m cron -a  'name="yum autoupdate" weekday="2" minute=0 hour=12 user="root" job="YUMINTERACTIVE=0 /usr/sbin/yum-autoupdate" cron_file=ansible_yum-autoupdate' 
ansilbe test -m cron -a  'cron_file=ansible_yum-autoupdate state=absent' 
9.yum
1
2
3
ansible test -m yum -a  'name=httpd state=latest' 
ansible test -m yum -a  'name="@Development tools" state=present' 
ansible test -m yum -a  'name=http://nginx.org/packages/centos/6/noarch/RPMS/nginx-release-centos-6-0.el6.ngx.noarch.rpm state=present' 
10.user
11.mount
1
2
3
4
ansible test -a  'dd if=/dev/zero of=/disk.img bs=4k count=1024' 
ansible test -a  'losetup /dev/loop0 /disk.img' 
ansible test -m filesystem 'fstype=ext4 force=yes opts=-F dev=/dev/loop0' 
ansible test -m mount 'name=/mnt src=/dev/loop0 fstype=ext4 state=mounted opts=rw' 
12.raw
四、Ansible’s playbooks