saltstack源码详解一
@(python之路)[saltstack源码详解一]
saltstack源码详解
初识源码流程
环境准备:
# 安装
yum install salt-ssh
pip3 install salt-ssh
# 命令
salt-ssh
# 配置
/etc/salt/roster
# 功能
salt-ssh "*" cmd.run "ls"
下面我们查看源码
入口
yum install salt-ssh后,他就会把代码放到python中的lib中。他会触发这个脚本
from salt.scripts import salt_ssh
if __name__ == '__main__':
salt_ssh()
他会调用这里边的东西并执行。
解析salt-ssh "*" cmd.run "ls" -i 命令
源码流程:
- 启动命令时python脚本
- 读取默认配置文件
obj = salt.clissh.SaltSSH()
obj.run() - 执行命令
obj = SSH(配置文件)
obj.run() - 创建进程间供享的队列;[]
- 读取配置文件中的主机,给每个符合条件的主机创建一个进程;
host = next(target_iter)
routine = MultiprocessingProcess(target=self.handle_routine,args=args)
每个进程执行得到结果后,将结果放入队列中
ret = self.handle_routing(……)
触发Single
触发Shell
触发terminal
que.put(ret)
salt日常使用
from salt.client.ssh.shell import Shell
shell = Shell({_ssh_version:(4,9 )})
result = shell.exec_cmd("ls")
print(result)
预留python接口:
from salt.client.ssh.client import SSHClient
client = SSHClient()
ret = client.cmd('*','cmd.run',('ls',),30)
print(ret)
1.grains.items
salt-ssh '*' grains.items
grains一般用于获取服务的静态信息
自定义:
# /srv/salt/_grains/xx.py
预留python接口
from salt.client.ssh.client import SSHClient
client = SSHClient()
ret = client.cmd("*",'grains.items')
print(ret)
2.pillar.items
salt-ssh "*" pillar.items
pillar一般用于获取服务器动态信息
方式一:
# /srv/pillar/top.sls
base:
"*": # "*" 表示所有的分组
- xxx # 文件名
# /srv/pillar/xxx.sls
x1:
{% if grains['os_family'] == 'Debian' %}
xxx1: 111111111111111
{% elif grains['os_family'] == 'RedHat' %}
xxx1: 222222222222222
{% elif grains['os'] == 'Arch' %}
xxx1: 333333333333333
{% endif %}
2/3: 是否可以用python脚本实现
# /etc/salt/master
ext_pillar:
- xiaohua:
api: 123
- tom:
# /var/cache/salt/master/extmods/pillar/tom.py # [**推荐使用**]
def ext_pillar(minion_id,pillar,*args,**kwargs):
import time
return {'alexcccccccccccccctime':str(time.time())}
# /usr/lib/python2.7/site-packages/salt/pillar/wupeiqi.py
def ext_pillar(minion_id,pillar,*args,**kwargs):
import time
return {'alexcccccccccccccctime':str(time.time())}
总结pillar源码分析:
salt/script.py
client = salt.cli.ssh.SaltSSH()
client.run()
salt/cli/ssh.py
# self.config是读取的配置文件
ssh = salt.client.ssh.SSH(self.config)
ssh.run()
salt/client/ssh/__init__.py
class SSH(object):
def run(self, jid=None):
if self.opts.get('raw_shell', False):
fun = 'ssh._raw'
args = argv
else:
fun = argv[0] if argv else ''
args = argv[1:]
for ret in self.handle_ssh():
pass
def handle_ssh():
routine = MultiprocessingProcess(target=self.handle_routine,args=args)
routine.start()
def handle_routine(self, que, opts, host, target, mine=False):
single = Single(...)
single.run()
salt/client/ssh/__init__.py
class Single(object):
def run(self, deploy_attempted=False):
stdout, retcode = self.run_wfunc()
return stdout, stderr, retcode
def run_wfunc(self):
# 实例化Pillar对象
pillar = salt.pillar.Pillar(
opts_pkg,
opts_pkg['grains'],
opts_pkg['id'],
opts_pkg.get('environment', 'base')
)
pillar_dirs = {}
# pillar对象.pillar => 去三个地方获取所有pillar
pillar_data = pillar.compile_pillar(pillar_dirs=pillar_dirs)
print(pillar_data)
salt/pillar/__init__.py
class Pillar(object):
def __init__(...):
# 去中找自定义pillar
# /var/cache/salt/master/extmods/pillar/alex.py # [**推荐使用**]
# /usr/lib/python2.7/site-packages/salt/pillar/wupeiqi.py
# ['xiaohua','tom','cmd_json',.....]
self.ext_pillars = salt.loader.pillars(ext_pillar_opts, self.functions)
def compile_pillar(self, ext=True, pillar_dirs=None):
# 1. top.sls
# 去中找自定义pillar
# 2. /var/cache/salt/master/extmods/pillar/alex.py # [**推荐使用**]
# 3. /usr/lib/python2.7/site-packages/salt/pillar/wupeiqi.py
pillar1 = self.render_pillar('top.cls')
pillar2 = self.ext_pillar(pillar1,...)
return pillar1 + pillar2
def self.ext_pillar(...):
return self._external_pillar_data(....)
def _external_pillar_data(self, pillar, val, pillar_dirs, key):
ext = self.ext_pillars[key](self.minion_id,pillar,*val)
return ext
saltstack源码详解一的更多相关文章
- Spark Streaming揭秘 Day25 StreamingContext和JobScheduler启动源码详解
Spark Streaming揭秘 Day25 StreamingContext和JobScheduler启动源码详解 今天主要理一下StreamingContext的启动过程,其中最为重要的就是Jo ...
- spring事务详解(三)源码详解
系列目录 spring事务详解(一)初探事务 spring事务详解(二)简单样例 spring事务详解(三)源码详解 spring事务详解(四)测试验证 spring事务详解(五)总结提高 一.引子 ...
- 条件随机场之CRF++源码详解-预测
这篇文章主要讲解CRF++实现预测的过程,预测的算法以及代码实现相对来说比较简单,所以这篇文章理解起来也会比上一篇条件随机场训练的内容要容易. 预测 上一篇条件随机场训练的源码详解中,有一个地方并没有 ...
- [转]Linux内核源码详解--iostat
Linux内核源码详解——命令篇之iostat 转自:http://www.cnblogs.com/york-hust/p/4846497.html 本文主要分析了Linux的iostat命令的源码, ...
- Shiro 登录认证源码详解
Shiro 登录认证源码详解 Apache Shiro 是一个强大且灵活的 Java 开源安全框架,拥有登录认证.授权管理.企业级会话管理和加密等功能,相比 Spring Security 来说要更加 ...
- udhcp源码详解(五) 之DHCP包--options字段
中间有很长一段时间没有更新udhcp源码详解的博客,主要是源码里的函数太多,不知道要不要一个一个讲下去,要知道讲DHCP的实现理论的话一篇博文也就可以大致的讲完,但实现的源码却要关心很多的问题,比如说 ...
- Activiti架构分析及源码详解
目录 Activiti架构分析及源码详解 引言 一.Activiti设计解析-架构&领域模型 1.1 架构 1.2 领域模型 二.Activiti设计解析-PVM执行树 2.1 核心理念 2. ...
- 源码详解系列(六) ------ 全面讲解druid的使用和源码
简介 druid是用于创建和管理连接,利用"池"的方式复用连接减少资源开销,和其他数据源一样,也具有连接数控制.连接可靠性测试.连接泄露控制.缓存语句等功能,另外,druid还扩展 ...
- 源码详解系列(七) ------ 全面讲解logback的使用和源码
什么是logback logback 用于日志记录,可以将日志输出到控制台.文件.数据库和邮件等,相比其它所有的日志系统,logback 更快并且更小,包含了许多独特并且有用的特性. logback ...
随机推荐
- java解决跨域
方法中response.setHeader("Access-Control-Allow-Origin", "https://ding.taozugong.com" ...
- 版本控制-https svn服务器搭建和常用命令(centos 6.3)
Svn是比较优秀的版本控制工具,虽然功能和性能上无法和Git媲美,但由于其容易搭建和使用的特性,所以在各个小公司还是很受欢迎的.使用Git可参考<版本控制-Git服务器搭建和常用命令使用> ...
- recv函数的用法详解
recv函数 int recv( SOCKET s, char FAR *buf, int len, int flags ); 不论是客户还是服务器应用程序都用rec ...
- Mac开发者常用的工具
http://www.oschina.net/news/53946/mac-dev-tools
- python文件操作os模块
Python 统计某一文件夹下文件数量 使用python pathlib模块 from pathlib import Path dir_path = ' ' print(len(list(Path( ...
- 《html5 从入门到精通》读书笔记(一)
今天看了<html5 从入门到精通>这本书,感觉阅读下来很舒心,不像阅读其他书籍很揪心.html增加的知识点,我觉得非常有价值,看完几章记录了一些内容,不但能巩固,也为下次遗忘知识点做好准 ...
- Replication--将LSN转换成16进制
在复制中经常会使用到16进制的LSN,但在日志fn_dblog中的LSN是数字形式,于是从网上找到以下转换函数CREATE FUNCTION dbo.fn_convertnumericlsntobin ...
- 使用 JSON JavaScriptSerializer 进行序列化或反序列化时出错
如题 报错提示: 使用 JSON JavaScriptSerializer 进行序列化或反序列化时出错.字符串的长度超过了为 maxJsonLength 属性设置的值.","Sta ...
- 使用Telegraf + Influxdb + Grafana 监控SQLserver服务器的运行状况
使用Telegraf + Influxdb + Grafana 监控SQLserver服务器的运行状况 前言 本文在Debian9下采用Docker的方式安装Telegraf + Influxdb + ...
- controller 状态码
工具使用lombok表示.如没有使用lombok 请 删除@Getter @Setter 并给get set方法 调用方法: 类型使用 Status ---> public ...