Remote Execution

  • salt命令执行后的返回结果的数据结构都一致,保证能够很容易地检查数据,并存储在数据库中。

  • salt 使用python modules来进行远程管理,可以自己增加python module来扩展。所有可以用python访问的应用或者服务,如一个shell命令,都可以作为salt中的一个执行模块。

  • 命令执行

salt '*' test.rand_sleep 120

'*'是指机器名称,test.rand_sleep 即:modult.function, 120是参数

  • 命令执行过程
  1. salt master通过发布端口发送命令
  2. salt minion检查命令,看是否需要执行该命令
  3. 若需要,目标minion找到执行module 和对应的方法,执行命令,将结果返回

    每个命令,都被分成一个工作线程,保证一个salt minion可以同事处理多个jobs

salt state

salt state 系统

salt state系统在salt remote系统不就之后就出现了,对其影响很大。二者非常相似,一个很大的不同在于,state系统包含一个检查系统是否处于正常状态的逻辑,检查完毕之后,会交给salt remote执行命令。

  • state 模块用于跨作业和夸平台系统
  • 返回的结果是连续的数据结构,便于检查和存储到数据库

salt state 系统流程

salt sate 和salt remote的主要区别是state 系统内的控制流程。 salt提供特殊命令,用于定义依赖,重用代码,控制流程,影响变量和模板。

Runner

salt runner

runner 子系统提供了一些在salt master上执行的salt mudule,实时事件视图,管理salt的文件server,查看salt的采集资料,向minion发送网络唤醒,调用webhook和其它http 请求等

命令:salt-run,不需要taget server,因为target就是salt master本身

参数传递方式和向satl 执行模块发送参数的方式相同。

Orchestrate Runner

orchestrate runner 提供了salt的一个核心功能:运行命令,在多个minion上依照一定义好的顺序运用配置.

System Data

data

系统数据的两个主要方面:获取系统相关数据,传递数据至系统。salt提供了两个不同的子系统,来分别执行这两个任务:salt grains和salt pillar

salt mine是用于将数据从minion上推送到master上的一个公共的数据存储库上,这个库可以被所有的minion访问。

grains

grains用于获取agent的系统数据,是关于操作系统、内存、磁盘和其他系统属性的静态信息。

机器启动时开始采集数据,数据会阶段性刷新,或者使用远程命令执行。

grains的使用场景:使用grains的某一个值,来列出所有的grains,从而周到所有的agent

grains也是trageting系统不可缺少的一部分,用于定位salt state 和 salt pillar数据。

salt pillar

salt pillar用于传输数据到系统。 一个场景应用场景就是,不同的minion机器的配置不同,salt pillar使我们可以定义这些数据值,然后使用target的形式赋值给minion,然后值以变量的形式给salt state.

salt pillar数据使用minion 的公钥编码,通过加密渠道传输,因而salt pillar也适用于发送如密码,ssh key之类的秘密数据,因为只有target minion机器才能解码。salt pillar数据从不会被写入minon的磁盘。

salt pillar 模块使用yaml文件定义pillar,超过20个salt module(即插件)用于支持一个多变的后端环境。常见的有:Mongo和Redis,都是用于存储结构化的数据的。有的用户使用yaml文件存储,然后使用git 仓库来管理和发送pillar data。

salt mine

salt mine用于在minion间共享数据。如果建立一个共享DB,可以给运行依赖于db server的salt minion添加配置,使之自动推送自己的ip到salt mine。这比存储在salt state和salt pillar上好,因为它们需要进行手动更新。

之后若需要数据,可以直接使用salt state file 去salt mine中获取。

基本子系统的重置,在其它文档中有介绍。

Python

modules

salt中,每一个子系统都是一个python module

  • salt源码中,所有的module都在salt文件夹下。一个子文件夹就是一个子系统
  • modules的命名规则salt.subsystem.module

执行函数的参数

需要的参数值以特定的顺序传进来,参数之间用空格隔开。optional 参数以键值对的形式传递

示例命令

salt '*' network.connect google-public-dns-a.google.com port=53 proto=udp timeout=3
salt '*' cp.get_file salt://vimrc /etc/vimrc gzip=5
`salt ns1 pkg.install pkgs=['bind9','bind9-docs','bind-utils']`
`salt '*' pkg.install sources='[{"foo": "salt://foo.deb"},{"bar": "salt://bar.deb"}]'`

State function arguments

state file中,state 函数的调用使用yaml 语法。yaml展示数据类型时,表现更为突出。使用key 获取参数值

a state example that calls user.present:
user.present:
- name: fred
- shell: /bin/zsh list:
install bind packages:
pkg.installed:
- pkgs:
- bind9
- bind9-docs
- bind-utils

list dictornary

install bind packages:
pkg.installed:
- pkgs:
- bind9
- bind9-docs
- bind-utils

具体见salt.states.user.present

tips:

并非所有的参数都会列在function 注释中,有时候需要check source code 去看到底支持什么类型。

saltstack执行远程命令的更多相关文章

  1. Ubuntu 14.10 下SSH执行远程命令

    有些时候需要在远程机器上执行命令,如果每次都等进去挺麻烦的,所以用脚本执行会方便很多.下面介绍一下在shell脚本中执行远程命令. 1,首先写好要运行的脚本 run-command.sh, 加上执行权 ...

  2. 在地铁上看了zabbix 的书发现 "报警执行远程命令"

    在地铁上看了zabbix 的书发现 "报警执行远程命令" 远程命令整个过程:  items -> triggers -> action -> remote com ...

  3. Zabbix报警执行远程命令

    日常Zabbix报警案例中,大多都是报警发送邮件,场景里很少有需要报警后执行一个命令(启动服务.清空磁盘空间.关停服务器);而今天就给大家讲讲最近需要做的事:报警后执行远程命令 刚好zabbix动作中 ...

  4. 如何使用 PsExec 执行远程命令

    前言 这紧紧只是一篇纯技术分享.我们的程序在运行时需要连接多台目标机器,并拷贝目标机器上特定文件夹中的文件.为了方便访问,要在每台目标机器上建立一个特定用户,所以 PsExec 成了实现此功能的一个方 ...

  5. (29)zabbix执行远程命令

    概述 监控,有的人只把他当做报警使用,出现问题之后打开跑回家打开电脑,巴拉巴拉的处理掉,大多数时候都是一些小问题,为何不让zabbix帮你把这些事情处理掉呢?和朋友具体,收到xx硬盘空间慢了.xx服务 ...

  6. psexec局域网执行远程命令

    执行远程命令的工具psexec.exe 下载 一.首先,被控制机器必须开启ipc$,以及admin$,否则无法执行 开启ipc$ net share IPC$ 开启admin$ net share A ...

  7. Python中使用os模块执行远程命令

    1. 使用os模块远程执行命令 服务端代码 1 import socket 2 import os 3 4 sh_server = socket.socket() #创建一个socket对象 5 sh ...

  8. Python网络编程03 /缓存区、基于TCP的socket循环通信、执行远程命令、socketserver通信

    Python网络编程03 /缓存区.基于TCP的socket循环通信.执行远程命令.socketserver通信 目录 Python网络编程03 /缓存区.基于TCP的socket循环通信.执行远程命 ...

  9. linux shell 执行远程命令

    我在本地的shell脚本中,想要直接执行远程服务器的一个shell脚本: ssh -l root 192.168.1.1 "/data/t.sh" 记得提前给远程服务器的 /dat ...

随机推荐

  1. css3 走马灯效果

    纯css3实现了一个正六边形的走马灯效果,记录一下css3动画的学习情况,效果如下: 主要用到的css3技术有:keyframes.perspective.perspective-origin.tra ...

  2. selenium代理

    selenium.KeyDown("id=ctaskName", "d");            selenium.KeyPress("id=cta ...

  3. 诸葛io | 精细化运营分析解决方案

    类型: 定制服务 软件包: business intelligence internet media solution collateral 联系服务商 产品详情 解决方案 概要 数据监测 ? 异常发 ...

  4. C#队列Queue,利用队列处理订单

    一.什么是队列 队列(Queue)代表了一个先进先出的对象集合.当您需要对各项进行先进先出的访问时,则使用队列.当您在列表中添加一项,称为入队,当您从列表中移除一项时,称为出队. 这是摘抄网上的.做了 ...

  5. 【js基础修炼之路】— null和undefined的区别

    在近期的复习期间遇到null和nudefined,于是通过查找资料,想写一篇文章来说明他们的区别.. javaScript高级程序设计: 在使用var声明变量但未对其加以初始化时,这个变量的值就是un ...

  6. php session小节

    1.为什么要用session? 在人们访问网站的时候,有很多个网页,由于http自身的特点,用户每执行一个脚本都需要和web服务器重新建立连接.由于他们之间是无状态的,这次的连接无法得到上次连接的状态 ...

  7. NutDao配置多数据源

    首先,我必须声明,这是一个非常简单的方法,很多小菜没做出来,是因为把nutz想得太复杂 数据源(或者是数据库连接池),在Nutz.Ioc看来,是一个普通的Bean,没任何特别之处. 再强调一点,除了$ ...

  8. centos6.x yum 安装 mysql5.6 mysql5.7

    先卸载低版本MYSQL yum remove mysql* rpm -ivh http://repo.mysql.com/mysql-community-release-el6.rpm yum ins ...

  9. SQL随手记

    数据库改名 想要达到的效果,类似于将一个文件[复制粘贴重命名]. 0.首先得断开连接,复制一份备份.然后再连接上,进行下面的操作. 1.在树形上,选中要改名的数据库,右键重命名. 2.还是它,右键,属 ...

  10. sql的where条件转换成mongdb筛选条件

    解析字符串 filterModel1 and filterModel2 and (filterModel3 or filterModel4) 1.转换成mongo的筛选条件 /// <summa ...