salt 基本组建之 grains,pillars(整理中)

grains

minion基本信息的管理html

基本使用:

<pre> salt '*' grains.ls 查看grains分类 salt '*' grains.items 查看grains全部信息 salt '*' grains.item osrelease 查看grains某个信息 </pre>web

自定义grains信息

Grains 信息能够在 minion 配置文件 /etc/salt/minion 中静态定义,自定义的 grains 能够将 Core grains 定义的信息覆盖,示例以下:ide

<pre> grains: roles: - webserver - memcache deployment: datacenter4 cabinet: 13 cab_u: 14-15 </pre>ui

若是不但愿将配置信息定义在 /etc/salt/minion 能够将配置信息写入 /etc/salt/grains,示例以下:lua

<pre> roles: - webserver - memcache deployment: datacenter4 cabinet: 13 cab_u: 14-15 </pre>server

重启 salt-minion 服务后,在 salt 'host' grains.items 能够查看自定义的信息是否生效,下面有几种自定义grains的方式,若是这些定义方式同时存在,则遵照以下由低到高的优先级:htm

  1. Core grains.
  2. Custom grains in /etc/salt/grains.
  3. Custom grains in /etc/salt/minion.
  4. Custom grain modules in _grains directory, synced to minions.

Each successive evaluation overrides the previous ones, so any grains defined in /etc/salt/grains that have the same name as a core grain will override that core grain. Similarly, /etc/salt/minion overrides both core grains and grains set in /etc/salt/grains, and custom grain modules will override any grains of the same name文档

<pre> salt '*' grains.item osrelease minoin1: osrelease: 6.2 </pre>get

在用salt进行管理客户端的时候或者写state的时候均可以引用grains的变量同步

文档:http://docs.saltstack.com/topics/targeting/grains.html

pillar

salt敏感信息的管理,只有匹配到的节点才能看到和使用

<pre> salt '*' pillar.items </pre>

文档:http://docs.saltstack.com/topics/tutorials/pillar.html

开启敏感信息配置管理 Pillar settings

编辑 /etc/salt/master 文件

<pre> pillar_roots: base: - /srv/pillar </pre>

mkdir -p /srv/pillar

默认:pillar数据定义文件存储路径:/srv/pillar

入口文件:/srv/pillar/top.sls

<pre> base: "targeting": - pillar #名字为pillar.sls的文件来存放对匹配到的minion的变量 </pre>

$pillar.sls

<pre> #基本: $key: $value #对应state引用方式: {{ pillar['$key'] }} #复杂: users: thatch: 1000 shouse: 1001 utahdave: 1002 redbeard: 1003 #state引用方式: #{% for user, uid in pillar.get('users', {}).items() %} # {{user}}: # user.present: # - uid: {{uid}} #{% endfor %} </pre>

查看节点的pillar数据:

<pre> salt 'client2' pillar.data </pre>

同步pillar:

<pre> salt '*' saltutil.refresh_pillar </pre>

附:这里咱们能够看到,pallar中也能够使用jinja

文档:http://docs.saltstack.com/topics/tutorials/pillar.html

相关文章
相关标签/搜索