自动化运维:ansible及模块功能解析

ansible是什么

ansible是新出现的自动化运维工具,基于Python开发,集合了众多运维工具(puppet、cfengine、chef、func、fabric)的优点,实现了批量系统配置、批量程序部署、批量运行命令等功能。

ansible工作模式

ansible是基于模块工作的,本身没有批量部署的能力。真正具有批量部署的是ansible所运行的模块,ansible只是提供一种框架。主要包括:

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

ansible怎么样

(1) no agents:不需要在被管控主机上安装任何客户端;
(2) no server:无服务器端,使用时直接运行命令即可;
(3) modules in any languages:基于模块工作,可使用任意语言开发模块;
(4) yaml,not code:使用yaml语言定制剧本playbook;
(5) ssh by default:基于SSH工作;
(6) strong multi-tier solution:可实现多级指挥。

ansible的优点

(1) 轻量级,无需在客户端安装agent,更新时,只需在操作机上进行一次更新即可;
(2) 批量任务执行可以写成脚本,而且不用分发到远程就可以执行;
(3) 使用python编写,维护更简单,ruby语法过于复杂;
(4) 支持sudo。

部署ansible

一、部署环境

master :20.0.0.11
node1:20.0.0.12
node2:20.0.0.13

二、安装epel源和ansible

#在yum仓库下导入epel.repo和CentOS7-Base-163.repo  
[root@master ~]# cd /etc/yum.repos.d/
[root@master yum.repos.d]# ls
backup                 epel.repo         epel-testing.repo  repos.bak
CentOS7-Base-163.repo  epel.repo.rpmnew  local.repo
[root@master yum.repos.d]# yum -y install epel-release
#报错:获取gpg密钥失败...
[root@master yum.repos.d]#vim epel.repo
把gpgcheck=1改成0,并注释掉gpgkey。
[root@master yum.repos.d]# yum -y install ansible
[root@master ~]# ansible --version

三、安装tree

[root@master ~]# yum -y install tree

[root@master ~]# tree /etc/ansible
#树状结构展示文件夹
/etc/ansible
├── ansible.cfg #ansible的配置文件
├── hosts #ansible的主仓库,用于存储需要管理的远程主机的相关文件
└── roles #角色

四、配置主机清单

[root@master ~]# cd /etc/ansible
[root@master ansible]# vi hosts
#末尾添加
[webserver]   #对应node1
20.0.0.12   
[mysql]       #对应node2
20.0.0.13

五、配置密钥,免交互

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值