天天看点

自动化运维工具Saltstack学习

自动化运维工具Saltstack学习

1.简介:

Saltstack 是一个开源的工具用来管理你的基础架构,可轻松管理成千上万台服务器。

支持:

Fedora

RedHat     Enterprise Linux / Centos (EPEL 5, EPEL 6)

Ubuntu (PPA)

Arch (AUR)

FreeBSD

Gentoo

Debian (sid)

Debian     (experimental)

2.物理环境

服务器角色

主机名

ID

OS

IP

组名称

master

master.puppet.net

默认

Centos6.4_64

192.168.1.191

minion1

master.puppet.com

192.168.1.102

magme

minion2

slave.puppet.net

192.168.1.192

magme/bermasde

3.配置环境。

修改主机名及/etc/hosts文件,使其能够相互解析和ping通,这只是测试用的,真实线上的环境一般都用DNS做解析。

修改主机名: hostname master.puppet.net

vim/etc/sysconfig/network,内容如下:

HOSTNAME= master.puppet.net

在hosts中加入如下配置:

192.168.1.102 master.puppet.com

192.168.1.191 master.puppet.net

192.168.1.192 slave.puppet.net

4.安装Saltstack

服务器master上:yum -y install salt-master

客户端minion上:yum -y install salt-minion

5.Saltstack配置

服务器master上: vim /etc/salt/master

# 设置master上侦听的IP地址

interface:192.168.1.191(此处可修改也可不改)

客户端minion上,vim /etc/salt/minion

#添加master IP地址和minion ID号

master:192.168.1.191

id:可随意填写。(可修改也可不改)

6.启动Saltstack服务

#saltstack master启动和设置开机自动启动

/etc/init.d/salt-master start

chkconfig salt-master on

#Saltstck minion启动和设置开机自动启动

/etc/init.d/salt-minion start

chkconfig salt-minion on

7.Saltstack master认证Minion KEY

Saltstack使用公共密钥加密来保证master和minions的安全通信。安装的时候Salt自动生成这些证书,但需要在master端验证minion的证书来确认master和minion之间是授信的。

#salt-key -L查看所有没有认证,通过认证,拒绝认证的证书。

[root@master puppet]# salt-key list

Accepted Keys:

Unaccepted Keys:

Rejected Keys:

#证书认证用命令salt-key-a id

[root@SaltMast ~]# salt-key -a slave.puppet.net

The following keys are going tobe accepted:

Proceed? [n/Y] y

Key for minion slave.puppet.net accepted.

<a href="http://s3.51cto.com/wyfs02/M02/00/00/wKiom1LFJkSi4zcrAAAwhc3i_nw315.jpg" target="_blank"></a>

[root@SaltMast ~]# salt-key -a master.puppet.com

The following keys are going to be accepted:

Key for minion master.puppet.com accepted.

<a href="http://s3.51cto.com/wyfs02/M02/00/00/wKioL1LFJrrD3l7IAAAyTjL4vXE508.jpg" target="_blank"></a>

#查看认证通过的证书

[root@SaltMast ~]# salt-key list

<a href="http://s3.51cto.com/wyfs02/M01/00/00/wKiom1LFJkPAWRM2AAAkY_mhRVc728.jpg" target="_blank"></a>

8.Saltstack测试

1) 通信测试:Saltstack证书认证通过以后,就可以进行通信,在master通过test.ping命令来测试它们之间的连接。通配符"*"代表了所有minion。

<a href="http://s3.51cto.com/wyfs02/M00/00/00/wKiom1LFJkTzNm9vAAAkvQJAFpA976.jpg" target="_blank"></a>

2)执行命令:在Saltstackmaster端通过执行"salt id 系统命令"来返回minion执行结果。

9.Saltstack分组及其测试

1)为什么要分组?安装配置相同或者相近的服务器可分为一组,方便批量安装和管理,编辑 /etc/salt/master 添加如下内容,每个组可以有N多服务,每个服务器用逗号分隔。

nodegroups:

magme:'[email protected],slave.puppet.net'

bermasde: 'slave.puppet.net'

<a href="http://s3.51cto.com/wyfs02/M02/00/00/wKiom1LFJkPwWFL2AAA4FKW9eJc600.jpg" target="_blank"></a>

2)分组测试

<a href="http://s3.51cto.com/wyfs02/M00/00/00/wKiom1LFJuPzAox-AABr02cgZbQ078.jpg" target="_blank"></a>

TheEnd .

总结:SaltStack安装和基本的配置已经完成,可以通过SaltStack批量执行系统命令,包括重启系统,重启服务,查看系统负载,添加/删除用户等等。SaltStackd在集群环境,有大量服务器的公司用的较多。功能之强大,不得不说“牛B”,为运维人员省了不少事。

本文转自pizibaidu 51CTO博客,原文链接:http://blog.51cto.com/pizibaidu/1347764,如需转载请自行联系原作者