saltstack 动态pillar实现
简介
pillar支持的数据存储方式有很多,mysql, mogo,json等。本篇介绍关于http存储方式。
首先简要说明整个流程:salt-master会去一个指定http发送get请求获取一个json串,然后将json存储为pillar。获取json时是根据salt-minon的minion_id 去获取,也就说每个minion_id获取到的json是不同的,这样http页面就应该是一个动态页面。例如http:/test.com/pillar/minion_id;不同的minion_id获取不同的json串。
实现过程
(1)HTTP
首先要建立HTTP服务,方法很多,这里的关键是提供一个动态url,salt通过不同的minion_id获取对应要存储的pillar值。
# 动态url获取内容,需要达到下面的效果, node1和node2是不同的minion_id
访问 http://192.168.1.12:8088/pillar/node1
获取: ' {"serverid":"1001","mysql_port":"3306"}'
访问 http://192.168.1.12:8088/pillar/node2
获取: ' {"serverid":"1002","mysql_port":"3306"}'
(2)salt 源码修改
写了个高大上的名字,其实就是添加一个Python脚本。。。脚本目录是在salt安装在python的site-packages目录里。找不到就find / -name salt ;
# cd /usr/local/lib/python3.6/site-packages/salt/pillar/ # 这个目录下是pillar的各种ext_pillar方法
# vim ops.py # 创建一个python脚本,名字随意取,但一定要唯一,名字之后会用到
#!/usr/bin/env python
# -*- coding:utf-8 -*-
# author : wangyongcun import logging
import requests
import json log = logging.getLogger(__name__) def ext_pillar(minion_id, pillar, api):
pillar_url = api + "/" + minion_id # 不同minion将访问不同的url
log.warning("Querying SOPS system Pillar of %s" % (minion_id, )) # 自己加的一条日志,可忽略
try:
ret = requests.get(url=pillar_url) # 向url发送get请求,这个方法需要requests模块,若没有需要安装,在master安装就可以
r = ret.text # get获取到的结果
if r:
result = json.loads(r) # 将获取的json字符串转化为字典类型
else: # 如果获取的json为空
result = {}
except Exception as e: # 这个异常处理,一般情况都是无法连接url获取到内容,记录个日志
log.exception(
"Query SOPS system failed! Error: [%s] :%s" % (minion_id,e, )
)
return {}
return result # 返回字典格式的数据
(3)修改salt-master 配置文件
# vim /etc/salt/master
# 注意格式空格
ext_pillar:
- sops: # 这个是上面添加的py文件名称
api: http://192.168.1.12:8088/pillar/
(4)重启master
# 重启
systemctl stop salt-master
systemctl start salt-master
# 刷新pillar
salt '*' saltutil.refresh_pillar
# 查看一下
[root@aliyuntest ~]# salt '*' pillar.items
node1:
----------
mysql_port:
3306
serverid:
1001
node2:
----------
mysql_port:
3306
serverid:
1002
saltstack 动态pillar实现的更多相关文章
- 菜鸟玩云计算之廿一: saltstack之pillar
菜鸟玩云计算之廿一: saltstack之pillar 参考: 点击打开链接 查看pillar数据: # salt '*' pillar.items pillar的默认根目录在:/srv/pillar ...
- SaltStack数据系统-Pillar
上一篇:SaltStack数据系统-Grains 使用saltstack进行配置管理可以使用pillar定义主机假如是Openstack修改了一下nova的密码就需要修改很多配置文件 pillar很安 ...
- Saltstack系列5:Saltstack之pillar组件
pillar组件 pillar也是Saltstack最重要的组件之一,其作用是定义与被控主机相关的任何数据,定义好的数据可以被其他组件使用,如模板.state.API等. 在pillar中定义的数据与 ...
- SaltStack数据系统-Pillar详解
1:存储位置 存储在master端,存放需要提供给minion的信息 每个minion只能访问master分配给自己的(应用场景) 2:在centos7 salt 2015.5.10 (Lithium ...
- python与saltstack动态传参变量名的研究
python动态变量名 import sys createVar = locals() listTemp = range(1,10) for i in range(1, len(sys.argv)): ...
- 1、自动化运维之SaltStack实践
自动化运维之SaltStack实践 1.1.环境 linux-node1(master服务端) 192.168.0.15 linux-node2(minion客户端) 192.168.0.16 1.2 ...
- 自动化运维之SaltStack实践
自动化运维之SaltStack实践 1.1.环境 linux-node1(master服务端) 192.168.0.15 linux-node2(minion客户端) 192.168.0.16 1.2 ...
- 自动化运维之SaltStack初探
1.1.基础环境 linux-node1(master服务端) 192.168.31.46 CentOS 6.6 X86_64 linux-node2(minion客户端) 192.168.31.47 ...
- 学习saltstack (四)
一.salt常用命令 salt 该命令执行salt的执行模块,通常在master端运行,也是我们最常用到的命令 salt [options] '<target>' <function ...
随机推荐
- 外层div高度不随内层div高度改变的解决办法
当b1和b2都是float=left时候,a1层的高度不会被b1和b2的高度撑开. <div id=“div1″> <div id=”div2″ style="float: ...
- SVG脚本编程简介
本文主要介绍SVG的脚本编程,并分别给出放大.缩小,查询,鼠标事件等实例. 一. SVG简介 SVG,全称为Scalable Vector Graphics(可伸缩矢量图形).它是W3C制定的.用矢量 ...
- PhpStorm (强大的PHP开发环境)2017.3.2 附注册方法
最新版PhpStorm 2017正式版改进了PHP 7支持,改进代码完成功能. PhpStorm 是最好的PHP开发工具,使用它进行PHP开发将会让你感觉到编程的乐趣. 快乐无极终于从oschina看 ...
- python性能测试脚本-乾颐堂
废话不多说,直接上代码. import httplib import urllib import time import json class Transaction(object): ...
- 16 Finding a Protein Motif
Problem To allow for the presence of its varying forms, a protein motif is represented by a shorthan ...
- jQuery 从 1.9 版开始,移除了 $.browser 和 $.browser.version
jQuery 从 1.9 版开始,移除了 $.browser 和 $.browser.version , 取而代之的是 $.support . 在更新的 2.0 版本中,将不再支持 IE 6/7/8. ...
- [label][git-commands] Several Git Commands
The process of Git commands Operation 1. git commit -m 'fist post' Windows PowerShellCopyright (C) 2 ...
- [leetcode] 10. Symmetric Tree
这次我觉得我的智商太低,想了很久才写出来.题目是让求镜像二叉树判断,题目如下: Given a binary tree, check whether it is a mirror of itself ...
- ASP.NET Core2使用Autofac实现IOC依赖注入竟然能如此的优雅简便
初识ASP.NET Core的小伙伴一定会发现,其几乎所有的项目依赖都是通过依赖注入方式进行链式串通的.这是因为其使用了依赖注入 (DI) 的软件设计模式,代码的设计是遵循着“高内聚.低耦合”的原则, ...
- 【转】敏捷开发之Scrum扫盲篇
现在敏捷开发是越来越火了,人人都在谈敏捷,人人都在学习Scrum和XP... 为了不落后他人,于是我也开始学习Scrum,今天主要是对我最近阅读的相关资料,根据自己的理解,用自己的话来讲述Scrum中 ...