一、简介
Puppet, SaltStack, Chef, Ansible都是服务器批量运维常用工具,其中Ansible最大的亮点在于”无客户端、简单易用和日志集中控管。”,不用帮每台机器 (instance) 预载 agent,只要有 SSH 和 Python 就可以。,本文介绍一下Ansible的基本使用。
二、结构
1、当 Control Machine (主控端) 可以用 SSH 连上 Managed node,且被连上的机器里有预载 Python 时,Ansible 就可以运作了!
2、Managed node 则是被 Ansible 操纵的机器。
三、在Control Machine中安装Ansible
#Ubuntu (Apt)
#安装 add-apt-repository 必要套件。
sudo apt-get install -y python-software-properties software-properties-common
#使用 Ansible 官方的 PPA 套件来源。 sudo add-apt-repository -y ppa:ansible/ansible; sudo apt-get update
#安装 Ansible。
sudo apt-get install -y ansible
#CentOS (Yum)
#新增 epel-release 第三方套件来源。 sudo yum install -y epel-release
#安装 Ansible。
sudo yum install -y ansible
#macOS (Homebrew)
#请先安装 homebrew,已安装者请略过。 /usr/bin/ruby -e "(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)"
#安装 Ansible。 brew install ansible
#Python (Pip)
#Ansible 近来的释出速度很快,若想追求较新的版本可改用 Pip 的方式进行安装,较不建议初学者使用。
#需请先安装 pip,已安装者请略过。
# Debian, Ubuntu
sudo apt-get install -y python-pip
# CentOS sudo yum install -y python-pip
# macOS
sudo easy_install pip
#升级 pip。 sudo pip install -U pip
#安装 Ansible。
$ sudo pip install ansible
四、在Managed node 中安装Python和SSH(一盘系统都自带了,因此可忽略此步骤)
#Ubuntu.
sudo apt-get install -y openssh-server python2.7
#CentOS. sudo yum install -y openssh-server python
五、修改配置
1、安装好Ansible后,我们可以在/etc/ansible目录下看到配置文件。修改:ansible.cfg,例如:
inventory = hosts
remote_user = root
host_key_checking=False
2、修改/etc/ansible/hosts文件,参考下图,可以使用如下变量:ansible_ssh_host、ansible_ssh_port、ansible_ssh_user、ansible_ssh_pass、ansible_ssh_private_key_file。

例如我测试使用的配置:

六、测试执行命令
如:执行:
$ ansible localhost -m command -a 'echo Hello World.'
localhost | SUCCESS | rc=0 >>
Hello World.

七、测试playbook
1、在/etc/ansible目录下,执行:vim ./helloworld.yml 内容如下:
---
- name: say 'hello world'
hosts: huawei
tasks:
- name: echo 'hello world'
command: echo 'hello world'
register: result
- name: print stdout
debug: var=result
2、执行:ansible-playbook ./helloworld.yml

八、模板测试

1、新建template文件,vi helloworld2.txt.j2,内容如下:
Hello "{{ dynamic_world }}"
2、新建playbook文件,vi helloworld2.yml,内容如下:
---
- name: Play the template module
hosts: all
vars:
dynamic_world: "World"
tasks:
- name: generation the hello_world.txt file
template:
src: helloworld2.txt.j2
dest: /tmp/hello_world.txt
- name: show file context
command: cat /tmp/hello_world.txt
register: result
- name: print stdout
debug:
msg:
3、执行playbook:
ansible-playbook helloworld2.yml

4、指定环境变量
ansible-playbook helloworld2.yml -e "dynamic_world=SongXingzhu"
