ansibleNote

集群自动化运维简单心得:(主管理节点必须是linux服务器,尽量使用root进行管理控制权限)

场景:hadoop集群简单运维(hadoop1-7 10.2.5.28-34)

(hadoop1上)安装ansible 更改配置文件 host信息  /etc/ansible/hosts

#a collection hadoop servers in the [hadoop] group

[hadoop]

#10.2.5.28 hostPerChild=hadoop1

10.2.5.29 hostPerChild=hadoop2

10.2.5.30 hostPerChild=hadoop3

10.2.5.31 hostPerChild=hadoop4

10.2.5.32 hostPerChild=hadoop5

10.2.5.33 hostPerChild=hadoop6

10.2.5.34 hostPerChild=hadoop7

安装完毕后简单命令如下:

ansible all -m ping

ansible all -a “/bin/echo hello”

ansible hadoop -m ping

ansible hadoop -a “/bin/echo hello”

结果中出现 success 即为成功,否则失败

ansible all --list-hosts

ansible hadoop --list-hosts

1、简介

ansible是新出现的自动化运维工具,基于Python开发,集合了众多运维工具(puppet、cfengine、chef、func、fabric)的优点,

实现了批量系统配置、批量程序部署、批量运行命令等功能。ansible是基于模块工作的,本身没有批量部署的能力。

真正具有批量部署的是ansible所运行的模块,ansible只是提供一种框架。主要包括:

(1)、连接插件connection plugins:负责和被监控端实现通信;

(2)、host inventory:指定操作的主机,是一个配置文件里面定义监控的主机;

(3)、各种模块核心模块、command模块、自定义模块;

(4)、借助于插件完成记录日志邮件等功能;

(5)、playbook:剧本执行多个任务时,非必需可以让节点一次性运行多个任务。

2、特性

(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:可实现多级指挥。

3、Ansible配置

配置主机组 /etc/ansible/hosts

配置完主机组之后,可以使用ansible all –m ping, 测试是否配置成功。

主机组配置方法:

显示pong,证明配置成功,可以连接到节点。

使用[]来定义主机组名,使用ansible_ssh_host定义需要部署的节点地址。

方括号[]中是组名,用于对系统进行分类,便于对不同系统进行个别的管理。

把一个组作为另一个组的成员:

可以把一个组作为另一个组的子成员,以及分配变量给整个组使用. 这些变量可以给 /usr/bin/ansible-playbook 使用,但不能给 /usr/bin/ansible 使用:

[atlanta]

host1

host2

[raleigh]

host2

host3

[southeast:children]

atlanta

raleigh

你可能感兴趣的:(ansibleNote)