首页 游戏 软件 资讯 排行榜 专题
首页
业界动态
SaltStack 入门指南:运维自动化的新手必备

SaltStack 入门指南:运维自动化的新手必备

热心网友
63
转载
2026-04-22

SaltStack:让大规模运维变得轻松高效

在日常运维工作中,面对成百上千台服务器的批量命令执行、应用部署和状态维护,团队难免会感到压力巨大。有没有一款工具,能像一位高度自律的指挥官,确保整个服务器集群整齐划一、高效运转?答案是肯定的。

免费影视、动漫、音乐、游戏、小说资源长期稳定更新! 👉 点此立即查看 👈

今天我们要深入探讨的,正是这样一款利器:SaltStack,业内常简称为Salt。它是一个基于Python开发的开源基础设施管理平台,核心能力在于远程执行和配置管理。简单来说,它能帮你实现:批量执行命令、自动化部署应用、确保配置的一致性,从而从根本上提升整个运维体系的效率。

如果你对Ansible这类工具已有接触,那么理解Salt的核心思想会快很多,它们的目标相似,但哲学和实现方式各有千秋。

一、Salt vs Ansible:如何选择?

简单来说,选择取决于你的场景规模和对性能的要求。如果你需要管理的是一个庞大且需要高并发控制的服务器集群,Salt基于ZeroMQ的通信架构通常能带来更高的效率。相反,对于服务器数量不多、追求快速上手的团队,Ansible基于SSG的无袋里模式可能初期会更友好。

二、Salt 核心概念:掌握这几项就够了

要玩转Salt,首先得理解它的几个核心术语,这就像是学习一门新语言的语法基础:

  • Master: 控制中心,所有命令和配置都从这里发起和分发。
  • Minion: 受控的客户端节点,忠诚地执行来自Master的指令。
  • Grains: 描述Minion本身静态信息的数据,比如操作系统、IP地址、CPU型号等,用于识别和定位节点。
  • Pillar: 存储 Minion 专属或敏感配置信息的地方,比如密码、密钥,它与Grains互补,一个静态一个动态/安全。
  • SLS 文件: Salt State文件的简称,用于描述系统应该处于何种状态,定义了配置管理的流程和步骤,其角色类似于Ansible中的Playbook。

一个典型的Salt架构,其通信流程可以这样直观理解:

+---------+      |  Master |      +----+----+           |           | ZeroMQ           |      +----+----+      |  Minion |      +---------+

三、Salt 核心配置文件:从安装到信任

理论懂了,接下来就是实战。从安装到建立Master与Minion之间的信任关系,是迈出的第一步。

1. master和minion安装

以主流的CentOS系统为例,安装过程非常直接。首先配置好yum源,然后分别安装对应的服务端和客户端包。

wget -O /etc/yum.repos.d/CentOS-Base.repo https://mirrors.aliyun.com/repo/Centos-7.repo
wget -O /etc/yum.repos.d/epel.repo https://mirrors.aliyun.com/repo/epel-7.repo
yum clean all #清空缓存
yum makecache #生成yum缓存
# master 安装salt-master
yum install salt-master -y
# sla ve 安装salt-minion
yum install salt-minion -y
# 启动
systemctl start salt-minion
systemctl start salt-master

2. 配置与密钥认证

安装完成后,关键的配置环节来了。Master的核心配置文件是 /etc/salt/master,其中几个基础参数需要关注:

[root@master ~]# grep -v ^# /etc/salt/master|grep -v ^$
interface: 0.0.0.0  #绑定到本地的0.0.0.0地址
publish_port: 4505  #管理端口,命令发送
user: root      #运行salt进程的用户
worker_threads: 5  #salt运行线程数,线程越多处理速度越快,不要超过cpu个数
ret_port: 4506  #执行结果返回端口
pidfile: /var/run/salt-master.pid #pid文件位置
log_file: /var/log/salt/master  #日志文件地址
#自动接收minion的key
auto_accept: False

Minion端的配置文件是 /etc/salt/minion,首要任务是指定Master是谁:

master: 10.xx.xx.xx  # 指定Salt Master 地址(此处为示例 IP)
master_port: 4506  # Minion与Master 通信端口,默认 4506
# 使用 TCP 作为 Minion 与 Master 的底层传输方式
# 默认使用 "zeromq",但在国产系统或安全要求场景,TCP 更稳定
transport: tcp
# Master 发布任务(事件总线)的端口
publish_port: 4505
# Minion 执行任务时使用的工作线程数
# 数值越高,可以处理更多并发任务
worker_threads: 10
# Minion 向 Master 返回执行结果失败时,每隔多少秒重试一次
return_retry_timer: 6
# 重试间隔最大值,用于限制重试时间的增长
return_retry_timer_max: 2000
# 返回结果的最大重试次数
return_retry_tries: 30
# root 用户可执行系统级任务,生产环境较常用
user: root
# 设置日志输出的级别:
# debug | info | warning | error
log_level: info
# 日志时间格式(仅日期)
log_datefmt: '%Y-%m-%d %H:%M:%S'
# 控制台日志输出格式
# 包含日期、毫秒、模块、函数、行号、日志等级等信息
log_fmt_console: '%(asctime)s,%(msecs)03d [%(name)s] %(funcName)s  %(lineno)d [%(levelname)s] %(message)s'
# 日志文件输出格式(结构同上)
log_fmt_logfile: '%(asctime)s,%(msecs)03d [%(name)s] %(funcName)s  %(lineno)d [%(levelname)s] %(message)s'
# DNS 名称解析失败时的重试次数(默认一般为 1)
retry_dns: 3

配置完成后启动服务,Salt的安全机制便开始运作。Minion启动后会主动连接Master并提交自己的公钥,但这并不意味着立即获得信任。此时,需要管理员在Master上手动审核并接受这个“新成员”。

使用 salt-key -L 命令可以查看所有密钥状态:

Accepted Keys:
Denied Keys:
Unaccepted Keys:
sla ve
Rejected Keys:

如果看到目标Minion(例如名为sla ve)出现在“Unaccepted Keys”列表中,说明连接已建立,但等待授权。这时,使用 salt-key -a sla ve 命令接受该密钥,双方之间加密的信任通道才算正式打通。

这里顺便列举几个 salt-key 的常用命令,方便管理:

[root@linux-node1 ~]# salt-key -L
Accepted Keys:  #已经接受的key
Denied Keys:    #拒绝的key
Unaccepted Keys:#未加入的key
Rejected Keys:#吊销的key
#常用参数
-L  #查看KEY状态
-A  #允许所有
-D  #删除所有
-a  #认证指定的key
-d  #删除指定的key
-r  #注销掉指定key(该状态为未被认证)
#在master端/etc/salt/master配置auto_accept: True   #如果对Minion信任,可以配置master自动接受请求

三、Salt 基础语法:从执行到配置

建立了信任,就可以发号施令了。Salt的操作主要分为两大类:远程执行和状态管理。

1. 执行模块(Execution Module)

这相当于 Ansible 中的 ad-hoc 命令,用于实时、一次性的远程操作。例如:

salt '*' test.ping            # 测试所有 Minion 是否在线
salt '*' cmd.run 'uptime'     # 查看所有节点的系统负载
salt '*' pkg.install nginx    # 在所有节点上安装 nginx
salt '*' service.start nginx  # 启动所有节点的 nginx 服务

2. 状态模块(State Module)

这是Salt进行配置管理的核心,通过声明式的SLS文件,描述系统最终应该达到的状态,类似于Ansible的Playbook。一个简单的示例:

install_nginx:
  pkg.installed:
    - name: nginx

start_nginx:
  service.running:
    - name: nginx
    - enable: True
    - require:
      - pkg: install_nginx

3. 文件管理

自动化运维离不开文件的分发与管理。Salt可以方便地创建目录、部署文件,甚至使用Jinja2模板动态生成配置文件:

# 创建目录
create_web_dir:
  file.directory:
    - name: /usr/share/nginx/html
    - user: root
    - group: root
    - mode: 755

# 部署模板文件
/usr/share/nginx/html/index.html:
  file.managed:
    - source: salt://nginx/index.html.jinja
    - template: jinja

4. 条件判断

在实际部署中,往往需要对不同的节点执行不同的操作。这时,结合Grains信息和Jinja2模板的条件判断就非常有用:

{% if grains['role'] == 'web' %}
# 这部分配置只会应用到 role 为 'web' 的节点上
{% endif %}

掌握了以上这些基础概念、安装配置和核心语法,你已经具备了上手SaltStack进行实战部署的能力。接下来,就是将这些知识应用到具体的项目中,去体验自动化运维带来的秩序与效率了。

来源:https://www.51cto.com/article/834505.html
免责声明: 游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。

最新APP

宝宝过生日
宝宝过生日
应用辅助 04-07
台球世界
台球世界
体育竞技 04-07
解绳子
解绳子
休闲益智 04-07
骑兵冲突
骑兵冲突
棋牌策略 04-07
三国真龙传
三国真龙传
角色扮演 04-07

热门推荐

腾讯:QQ 将全面接入微信小程序,建议开发者尽快迁移降低维护成本
手机教程
腾讯:QQ 将全面接入微信小程序,建议开发者尽快迁移降低维护成本

腾讯生态整合新动向:QQ全面接入微信小程序 7月1日,腾讯QQ小程序开发者平台发布了一项重要更新。核心内容是,为了帮助开发者降低双端开发与维护成本,QQ将全面接入微信小程序体系。这意味着,未来用户可以直接在QQ内搜索并打开微信小程序。 对于现有的存量QQ小程序,此次调整并未“一刀切”。它们目前仍可正

热心网友
04.22
天玑9600/9600 Pro双芯齐发:5GHz主频史无前例 硬刚高通骁龙8E6
手机教程
天玑9600/9600 Pro双芯齐发:5GHz主频史无前例 硬刚高通骁龙8E6

下半年芯片市场巅峰对决提前揭幕 今年下半年,全球芯片市场的战火将空前炽热。两位重量级选手——联发科与高通,已经准备好亮出各自的王牌。天玑9600系列与骁龙8E6系列,这两大迭代旗舰平台的正面交锋,注定会成为今年科技行业最值得关注的戏码。 双芯策略:精准卡位旗舰市场 有意思的是,联发科这次玩了个新花样

热心网友
04.22
微信好友申请为何能通过搜索qq号添加
手机教程
微信好友申请为何能通过搜索qq号添加

在当今数字化社交的时代,微信已成为人们日常沟通交流的重要工具。不少人都发现,微信好友申请居然可以通过搜索 qq 号来添加,这背后有着诸多有趣的原因和便利之处。 一、社交关系的延续与拓展 要知道,微信与QQ同属腾讯旗下,两者之间存在着千丝万缕的联系。很多用户的社交关系其实根植于QQ时代,那些好友列表里

热心网友
04.22
高德地图如何更改定位
手机教程
高德地图如何更改定位

高德地图如何更改定位?三种方法详解及注意事项 无论是日常通勤、外出旅行还是朋友相聚,高德地图已经成了我们依赖的“导航神器”,精准定位和路线规划是其核心功能。不过,现实场景有时会有点特殊——比如,你可能需要模拟一个位置来测试应用,或者在某个游戏中“签到”,又或者只是想和朋友开个无伤大雅的玩笑。这个时候

热心网友
04.22
巧学宝app如何绑定手机号
手机教程
巧学宝app如何绑定手机号

巧学宝App绑定手机号全程指南 在巧学宝App上完成手机号绑定,是解锁其完整功能的关键一步。这个看似简单的操作,能为你后续的学习之旅带来不少实实在在的便利。那么,该如何快速搞定呢?下面这张流程图,能帮你一眼看清完整的操作路径。 第一步:进入个人中心 首先,打开你的巧学宝App。进入主界面后,注意力可

热心网友
04.22