通过SaltStack批量管理文件和计划任务

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

简介

saltstack是由thomas Hatch于创建的一个开源项目,设计初衷是为了实现一个快速的远程执行系统。用来管理你的基础架构,可轻松管理成千上万台服务器。

关于saltstack更多功能本文不多介绍了,本文主要演示使用saltstack来管理服务器的文件(例如/etc/hosts,/etc/resolv.conf)和计划任务。

使用场景

在维护大量服务器的时候,系统一般初始化并上线以后,我们希望所有的服务器系统的某些配置文件一样,这时候我们需要一种工具来批量管理这些文件,保证配置文件的一致性,比如:/etc/resolv.conf这个文件。我们会希望这个文件不管在任何时候都是统一的。接下来我们就通过saltstack来演示这个功能

环境准备

你需自行安装好salt-master salt-minion,并且在master上能够使用test.ping模块检查到minion,如下所示

   [root@saltmaster001 salt] salt 'qd01-stop-free002*' test.ping
   qd01-stop-free002:
       True

配置master

修改/etc/salt/master,添加如下

   file_roots:
     base:
       - /srv/salt
   pillar_roots:
     base:
       - /srv/pillar
   pillar_opts: True

编写sls文件

1、切换到/srv/salt目录,我们新建一个sysinit的目录,主要用来管理系统的一些配置文件

2、cd sysinit,创建conf、scripts目录,并创建sysinit.sls文件

   [root@saltmaster001 sysinit]# ll
   total 4
   drwxr-xr-x 2 root root  191 Dec 31 11:48 conf
   drwxr-xr-x 2 root root  198 Dec 14 12:41 scripts
   -rw-r--r-- 1 root root 3107 Dec 31 11:49 sysinit.sls

说明:

conf目录主要存放配置文件,例如hosts,resolv.conf等配置文件。

scripts目录主要存放脚本文件,比如您自己写的系统环境监测脚本check_server_env.sh等脚本

3、编写sysinit.sls

   /opt/resolv.conf:
     file.managed:
       - source: salt://sysinit/conf/resolv.conf
       - user: root
       - group: root
       - mode: 644
       - replaceTrue: True

如上所示,这里说明下,这里主要使用了salt的file模块

   /opt/resolv.conf:表示需要管理的配置文件所在的目录(minion端)这里表示把master的salt://sysinit/conf/resolv.conf同步到minion端的/opt/resolv.conf
   source:文件的源路径
   user:文件所属用户
   group:文件所属组
   mode:文件权限
   replaceTrue    :强制文件和master一致

4、在/srv/salt创建top.sls

   base:
     '*':
       - sysinit.sysinit

上面这段代码表示:sysinit目录下的sysinit.sls文件会被salt执行,并且目标是所有的minion端

以上需要的配置文件及sls文件都写好了,接下来我们来执行看看效果

5、执行同步

我这里minion只有一台服务器qd01-stop-free002,先看下opt目录,现在并没有resolv.conf这个文件

   [root@qd01-stop-free002 opt]# ll
   total 8
   drwxr-xr-x  4 root root 4096 Jul 13  2017 dell
   drwxr-xr-x 10 root root 4096 Mar 26  2019 gitlab

手动同步

   [root@saltmaster001 salt]# salt 'qd01-stop-free002' state.apply sysinit.sysinit
   qd01-stop-free002:
   ----------
             ID: /opt/resolv.conf
       Function: file.managed
         Result: True
        Comment: File /opt/resolv.conf updated
        Started: 15:31:17.355667
       Duration: 52.986 ms
        Changes:
                 ----------
                 diff:
                     New file
                 mode:
                     0644

现在看下qd01-stop-free002的/opt目录,已经有resolv.conf文件了

   [root@qd01-stop-free002 opt]# ll
   total 12
   drwxr-xr-x  4 root root 4096 Jul 13  2017 dell
   drwxr-xr-x 10 root root 4096 Mar 26  2019 gitlab
   -rw-r--r--  1 root root  103 Jan  6 15:34 resolv.conf

现在可以看到,虽然minion端已经同步了master端的文件,但是这是我们手动执行的同步。如果我们需要定期检查这个,就需要用到salt schedule

6、配置schedule

schedule可以配置到master或者minion端,本文配置到master端

修改/etc/salt/master文件,添加如下

   ##### schedule #####
   schedule:
     sysinit:
       function: state.orchestrate
       seconds: 0
       minutes: 5
       hours: 0
       args:
         - orchestration.sysinit.sysinit

说明:

使用salt的state.orchestrate函数,minutes: 5表示每五分钟检查一次 args表示需要执行的sls,这里为sysinit.sysinit,从结构可以看出是/srv/salt/sysinit/sysinit.sls文件。注意观察您就知道这个结构了。

配置我以后,需要重启salt-master

[root@altmaster001 salt]# systemctl  restart salt-master

再次删除qd01-stop-free002的 /opt/resolv.conf,5分钟后观察, /opt/resolv.conf又回来了。

以上就是演示了怎么使用salt来自动管理远程服务器的配置文件。如果你们需要管理多个配置文件,只需要修改sysinit.sls文件即可,例如

   /opt/resolv.conf:
     file.managed:
       - source: salt://sysinit/conf/resolv.conf
       - user: root
       - group: root
       - mode: 644
       - replaceTrue: True
   
   /root/.ssh/authorized_keys:
     file.managed:
       - source: salt://sysinit/conf/authorized_keys
       - user: root
       - group: root
       - mode: 0600
       - replaceTrue: True

管理cron任务

1、和管理配置文件一样,我们同样修改sysinit.sls文件,但是这里使用salt的cron模块

   root_crontab_job1:
     cron.present:
       - name: sh /home/ntp.sh >> /tmp/ntp.log
       - minute: "00"
       - hour: "*/2"
       - identifier: NTP

说明:

cron.present: salt模块

name: 任务语句,和系统的cron任务一致

分、时、日、月、周 参考crontab

identifier: 任务标识

修改完sysinit.sls,我们保存退出,因为我们前面已经配置了自动执行同步sls任务。五分钟后在qd01-stop-free002机器上查看crontab -l

   # Lines below here are managed by Salt, do not edit
   # SALT_CRON_IDENTIFIER:NTP
   00 */2 * * * sh /home/ntp.sh >> /tmp/ntp.log

文章来源网络,作者:管理,如若转载,请注明出处:https://shuyeidc.com/wp/219875.html<

(0)
管理的头像管理
上一篇2025-04-14 07:43
下一篇 2025-04-14 07:45

相关推荐

  • 骨干网络体系结构能干什么?骨干网络体系结构的作用

    骨干网络体系结构是现代信息社会的“超级高速公路网”,它通过分层设计、冗余备份和智能调度,确保海量数据在全球范围内高速、稳定、安全地传输,是支撑云计算、物联网及人工智能应用的底层基石,想象一下,如果你把互联网比作一个巨大的城市交通系统,那么骨干网络就是连接各个城市的主干道和立交桥,没有它,你的每一次微信发送、每一……

    2026-06-18
    0
  • 高io数据库可以干什么用?高io数据库适合什么场景

    高IO数据库的核心价值在于通过极高的读写吞吐量,解决海量数据场景下的性能瓶颈,是支撑高并发交易、实时分析及大规模内容分发的关键基础设施,在数字化转型的深水区,数据不再仅仅是静态的记录,而是流动的资产,传统的机械硬盘或普通SSD早已无法满足现代应用对速度的极致追求,高IO(Input/Output)数据库,就是那……

    2026-06-18
    0
  • 高io服务器性能如何?高io服务器适合什么场景

    高IO服务器并非单纯指代某种硬件,而是指在随机读写、高并发连接及小文件处理场景下,具备极致IOPS(每秒输入输出操作次数)和低延迟特性的计算资源,它是支撑现代高并发应用稳定运行的核心基石,在2026年的数字化浪潮中,业务负载早已从简单的静态页面展示演变为复杂的实时数据处理,许多开发者在排查系统瓶颈时,往往忽略了……

    2026-06-18
    0
  • 隔离网络空间哪里便宜?国内隔离网络空间价格

    隔离网络空间并没有统一的“便宜”标准,其成本高度取决于物理隔离等级、带宽需求及安全合规要求,通常物理网闸方案初期投入较高但长期运维成本低,而逻辑隔离方案虽初期便宜但存在潜在安全风险,建议根据业务敏感度选择混合隔离架构以平衡成本与安全,在数字化时代,企业构建独立网络环境的需求日益增长,但“隔离网络空间哪里便宜”这……

    2026-06-18
    0
  • 骨干网络体系结构设备为何故障?常见原因有哪些

    骨干网络体系结构设备故障的核心原因通常归结为硬件老化、配置错误、物理链路中断及外部攻击四大类,其中电源模块失效与光模块性能衰减是占比最高的隐性故障源,骨干网作为数字经济的“大动脉”,其稳定性直接关乎国计民生,当核心路由器或交换机出现丢包、震荡甚至宕机时,运维人员往往面临巨大的压力,很多人第一反应是检查软件配置……

    2026-06-18
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注