ansible是新出现的自动化运维工具,基于Python开发,集合了众多运维工具(puppet、cfengine、chef、func、fabric)的优点,实现了批量系统配置、批量程序部署、批量运行命令等功能。
ansible是基于模块工作的,本身没有批量部署的能力。真正具有批量部署的是ansible所运行的模块,ansible只是提供一种框架。主要包括:
(1)、连接插件connection plugins:负责和被监控端实现通信;
(2)、host inventory:指定操作的主机,是一个配置文件里面定义监控的主机;
(3)、各种模块核心模块、command模块、自定义模块;
(4)、借助于插件完成记录日志邮件等功能;
(5)、playbook:剧本执行多个任务时,非必需可以让节点一次性运行多个任务。
只需要在服务端上安装好ansible即可使用
yum install ansible -y
# 查看ansible版本
yum info ansible
# 查看有哪些模块
ansible-doc -l
安装及程序环境
程序:
ansible
ansible-playbook
ansible-doc
配置文件:
/etc/ansible/ansible.cfg
主机清单
/etc/ansible/hosts
插件目录:
/usr/share/ansible_plugins/
前提条件:1、做好免密 2、在/etc/ansible/hosts定义好对应host信息
# 将本地的文件复制到对应host中
ansible host组 -m copy -a "src=$本地路径 dest=$远程主机路径"
# 在远程host上执行命令
ansible hosts组 -m shell -a "/usr/bin/ifconfig"
前提条件:1、无需免密,无需定义host信息 2、熟悉playbook语法
创建一个hosts文件,记录好hosts信息
[ceshi]
192.168.200.160 ansible_connection=ssh ansible_username=root ansible_port=22 ansible_ssh_pass=123456
查看通过shell模块获取目标主机信息:
- hosts: ceshi
remote_user: root
tasks:
- name: ip
shell: /usr/sbin/ifconfig &>> /var/log/messages
执行结果如下:
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。