Linux中的Ansible详解

ansible简介:

ansible是新出现的自动化运维工具,基于Python开发,
集合了众多运维工具(puppet、cfengine、chef、func、fabric)的优点,
实现了批量系统配置、批量程序部署、批量运行命令等功能。
ansible是基于模块工作的,本身没有批量部署的能力。
真正具有批量部署的是ansible所运行的模块,ansible只是提供一种框架。
主要包括:

  1. 连接插件connection plugins:负责和被监控端实现通信;
  2. host inventory:指定操作的主机,是一个配置文件里面定义监控的主机;
  3. 各种模块核心模块、command模块、自定义模块;
  4. 借助于插件完成记录日志邮件等功能;
  5. playbook:剧本执行多个任务时,非必需可以让节点一次性运行多个任务。

Ansible服务专用术语对照表

术语 中文叫法 含义
Control node 控制节点 指的是安装了Ansible服务的主机,也被称为Ansible控制端,主要是用来发布运行任务、调用功能模块,对其他主机进行批量控制。
Managed nodes 受控节点 指的是被Ansible服务所管理的主机,也被称为受控主机或客户端,是模块命令的被执行对象。
Inventory 主机清单 指的是受控节点的列表,可以是IP地址、主机名称或者域名。
Modules 模块 指的是上文提到的特定功能代码,默认自带有上千款功能模块,在Ansible Galaxy有超多可供选择。
Task 任务 指的是Ansible客户端上面要被执行的操作。
Playbook 剧本 指的是通过YAML语言编写的可重复执行的任务列表,把常做的操作写入到剧本文件中,下次可以直接重复执行一遍。
Roles 角色 从Ansible 1.2版本开始引入的新特性,用于结构化的组织Playbook,通过调用角色实现一连串的功能。

ansible的架构:

连接其他主机默认使用ssh协议
在这里插入图片描述
在这里插入图片描述

Ansible主要组成部分

  1. ANSIBLE PLAYBOOKS:任务剧本(任务集),编排定义Ansible任务集的配置文件,由Ansible顺序依次执行,通常是JSON格式的YML文件
  2. INVENTORY:Ansible管理主机的清单 /etc/anaible/hosts
  3. MODULES: Ansible执行命令的功能模块,多数为内置核心模块,也可自定义
  4. PLUGINS: 模块功能的补充,如连接类型插件、循环插件、变量插件、过滤插件等,该功能不常用
  5. API: 供第三方程序调用的应用程序编程接口
  6. ANSIBLE: 组合INVENTORY、API、MODULES、PLUGINS的绿框,可以理解为是ansible命令工具,其为核心执行工具

Ansible命令执行来源:

 USER,普通用户,即SYSTEM ADMINISTRATOR
 CMDB(配置管理数据库) API 调用
 PUBLIC/PRIVATE CLOUD API调用  (公有私有云的API接口调用)
 USER-> Ansible Playbook -> Ansibile

利用ansible实现管理的方式:

  Ad-Hoc 即ansible单条命令,主要用于临时命令使用场景
 Ansible-playbook 主要用于长期规划好的,大型项目的场景,需要有前期的规划过程

Ansible-playbook(剧本)执行过程

将已有编排好的任务集写入Ansible-Playbook
通过ansible-playbook命令分拆任务集至逐条ansible命令,按预定规则逐条执行

Ansible主要操作对象

  1. HOSTS主机
  2. NETWORKING网络设备
    注意事项:
    1 . 执行ansible的主机一般称为主控端,中控,master或堡垒机
    2 . 主控端Python版本需要2.6或以上
    3 . 被控端Python版本小于2.4需要安装python-simplejson
    4 . 被控端如开启SELinux需要安装libselinux-python
    5 . windows不能做为主控端
    6 . ansible不是服务,不会一直启动,只是需要的时候启动

猜你喜欢

转载自blog.csdn.net/weixin_46329906/article/details/116946153