SaltStack Execution Modules

SaltStack Execution Modules


    SaltStack有许多的内置模块,如果想要添加自定义的模块SaltStack也提供了比较简单的方式.

    SaltStack内置模块列表


添加自定义模块


    一个自定义SaltStack模块是需要存放在由/etc/salt/master配置文件中file_roots指定的路径下的_modules目录下.(需要创建)

默认位置为/src/salt/_modules.


同步模块至Minion


    如果使用自定义模块,首先应该添加模块至_modules目录下,其次同步自定义模块至各个Minion中.

同步模块至Minion可使用下列三个命令之一:

    ++  state.highstate

    ++  saltutil.sync_modules

    ++  saltutil.sync_all


模块名称重写


    调用名称默认是模块名称.如模块名称是deploy.py那么调用的时候就是deploy.如果想与模块名称不同,那么可以使用__virtual__函数.

[root@localhost ~]# cat /srv/salt/_modules/deploy.py

[root@localhost ~]#salt '*' saltutil.sync_modules  
192.168.24.153:
    - modules.deploy
[root@localhost ~]# salt '*' deploy.test  \\通过deploy名称调用test函数           
192.168.24.153:
    test!

    使用virtual函数

[root@localhost ~]# cat /srv/salt/_modules/deploy.py

[root@localhost ~]#salt '*' saltutil.sync_modules   
192.168.24.153:
    - modules.deploy
[root@localhost ~]# salt '*' haha.test          \\通过haha名称调用test函数 
192.168.24.153:
    test!
[root@localhost ~]# salt '*' deploy.test       \\此时deploy模块名已经不生效了
192.168.24.153:
    'deploy.test' is not available.


本地检测模块


使用模块执行系统命令,默认是在远端执行.

可通过salt-call --local参数先本地运行模块测试.

salt-call --local -m /srv/salt/_modules deploy.test


关于使用class

如果使用的class方式来做模块需要在主程序开头加上

import sys
###  set master $PYTHONPATH
sys.path.append('/srv/salt/_modules')
###  set minion $PYTHONPATH
sys.path.append('/var/cache/salt/minion/extmods/modules/')
来帮助程序找到我们写的class.


--------------------------------------------------------------------------------------
版权所有,转载时必须以链接方式注明源地址,否则追究法律责任!

QQ    :   413844436
Email  :   softomg@163.com
Blog   :   http://blog.csdn.net/softomg


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要安装SaltStack 3004,你需要在一台主机上安装一个master和多个minion。首先,使用以下命令安装master: sudo yum install salt-master 接下来,使用以下命令安装minion: sudo yum install salt-minion 然后,启动master和minion。使用以下命令启动master: sudo systemctl enable salt-master && sudo systemctl start salt-master 使用以下命令启动minion: sudo systemctl enable salt-minion && sudo systemctl start salt-minion SaltStack有四种运行方式: 1. local本地运行:在Master上向Minion发送命令和配置,适用于实时监控、状态和库存。 2. Master/Minion传统方式:Master向Minion发送命令和配置,Minion从Master接收命令和配置,适用于一次性命令和脚本、部署关键更新等。 3. Syndic分布式:用于将命令和配置转发到其他Master,适用于跨多个区域或数据中心的环境。 4. Salt SSH:通过SSH在没有Minion的系统上运行Salt命令。 SaltStack的组件包括: - Salt Master:将命令和配置发送到受管系统上运行的Salt Minion。 - Salt Minion:从Salt Master接收命令和配置。 - Execution Modules:在命令行针对一个或多个受管系统执行的临时命令。 - Formulas (States):系统配置的声明性或命令式表示。 - Grains:有关底层受管系统的静态信息,包括操作系统、内存等系统属性。 - Pillar:用户定义的变量,在Salt Master中定义并存储,然后分配给一个或多个Minion。 - Top File:将Formulas (States)和Salt Pillar数据与Salt Minions匹配。 - Runners:在Salt Master上执行的模块,用于执行支持任务。 - Returners:将Salt Minions返回的数据发送到另一个系统,例如数据库。 - Reactor:在SaltStack环境中发生事件时触发反应。 - Salt Cloud / Salt Virt:在云提供商/虚拟机管理程序上提供系统,并立即将其置于管理之下。 这些是SaltStack的核心组件和运行方式。你可以根据具体需求选择适合的方式来安装和配置SaltStack

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值