设为首页 收藏本站
查看: 2387|回复: 0

[经验分享] saltstack的rest接口salt-api开发使用指南

[复制链接]

尚未签到

发表于 2018-8-1 11:28:14 | 显示全部楼层 |阅读模式
  前言:
  saltsatck本身就提供了一套算完整的api,专业说法 sdk。 saltstack 的webui hahite就是用cherrypy框架和salt接口组成的。
  salt-api 简单配置下
  安装:
yum -y install salt-api  配置:
[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
curl -k https://10.10.10.65:8000/login -H "Accept: application/x-yaml"  -d username='admin'  -d password='123123'  -d eauth='pam'
DSC0000.jpg

  原文:http://rfyiamcool.blog.51cto.com/1030776/1362979
  这里是使用获取的token,查询硬盘的使用情况
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'
DSC0001.jpg

  调用它的模块
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"
DSC0002.jpg

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

  虽然salt-api的接口相对来说,不管是文档还是使用易度算方便,但是这东西是cherrypy写的,绝对不主流的东西,我先前搞hahite的时候,研究一段时间的cherrypy,基本的mvc和session也都过了一遍,感觉用起来还是不爽。 所以 个人觉得完全可以自己写一套自己的api,不用非要rest,在接口上把安全做好就行了。
  这里讲解下,saltsatck的api,我发现群里有人迷茫了,saltstack api 是一个直接调用函数的集合罢了,salt-api是一个基于cherrypy的rest接口 !!!
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'}
  可以一次套用多个模块 !
>>> local.cmd('*', [  'grains.items',
  'sys.doc',
  'cmd.run',
  ],
  [
  [],
  [],
  ['uptime'],
  ])

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


  得到jid后,salt-run jobs.lookup_jid <job>  在api里面可以用runner.low 方法:
runner.low({'fun': 'jobs.lookup_jid', 'jid': '20131219215921857715'})  就说到这里啦,大家自己玩玩吧,有问题,拿出来咱们讨论下 ~ 有更好的见解,请指出,绝对受教 !!!

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-544701-1-1.html 上篇帖子: centos 6上安装使用saltstack以及基础管理 下篇帖子: saltstack的rest接口salt-api开发—基于flask-restful
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表