百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

基于centos7部署saltstack服务器管理自动化运维平台

itomcoil 2025-07-06 12:59 2 浏览

概述

SaltStack是一个服务器基础架构集中化管理平台,具备配置管理、远程执行、监控等功能,基于Python语言实现,结合轻量级消息队列(ZeroMQ)与Python第三方模块(Pyzmq、PyCrypto、Pyjinjia2、python-msgpack和PyYAML等)构建。

通过部署SaltStack,我们可以在成千万台服务器上做到批量执行命令,根据不同业务进行配置集中化管理、分发文件、采集服务器数据、操作系统基础及软件包管理等,SaltStack是运维人员提高工作效率、规范业务配置与操作的利器。

下面介绍一下saltstack的部署及使用教程。

官网:http://docs.saltstack.cn/

环境:




一、yum安装saltstack

1、配置epel源

salt软件包需要epel源的支持,那么下载

for i in /etc/yum.repos.d/*.repo;do cp $i ${i%.repo}.bak;done
rm -rf /etc/yum.repos.d/*.repo
wget -O /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-7.repo
wget -O /etc/yum.repos.d/epel.repo http://mirrors.aliyun.com/repo/epel-7.repo
yum clean all && yum makecache


2、安装salt包

--先安装epel源
yum install epel-release -y 
--安装salt-master
yum install salt-master -y
--安装salt-minion
yum install salt-minion -y
--其他
yum install salt-ssh -y
yum install salt-syndic -y
yum install salt-cloud -y

3、开机自启动

--salt-master开机自启
systemctl enable salt-master.service 
systemctl start salt-master.service 
systemctl status salt-master.service 

--salt-minion开机自启
systemctl enable salt-minion.service 
systemctl start salt-minion.service 
systemctl status salt-minion.service



二、saltstack配置

1、管理端配置

1.1、修改hosts文件解析

# vim /etc/hosts
#####################saltstack#########################
xx.xx.xx.3   xxxsalt-master
#prod
xx.xx.xx.134  xxxxsalt-minion

1.2、修改salt-master配置文件

# cat /etc/salt/master |grep -v '^#'|grep -v '^#39;
==============================================================================
interface: salt-master-IP        #监听地址改成主机IP
publish_port: 4505             #4505消息发布端口(所有minion在4505上保持established)
ret_port: 4506                 #salt客户端和服务端通信使用4506端口,内容传输使用消息队列
auto_accept: True              #证书认证
file_roots:                    #开启站点目录
  base:
    - /srv/salt/
  prod:
    - /srv/salt/prod/services
    - /srv/salt/prod/states
  uat:
    - /srv/salt/uat/services
    - /srv/salt/uat/states
pillar_roots:
  base:
    - /srv/pillar
pillar_opts: True              #开启pillar功能,同步文件功能
nodegroups:
  group1: 'XX-AP'      #被管理端主机名
  group2: 'XX-TEST-AP'

1.3、创建配置文件中对应的目录

mkdir -p /srv/salt/prod/services
mkdir -p /srv/salt/prod/states
mkdir -p /srv/salt/uat/services
mkdir -p /srv/salt/uat/states

1.4、重启服务

 systemctl restart salt-master

2、被管理端配置

2.1、修改配置文件

cat > /etc/salt/minion << EOF
  master: salt-master-ip
  id: `hostname`
EOF

2.2、重启服务

 systemctl restart salt-minion



三、salt集群测试

1、salt-key 密钥管理,通常在master端执行
salt-key [options]
salt-key -L ##查看所有minion-key
salt-key -a <key-name> ##接受某个minion-key
salt-key -d <key-name> ##删除某个minion-key
salt-key -A ##接受所有的minion-key
salt-key -D ##删除所有的minion-key


2、salt-run 在master执行runner
salt-run [options] [runner.func]
salt-run manage.status ##查看所有minion状态
salt-run manage.down ##查看所有没在线minion
salt-run manged.up ##查看所有在线minion

3、salt可以让minion执行命令.
执行模块命令。

cmd.run模块执行shell命令。

cmd.script方式:可以向远程主机执行脚本。

salt -C 'ZL-FSL-AMS-TEST-AP' test.ping        #模块命令。测试minion存活状态,-C多参数
salt  'ZL-FSL-AMS-TEST-AP'  cmd.run 'ls /home'
salt '*' cmd.script salt://temp.sh salt:// == /srv/salt(salt的默认发布目录)

4、salt执行cp模块salt-cp 分发文件到minion上,不支持目录分发。

  salt-cp '*'  /home/scripts/zabbix_backup.sh  /home/zabbix_backup.sh


5、salt执行自定义脚本。

salt:// 是指 /srv/salt(salt的默认发布目录)



觉得有用的朋友多帮忙转发哦!后面会分享更多devops和DBA方面的内容,感兴趣的朋友可以关注下~


相关推荐

zabbix企业微信告警(zabbix5.0企业微信告警详细)

zabbix企业微信告警的前提是用户有企业微信且创建了一个能够发送消息的应用,具体怎么创建可以协同用户侧企业微信的管理员。第一步:企业微信准备我们需要的内容包括企业ID,应用的AgentId和应用的S...

基于centos7部署saltstack服务器管理自动化运维平台

概述SaltStack是一个服务器基础架构集中化管理平台,具备配置管理、远程执行、监控等功能,基于Python语言实现,结合轻量级消息队列(ZeroMQ)与Python第三方模块(Pyzmq、PyCr...

功能实用,效率提升,Python开发的自动化运维工具

想要高效的完成日常运维工作,不论是代码部署、应用管理还是资产信息录入,都需要一个自动化运维平台。今天我们分享一个开源项目,它可以帮助运维人员完成日常工作,提高效率,降低成本,它就是:OpsManage...

centos定时任务之python脚本(centos7执行python脚本)

一、crontab的安装默认情况下,CentOS7中已经安装有crontab,如果没有安装,可以通过yum进行安装。yuminstallcrontabs二、crontab的定时语法说明*代表取...

Fedora 41 终于要和 Python 2.7 说再见了

红帽工程师MiroHroncok提交了一份变更提案,建议在Fedora41中退役Python2.7,并放弃仍然依赖Python2的软件包。Python2已于2020年1...

软件测试|使用docker搞定 Python环境搭建

前言当我们在公司的电脑上搭建了一套我们需要的Python环境,比如我们的版本是3.8的Python,那我可能有一天换了一台电脑之后,我整套环境就需要全部重新搭建,不只是Python,我们一系列的第三方...

环境配置篇:Centos如何安装Python解释器

有小伙伴时常会使用Python进行编程,那么如何配置centos中的Python环境呢?1)先安装依赖yuminstallgccgcc-c++sqlite-devel在root用户下操作:1...

(三)Centos7.6安装MySql(centos8.3安装docker)

借鉴文章:centos7+django+python3+mysql+阿里云部署项目全流程。这里我只借鉴安装MySql这一部分。链接:https://blog.csdn.net/a394268045/a...

Centos7.9 如何安装最新版本的Docker

在CentOS7.9系统中安装最新版本的Docker,需遵循以下步骤,并注意依赖项的兼容性问题:1.卸载旧版本Docker(如已安装)若系统中存在旧版Docker,需先卸载以避免冲突:sudoy...

Linux 磁盘空间不够用?5 招快速清理文件,释放 10GB 空间不是梦!

刚收到服务器警告:磁盘空间不足90%!装软件提示Nospaceleftondevice!连日志都写不进去,系统卡到崩溃?别慌!今天教你5个超实用的磁盘清理大招,从临时文件到无用软件一键搞定...

Playwright软件测试框架学习笔记(playwright 官网)

本文为霍格沃兹测试开发学社学员学习笔记,人工智能测试开发进阶学习文末加群。一,Playwright简介Web自动化测试框架。跨平台多语言支持。支持Chromium、Firefox、WebKit...

为SpringDataJpa集成QueryObject模式

1.概览单表查询在业务开发中占比最大,是所有CRUDBoy的入门必备,所有人在JavaBean和SQL之间乐此不疲。而在我看来,该部分是最枯燥、最没有技术含量的“伪技能”。1.1.背景...

金字塔测试原理:写好单元测试的8个小技巧,一文总结

想必金字塔测试原理大家已经很熟悉了,近年来的测试驱动开放在各个公司开始盛行,测试代码先写的倡议被反复提及。鉴于此,许多中大型软件公司对单元测试的要求也逐渐提高。那么,编写单元测试有哪些小技巧可以借鉴和...

测试工程师通常用哪个单元测试库来测试Java程序?

测试工程师在测试Java程序时通常使用各种不同的单元测试库,具体选择取决于项目的需求和团队的偏好。我们先来看一些常用的Java单元测试库,以及它们的一些特点:  1.JUnit:  ·描述:JUn...

JAVA程序员自救之路——SpringAI评估

背景我们用SpringAI做了大模型的调用,RAG的实现。但是我们做的东西是否能满足我们业务的要求呢。比如我们问了一个复杂的问题,大模型能否快速准确的回答出来?是否会出现幻觉?这就需要我们构建一个完善...