一、了解ansible
1、ansible 是什么
ansible是新出现的自动化运维工具,基于Python开发,集合了众多运维工具(puppet、chef、func、 fabric)的优点,实现了批量系统配置、批量程序部署、批量运行命令等功能。
ansible是基于 paramiko 开发的,并且基于模块化工作,本身没有批量部署的能力。真正具有批量部署的 是ansible所运行的模块,ansible只是提供一种框架。ansible不需要在远程主机上安装client/agents, 因为它们是基于ssh来和远程主机通讯的。
2、 ansible 特点
部署简单,只需在主控端部署Ansible环境,被控端无需做任何操作;
默认使用SSH协议对设备进行管理;
有大量常规运维操作模块,可实现日常绝大部分操作;
配置简单、功能强大、扩展性强;
通过Playbooks来定制强大的配置、状态管理;
轻量级,无需在客户端安装agent,更新时,只需在操作机上进行一次更新即可
二、安装
yum install ansible* -y
三、配置
# vi /etc/ansible/ansible.cfg
[defaults]
inventory = /etc/ansible/hosts #资源清单inventory文件的位置
library = /usr/share/my_modules/ #存放模块的目录,支持多个目录,用:隔开
forks = 5 #并发连接数,默认为5
sudo_user = root #设置默认执行命令的用户
remote_port = 22 #指定连接被管节点的管理端口,默认为22端口, 建议修改,能够更加安全
ask_pass = True #是否需要密码
host_key_checking = False #设置是否检查SSH主机的密钥
timeout = 10 #设置SSH连接的超时时间,单位为秒
log_path = /var/log/ansible.log #指定一个存储ansible日志的文件(默认不记录 日志)
四、添加 主机清单
# vi /etc/ansible/hosts
[linux1]
linux1.sy.com
[srv]
linux2.sy.com linux3.sy.com
五、测试
# ansible srv -m ping
linux2.sy.com | SUCCESS => {
"ansible_facts": {
"discovered_interpreter_python": "/usr/libexec/platform-python"
},
"changed": false,
"ping": "pong"
}