ansible架构解析
用户通过ansible去管理各个主机,那么ansible就是我们所说的主控端,后面的Host为被控端。
在控制主机时,ansible是如何知道哪些主机是被自己控制的呢?
这就需要一个Host Inventory(主机清单),用于记录ansible可以控制网络中的哪些主机。另外,要配置和管理这些主机,可以采用两种方式,一种是单一的命令实现,另外一种也可以使用palybook实现。单一的命令模式是采用不同的模块进行管理,一个模块类似于一些管理的命令,如top,ls,ping等等,适用于临时性的操作任务。如果需要执行一些例行性或经常性的操作,则需要采用playbook的方式,playbook类似于一个脚本,将多个模块按一定的逻辑关系进行组合,然后执行。ansible还支持一些插件,如邮件、日志等,在和远程主机通信时,也会采用类似的连接插件,这里使用则是SSH协议的插件进行通信。
ansible主要组成部分
1)命令执行来源:
ANSIBLE PLAYBOOKS :任务剧本,编排定义ansible任务急的配置文件,有Ansible顺序执行,通常为json格式的YAML文件INBENTORY:Ansible管理主机的清单/etc/anaible/hostsMODULES:Ansible的执行命令的功能模块,多数为内置核心模块,也可以自定义PLUGINS:模块功能补充,比如链接类型插件、循环插件、变量插件、过滤插件等,不常用API:供第三方程序调用的应用程序编程接口ANSIBLE:组合INVENTORY API MODUES PLUGINS的绿框,可以理解为Ansible的命令工具,其为核心执行工具
2)利用ansible实现管理的方式
Ad-Hoc即ansible命令,主要用于临时命令场景ansible-playbook主要用户长期规划好的,大型项目的场景,需要提前规划
3)Ansile-playbook执行过程
将已有编排好的任务急写入Ansible-playbook通过ansible-playbook命令分拆任务急至逐条ansible命令,按照预定规则执行
4)Ansible主要操作对象
Hosts主机Networking网络设备
5)注意事项
执行ansile的主机一般称为主控端,中控,master或堡垒机主控端python版本需要2.6以上被控端python版本需要2.4以上,小于2。4需要安装python-simplejson被控端如开启selinux需要安装libselinux-pythonwindows端不能作为主控端