saltstack 支持在master上向client 远程执行命令,并显示命令执行的结果

命令格式:


salt '<操作目标>' <方法> [参数]

示例

  • 示例1 ping检查agent

*:代表所有minion主机;test:模块; ping:test模块的一个方法,这里的单引号也可以使用双引号 [root@stack-master ~]# salt '*' test.ping stack-master: True stack-node01: True stack-node02: True
  • 示例2 执行命令

使用cmd.run远程执行命令,cmd是模块,run是cmd模块的一个方法 [root@stack-master ~]# salt '*' cmd.run "free -m" stack-master: total used free shared buffers cached Mem: 1877 670 1207 0 28 225 -/+ buffers/cache: 415 1461 Swap: 4095 0 4095 stack-node01: total used free shared buffers cached Mem: 1877 377 1499 0 27 223 -/+ buffers/cache: 126 1751 Swap: 4095 0 4095 stack-node02: total used free shared buffers cached Mem: 1877 377 1499 0 28 223 -/+ buffers/cache: 125 1751 Swap: 4095 0 4095

针对<操作目标> saltstack 提供了多种方法对client(id)进行过滤

  • 普通匹配

匹配所有 '*' 匹配单个 'minion_id'
  • 正则匹配

使用-E ,--pcre 进行正则匹配


[root@stack-master ~]# salt -E '^stack-node\w+' cmd.run "free -m" stack-node01: total used free shared buffers cached Mem: 1877 377 1499 0 27 223 -/+ buffers/cache: 126 1751 Swap: 4095 0 4095 stack-node02: total used free shared buffers cached Mem: 1877 377 1499 0 28 223 -/+ buffers/cache: 125 1751 Swap: 4095 0 4095
  • 列表匹配

-L,--list,以主机id名列表的形式进行过滤,格式与Python的列表相似,即不同主机id 名称使用逗号分隔


[root@stack-master ~]# salt -L 'stack-node01,stack-node02' cmd.run "free -m" stack-node02: total used free shared buffers cached Mem: 1877 376 1501 0 28 223 -/+ buffers/cache: 123 1753 Swap: 4095 0 4095 stack-node01: total used free shared buffers cached Mem: 1877 378 1499 0 28 223 -/+ buffers/cache: 126 1751 Swap: 4095 0 4095
  • IP匹配

-S,--ipcidr,根据被控主机的IP地址或IP子网进行匹配


[root@stack-master ~]# salt -S 172.16.202.0/24 cmd.run "free -m" stack-master: total used free shared buffers cached Mem: 1877 676 1201 0 30 225 -/+ buffers/cache: 420 1457 Swap: 4095 0 4095 stack-node01: total used free shared buffers cached Mem: 1877 378 1498 0 28 223 -/+ buffers/cache: 126 1751 Swap: 4095 0 4095 stack-node02: total used free shared buffers cached Mem: 1877 376 1500 0 28 223 -/+ buffers/cache: 123 1753 Swap: 4095 0 4095

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

  1. Linux centosVMware 自动化运维认识自动化运维、启动salt相关服务、saltstack配置认证、salt-key命令用法、saltstack远程执行命令、saltstack - grains、saltstack – pillar

    一.认识自动化运维 传统运维效率低,大多工作人为完成 传统运维工作繁琐,容易出错 传统运维每日重复做相同的事情 传统运维没有标准化流程 传统运维的脚本繁多,不能方便管理 自动化运维就是要解决上面所有问 ...

  2. 利用 Saltstack 远程执行命令

    Saltstack的一个比较突出优势就是具备执行远程命令的功能. 操作方法与func (https://fedorahosted.org/func/)相似,可以帮助运维人员完成集中化的操作平台. ht ...

  3. Saltstack系列2:Saltstack远程执行命令

    命令 命令格式: salt '<操作目标>' <方法>[参数] 例: salt 'wx' cmd.run 'free -m' #查看被控主机内存使用情况 常用参数 针对< ...

  4. SaltStack远程执行命令

    编辑fansik_cmd.sls文件: 内容如下: fansik_cmd:  cmd.run:    - unless:      - test -f /tmp/fansik.txt      - t ...

  5. Saltstack远程执行(四)

    Saltstack远程执行 语法例:salt '*' cmd.run 'w' -  命令:salt -  目标:'*' -  模块:cmd.run,自带150+模块,也可以自己写模块 -  返回:执行 ...

  6. SaltStack远程执行-返回MySQL

    上一篇:SaltStack远程执行-模块 参考官方文档:https://docs.saltstack.com/en/latest/ref/returners/all/salt.returners.my ...

  7. SaltStack远程执行

    上一篇:SaltStack概述及安装 master也需要安装一个minion 启动salt-master systemctl start salt-master 配置文件在目录/etc/salt下 p ...

  8. 利用scp 远程上传下载文件/文件夹和ssh远程执行命令

    利用scp传输文件 1.从服务器下载文件scp username@servername:/path/filename /tmp/local_destination例如scp codinglog@192 ...

  9. Saltstack异步执行命令(十三)

    Saltstack异步执行命令 salt执行命令有时候会有超时的问题,就是命令下发下去了,部分主机没有返回信息,这时候就很难判断命令或任务是否执行成功.因此,salt提供异步执行的功能,发出命令后立即 ...

随机推荐

  1. 海量数据mysql优化步骤

    第一优化你的sql和索引: 第二加缓存,memcached,redis: 第三以上都做了后,还是慢,就做主从复制或主主复制,读写分离,可以在应用层做,效率高,也可以用三方工具,第三方工具推荐360的a ...

  2. 【Unity笔记】UGUI物体的渲染顺序

    ①不同Camera的Depth.(大在前,小在后)②同Camera的SortingLayer.(下在前,上在后)③同SortingLayer下的Order in Layer.(大在前,小在后)④同Or ...

  3. Object中有哪些方法?

    有一种遗憾就是,每天都见到你,但是却不关注你!等到面试的时候才后悔莫及. Object类中有9大public方法: equals:判断两个对象"相等" hashCode:获取对象的 ...

  4. git 远程仓库版本的回退以及git reset 几种常用方式记录

    由于 github push 了两个比较潦草的commit, 自己很不满意,又不想重新开vpn进行上传,所以找了一下相关的教程. 最后研究了一下,原理为先在本地还原到你想要的commit,然后强制pu ...

  5. BusyBox inittab

    # /etc/inittab init(8) configuration for BusyBox## Copyright (C) 1999-2004 by Erik Andersen <ande ...

  6. kcp协议详解

    kcp协议是传输层的一个具有可靠性的传输层ARQ协议.它的设计是为了解决在网络拥堵情况下tcp协议的网络速度慢的问题.kcp力求在保证可靠性的情况下提高传输速度.kcp协议的关注点主要在控制数据的可靠 ...

  7. 【转】 web 测试使用的chrome插件

    1.二维码插件 https://chrome.google.com/webstore/detail/%E4%BA%8C%E7%BB%B4%E7%A0%81qr%E7%A0%81%E7%94%9F%E6 ...

  8. 矩阵分解(Matrix Factorization)与推荐系统

    转自:http://www.tuicool.com/articles/RV3m6n 对于矩阵分解的梯度下降推导参考如下:

  9. Ubuntu之音效调节

    sudo add-apt-repository ppa:nilarimogard/webupd8 sudo apt-get update sudo apt-get install pulseaudio ...

  10. Maven学习日记(二)---MAVEN创建多模块的项目

    手动构建多模块maven项目,这个simple-parent项目下有两个子模块,一个是jar包型的simple-weather和一个war型的simple-webapp1.创建一个父的simple-p ...