用了两天的时间把salt的源码安装搞定,蛋疼啊。现在记录下salt的基础学习过程。

常用术语:

minion: salt客户端

master: salt服务端

grains: 客户端的一些底层信息、比如cpu、ip、mem

pillar: 用户在master端自定义的数据、可用于minion

state: 用户自定义的sls文件、用来管理文件、包的状态

mine: 客户端收集的信息、这个信息是共享的

jinja:sls默认的模版,用于替换数据的

targeting: 操作目标、就是客户端

returner: 将数据返回到其他地方、支持mysql、redis等

renderer:配置、模版解析引擎,包含jinja、json、yaml、py等


targeting:

在管理服务器时,我们需要指定管理的目标,这个时候就需要用到targeting。


target有以下几种方式:

使用id指定target    

使用grains指定target  -G(--grain)  --grain-pcre

使用配置文件中预定义的nodegroups  -N(--nodegroup)

使用函数返回状态码指定target  -X(--exsel)

使用pillar指定target  -I(--pillar)

使用ip地址段或ip指定target  -S(--ipcidr)

混合指定target  -C(--compound)


target匹配方式:

使用shell通用匹配符匹配

使用pcre匹配


基本架构:

saltstack基础概念_第1张图片



命令执行

wKiom1OGx6uQNiC9AAB-5ap-bkc287.jpg

这个命令用来测试主机的存活,这里我使用ip作为key.返回true代表存活

saltstack基础概念_第2张图片

这个命令用来远程执行命令,这就是salt特点,可以在本地管理远程机器,很方便。


上面命令都是通过id指定target。

通过列表指定target: 

salt -L '192.168.79.49,192.168.79.50' test.ping

通过组指定target,组的定义可以在master配置

salt -N 'group1' test.ping

通过grains指定target:

salt -G 'shell:/bin/bash' test.ping

可以通过正则匹配:

salt -E '192.168.79.*' test.ping