Published on

SaltStack实战之SaltStack快速入门

Authors
  • avatar
    Name
    老杨的博客
    Twitter

SaltStack 实战之 SaltStack 快速入门

[TOC]

1. SaltStack 介绍

Salt,一种全新的基础设施管理方式,部署轻松,在几分钟内可运行起来,扩展性好,很容易管理上万台服务器,速度够快,服务器之间秒级通讯。 SaltStack 是使用 Python 语言开发,同时提供 Rest API 方便二次开发以及和其它平台进行集成。 Salt 底层采用动态的连接总线, 使其可以用于编配, 远程执行, 配置管理等等。 其它详细介绍:http://docs.saltstack.cn/topics/index.html

1.1 SaltStack 常用网址

官方网站:http://www.saltstack.com 官方文档:http://docs.saltstack.com GitHub:https://github.com/saltstack 中国 SaltStack 用户组:http://www.saltstack.cn

1.2 SaltStack 运行方式

* Local
* Master/Minion
* Salt SSH

1.3 SaltStack 三大功能

* 远程执行
* 配置管理
* 云管理

Salt 对于常用操作系统都支持。windows 不支持 Slat-master。

2. SaltStack 部署

环境:CentOS6 及以上版本 安装方式:推荐用 yum 如果安装失败,可先执行 yum -y update python 再执行 yum -y install salt-master salt-minion 安装教程详细介绍:http://docs.saltstack.cn/topics/installation/index.html#installation

2.1 SaltStack master 配置

vim /etc/salt/master # 修改interface配置为0.0.0.0

interface: 0.0.0.0

配置文件其它参数详细介绍:http://docs.saltstack.cn/ref/configuration/master.html

2.2 SaltStack minion 配置

vim /etc/salt/minion # 修改master配置为master主机IP

master: 10.1.0.111

配置文件其它参数详细介绍:http://docs.saltstack.cn/ref/configuration/minion.html

2.3 SaltStack 认证

[root@salt-master111 ~]# salt-key -A
[root@salt-master111 ~]# salt-key -L
Accepted Keys:
salt-master111
Denied Keys:
Unaccepted Keys:
Rejected Keys:
[root@salt-master111 ~]#

2.4 saltsatck 远程执行

[root@salt-master111 ~]# salt 'salt-master111' cmd.run 'uptime'
salt-master111:
     11:04:55 up 202 days,  1:25,  1 user,  load average: 0.11, 0.15, 0.20
[root@salt-master111 ~]# salt 'salt-master111' test.ping
salt-master111:
    True
[root@salt-master111 ~]#

以上的cmdtest是模块,pingrun是其相应模块的”功能函数”。

2.5 saltsatck 配置管理

Salt 使用 State 模块文件进行配置管理,使用 YAML 编写,以.sls 结尾。 了解 salt state:http://docs.saltstack.cn/topics/tutorials/starting\_states.html

2.5.1 修改 master 配置

vim /etc/salt/master # 修改 file_roots 配置如下

file_roots:
  base:
    - /srv/salt

修改后,重启 master 服务。

service salt-master restart

2.5.2 创建 top.sls 文件

创建一个 top.sls 文件,这个也是入口文件,也就是说,你执行相关命令的时候,会先检测这个文件,这文件提供了其它文件的映射,可以用于作为其它服务器的基础配置文件。 vim /srv/salt/top.sls

base:
  '*':
    - apache
    - user.useradd
    - user.users
    - user.userpasswd
    - user.userdel
    - user.sudoadd
    - user.groupadd
    - user.groupdel:

说明: base 表示基础入口; '*'表示应用到所有 minion; -后接子 sls 配置文件,不需要写文件后缀,.前表示文件夹;

2.5.3 创建子 sls 文件

vim /srv/salt/apache.sls

apache-service:
  pkg.installed:
    - names:
      - httpd
      - httpd-devel
    service.running:
      - name: httpd
      - enable: True

2.5.4 执行生效

执行如下命令,apache 服务则会自动安装和启动。 salt 'salt-master111' state.highstate

其它详细文档:http://docs.saltstack.cn/topics/states/index.html