SaltStack之target

本文涉及的产品
日志服务 SLS,月写入数据量 50GB 1个月
简介:

不管你写了什么sls,或者执行何样的命令动作,最终你需要将此动作或者状态文件推送给谁?target就是我们今天要学习的东西。


SaltStack工作环境

Role

ip

os

Master

192.168.1.58

Centos6.3

Minion_id:web01.tx.com

192.168.1.61

Centos6.3

Minion_id:web02.tx.com

192.168.1.62

Ubuntu13.04


我们先来从以下简单的salt命令来谈吧.

[root@kvm images]# salt 'web01.tx.com'test.ping

web01.tx.com:

True

这句话的意思是,web01.tx.com这台机器活着吗?答案是,活着。


看到没?我们是对web01.tx.com这台机器执行了一个动作。现在我们知道了这台机器的ID,但是,如果我们有很多台,很多台,我们这里要怎么写?是不是要把所有的机器ID都写一次。我想这太傻了吧。

那如果就两台呢?是否可以这样写呢?

Salt ‘web01.tx.com,web02.tx.com’ test.ping

答案是不行,它们将单引号下的内容视为一个ID,所以我们需要使用-L参数,表示列表

如:salt -L 'web01.tx.com,web02.tx.com' test.ping 这样就没问题了。

那如果超过两台,或者多台呢?或者干脆我想知道在我管下所有机器呢。

salt ‘*’ test.ping 这是针对所有的.

也有可能我们的服务器ID,是有规律的如web01,web02….那么我们可以借助perl正则表达式来匹配target,

Salt –E ‘web\d+.tx.com’ test.ping


也有可能我们的服务器有各种操作系统,但今天我只想了解oscentos,这时候我们就需要用grains来匹配了.

Salt –G ‘os@Centos’ test.ping

以上是命令形式,但我们也会写些sls,这里面也需要匹配target,如果此时我需要在Centos安装apache怎么做呢?

top.sls

base:

'os:Centos':

- match: grain

- apache
这样我们执行salt '*' state.highstate便可以在centos安装apache.

在这也许大家会奇怪我的target’*’应该是所有机器啊,在这里我们还需要关注top.sls文件中的匹配条件.


也有可能我们需要知道所有db01,db02…这样的数据库服务器运行状态,那时候内置的grains变量不再符合我们的需求了,这时候我们可以自己定义garins变量,前期规划。

在每台minion端添加/etc/salt/minion

grains:

roles:

- web01

后重启/etc/init.d/salt-minion restart

过后,我们来通过如下命令来获取是否生效.

[root@kvm images]# salt -E 'web\d+.tx.com'grains.item roles

web02.tx.com:

roles:

db02

web01.tx.com:

roles:

db01

好了,接下来,我们执行如下命令

[root@kvm images]# salt --grain-pcre'roles:db\d+' test.ping

web01.tx.com:

True

web02.tx.com:

True

此命令结合了grainspcre(perl正则)


也有可能我们想知道某个IP,或者某个段下的情况,可以使用如下命令:

[root@kvm images]# salt -S '192.168.1.0/24'test.ping

web02.tx.com:

True

web01.tx.com:

True


此时,还可以指定某个固定ip.


很多情况下,我们采用的是分组形式,这样我们只需要记住一组类型便可以了。

/etc/salt/master

nodegroups:

db:'P@roles:db\d+'

重启master,/etc/init.d/salt-master restart

[root@kvm images]# salt -N db test.ping

web02.tx.com:

True

web01.tx.com:

True


当然我们还可以使用混合来指定更加精确的target,如我们想获取操作系统是centos并且ip192.168.1.61,而且rolesdb01的。

[root@kvm images]# salt -C 'G@os:Centos andS@192.168.1.61 and G@roles:db01' test.ping

web01.tx.com:

True


当然我们还可以使用pillar定义特征来获取target,还可以在sls文件中使用pillarnodegroup,pillar,compound,使用jinja模板来选择target.


总之,有这么多技术,我相信只要我们前期设计得好,这些技术足够我们使用了.



本文转自hahazhu0634 51CTO博客,原文链接:http://blog.51cto.com/5ydycm/1361404,如需转载请自行联系原作者

相关实践学习
日志服务之使用Nginx模式采集日志
本文介绍如何通过日志服务控制台创建Nginx模式的Logtail配置快速采集Nginx日志并进行多维度分析。
相关文章
|
JavaScript
【node错误】/usr/bin/env: node: No such file or directory
背景 安装了node后,执行npm run xxx的命令的时候,报错,提示如下: /usr/bin/env: node: No such file or directory   步骤 1.
6341 0
|
5月前
|
存储 JavaScript 算法
若依修改-Starting development server...10% building 0/1 modules 1 active ...-node
若依修改-Starting development server...10% building 0/1 modules 1 active ...-node
|
7月前
|
JavaScript Unix Shell
#! /usr/bin/env node 命令与 npm link 建立项目间软连接(一)
#! /usr/bin/env node 命令与 npm link 建立项目间软连接(一)
176 0
|
iOS开发 MacOS
如何解决npm命令报错Missing write access to /usr/local/lib/node_modules
如何解决npm命令报错Missing write access to /usr/local/lib/node_modules
如何解决npm命令报错Missing write access to /usr/local/lib/node_modules
That command depends on command in Target 'XXX': script phase “[CP] Copy Pods Resourc 报错解决方法
That command depends on command in Target 'XXX': script phase “[CP] Copy Pods Resourc 报错解决方法
183 0
|
JavaScript IDE 测试技术
使用V8和node轻松profile分析nodejs应用程序
使用V8和node轻松profile分析nodejs应用程序
|
Ruby
puppet 执行source
bash -c 'source ~/.rvm/scripts/rvm svn add . --no-ignore --force svn add . --no-ignore --force svn commit -m "2018" svn add --...
932 0
|
网络协议 关系型数据库 Linux
|
关系型数据库 Apache MySQL