前言:

     saltsatck官方提供了一套算完整的api,专业说法 sdk。 saltstack 的webui hahite就是用cherrypy框架和salt接口组成的。插入一句,为毛用Cherrypy呀。 

      如果有一定的开发能力,还是推荐自己调用salt.client.LocalClient()相关函数,开发saltstack api接口,有兴趣的朋友看下我博客里面关于saltstack api开发的文章 。 


Hello , 这里说下文章的原文地址 blog.xiaorui.cc

关于salt-api的安装及配置

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

首先通过认证的登录,然后获取token


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

那继续来调用它的模块,cmd.run

我这里测试了下他的性能,不是对他性能的测试,因为就算是bottle这样的web框架也能抗住500+的压力,这里测试他的是他的堵塞,我开了两个终端,都是sleep 5 ,第二个链接花费了9s,那么说明salt-api默认的配置是堵塞的。 当然,我的测试方法也很是片面,salt-api 也是有jobs的jid来支持任务的异步化,同样也可以在wsgi层面做cherrypy uwsgi配置,多开几个线程。

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


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

可以一次套用多个模块 !

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

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

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


关于salt-api就说到这里了,更详细的看文档和代码,有问题,拿出来咱们讨论下 ~ 有更好的见解,请指出,绝对受教 !!!





对Python及运维开发感兴趣的朋友可以加QQ群 : 478476595 !!!
{ 2000人qq大群内有各厂大牛,常组织线上分享及沙龙,对高性能及分布式场景感兴趣同学欢迎加入该QQ群 }

另外如果大家觉得文章对你有些作用!   帮忙点击广告. 一来能刺激我写博客的欲望,二来好维护云主机的费用.
如果想赏钱,可以用微信扫描下面的二维码. 另外再次标注博客原地址  xiaorui.cc  ……   感谢!
暂无相关产品

1则回应给“使用saltstack的rest api接口salt-api开发实例”

  1. jacky说道:

    “有兴趣的朋友看下我博客里面关于saltstack api开发的文章”, 峰云大神,文章在哪儿呢?

发表评论