开发者社区> 技术小胖子> 正文

saltstack的rest接口salt-api开发使用指南

简介:
+关注继续查看

前言:

   saltsatck本身就提供了一套算完整的api,专业说法 sdk。 saltstack 的webui hahite就是用cherrypy框架和salt接口组成的。


salt-api 简单配置下

安装:

1
yum -y install salt-api


配置:

1
2
3
4
5
6
7
8
9
10
11
[root@65 ~]# tail -n 10 /etc/salt/master
#         - '*'
rest_cherrypy:
  port: 8000
  debug: True
  ssl_crt: /etc/pki/tls/certs/ca.crt
  ssl_key: /etc/pki/tls/certs/ca.key
external_auth:
  pam:
    admin:
      - .*


下面的测试用的是curl做的,线上环境调用的话,肯定不能这么搓,可以用python的urllib2 。

登录,然后获取token


1
curl -k https://10.10.10.65:8000/login -"Accept: application/x-yaml"  -d username='admin'  -d password='123123'  -d eauth='pam'


wKiom1MLaOng1mAXAAHICb2x_Gs256.jpg


原文:http://rfyiamcool.blog.51cto.com/1030776/1362979

这里是使用获取的token,查询硬盘的使用情况


1
2
3
4
5
6
curl -k https://10.10.10.65:8000 \
        -H "Accept: application/x-yaml" \
        -H "X-Auth-Token: f43a327ec50615ee0e3dc988cc7e290276ac959e" \
        -d client=local \
        -d tgt='*' \
        -d fun='status.diskusage'


wKioL1MLaYzx7XBdAANGMPpGMcE458.jpg


调用它的模块

1
2
3
4
5
6
7
curl -k https://10.10.10.65:8000 \
        -H "Accept: application/x-yaml" \
        -H "X-Auth-Token: f43a327ec50615ee0e3dc988cc7e290276ac959e" \
        -d client=local \
        -d tgt='*' \
        -d fun='cmd.run' \
        -d arg="free -m"


wKiom1MLaoTCTgFPAAK0f1MY1rY368.jpg



   我这里测试了下他的性能,不是对他性能的测试,因为就算是bottle这样的web框架也能抗住500+的压力,这里测试他的是他的堵塞,我开了两个终端,都是sleep 5 ,第二个链接花费了9s,很明显是堵塞的接口。 当然,我的测试方法也很是片面,salt-api 也是有jobs的jid支持的。也可以cherrypy nginx的uwsgi配合,多开几个线程。


wKiom1MLbm3wDYDZAAKkFhFLB6k627.jpg



虽然salt-api的接口相对来说,不管是文档还是使用易度算方便,但是这东西是cherrypy写的,绝对不主流的东西,我先前搞hahite的时候,研究一段时间的cherrypy,基本的mvc和session也都过了一遍,感觉用起来还是不爽。 所以 个人觉得完全可以自己写一套自己的api,不用非要rest,在接口上把安全做好就行了。


这里讲解下,saltsatck的api,我发现群里有人迷茫了,saltstack api 是一个直接调用函数的集合罢了,salt-api是一个基于cherrypy的rest接口 !!!


1
2
3
4
In [8]: import salt.client
In [9]: local = salt.client.LocalClient()
In [10]: local.cmd('*''cmd.run', ['ip a'])
Out[10]: {'66.ruifengyun.com''1: lo: <LOOPBACK,UP,LOWER_UP> mtu 16436 qdisc noqueue state UNKNOWN \n    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00\n    inet 127.0.0.1/8 scope host lo\n    inet6 ::1/128 scope host \n       valid_lft forever preferred_lft forever\n2: eth0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UNKNOWN qlen 1000\n    link/ether 00:0c:29:06:f2:dc brd ff:ff:ff:ff:ff:ff\n    inet 10.10.10.66/24 brd 10.10.10.255 scope global eth0\n    inet6 fe80::20c:29ff:fe06:f2dc/64 scope link \n       valid_lft forever preferred_lft forever'}


可以一次套用多个模块 !

1
2
3
4
5
6
7
8
9
10
>>> local.cmd('*', [
        'grains.items',
        'sys.doc',
        'cmd.run',
    ],
    [
        [],
        [],
        ['uptime'],
    ])

通过saltstack的run_job可以实现任务的后台执行,扔到后面之前,会扔出一个job id !

wKiom1MLdonTPf96AAJWHoZa7H0147.jpg


得到jid后,salt-run jobs.lookup_jid <job id number> 直接获取数据 !

在api里面可以用runner.low 方法:

1
runner.low({'fun''jobs.lookup_jid''jid''20131219215921857715'})



就说到这里啦,大家自己玩玩吧,有问题,拿出来咱们讨论下 ~ 有更好的见解,请指出,绝对受教 !!!






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


版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
超全API使用工具
如今,API已在软件、Web和移动应用程序开发领域无处不在,从企业内部到面向公众的应用以及与合作伙伴进行系统集成。通过使用API,开发人员可以创建满足各种客户需求的应用程序。而软件架构也在随着应用程序开发方法的改变而改变。
16 0
这个开源的 API 管理工具,竟然也有 Mock 功能
Mock 测试就是在测试活动中,对于某些不容易构造或者不容易获取的比较复杂的数据/场景,用一个虚拟的对象(Mock对象)来创建用于测试的测试方法。
46 0
Ansible最佳实践之 AWX 使用 Ansible 与 API 通信
写在前面 分享一些 AWX 使用 Ansible 与 API 通信的笔记 博文内容涉及: curl 方式调用 AWX API 浏览器接口文档方式调用 AWX API 使用 API 调用方式启动 AWX 中 作业模板 Ansible 模块 uri 的简单介绍 Ansible 剧本方式 调用 API 启动作业模板 理解不足小伙伴帮忙指正
249 0
Tendermint JSONRPC API中文手册
Tendermint RPC API文档中文版由汇智网翻译整理,访问地址:http://cw.hubwiz.com/card/c/tendermint-rpc-api/。 配置:可以使用配置文件 $TMHOME/config/config.toml或使用命令行参数--rpc.X 来调整terdernmint节点的rpc功能。
8013 0
Truffle 5命令及API文档
Truffle是一个世界级的用于以太坊区块链开发的开发环境、测试框架和资源处理流水线,其最新版本为Truffle 5,中文版文档由汇智网翻译整理,访问地址:http://cw.hubwiz.com/card/c/truffle-5-manual/。
2833 0
Zabbix API初步入门
Zabbix API是实现Zabbix自动化监控的主要手段之一,你可以使用Zabbix Agent的自动注册功能,也可以使用网络自动发现功能,但是这些功能各有各的缺点。如果编写脚本对你来说没有压力,我跟建议Zabbix的所有自动化功能全部使用API的方式来完成。
1029 0
如何使用 NodeJS 构建基于 RPC 的 API 系统
> * 原文地址:[How to build an RPC based API with node.js](https://scotch.io/@alloys/how-to-build-an-rpc-based-api-with-nodejs) > * 原文作者:[Alloys Mila](https://scotch.io/@alloys) > * 译文出自:[阿里云翻译小组](https:
1788 0
Derek解读Bytom源码-Api Server接口服务
作者:Derek 简介 https://github.com/Bytom/bytom 本章介绍bytom代码Api-Server接口服务 作者使用MacOS操作系统,其他平台也大同小异 Golang Version: 1.8 Api-Server接口服务 Api Server是比原链中非常重要的一个功能,在比原链的架构中专门服务于bytomcli和dashboard,他的功能是接收并处理用户和矿池相关的请求。
1582 0
API Monitor简介(API监控工具)
API Monitor是一个免费软件,可以让你监视和控制应用程序和服务,取得了API调用。 它是一个强大的工具,看到的应用程序和服务是如何工作的,或跟踪,你在自己的应用程序的问题。 64位支持 API监控支持监控的64位应用程序和服务。
3356 0
+关注
技术小胖子
文章
问答
视频
相关电子书
更多
简介Bytom架构
立即下载
低代码开发师(初级)实战教程
立即下载
阿里巴巴DevOps 最佳实践手册
立即下载