定制openstack SPS服务(类似nova)详解

感谢朋友支持本博客,欢迎共同探讨交流,由于能力和时间有限,错误之处在所难免,欢迎指正!

如有转载,请保留源作者博客信息。

Better Me的博客blog.csdn.net/tantexian

如需交流,欢迎大家博客留言。


一:简介
1、本文,主要讲解如果定制化一个类似nova服务的基础框架。基础架构参考glance,少数地方参考nova框架。暂且命名为sps-2014-4

2、本示例没有走keystone,假若需要配置走keystone,请自行参考博文,自行配置。 openstack_ice之wsgi详解(paste从ini配置文件->routesr具体发布流程)

3、基础框架最终代码地址: https://github.com/tantexian/sps-2014-12-4


二:安装sps服务及demo数据库建立与route API 发布
1、安装sps服务,执行上述sps包中的脚本  ./install.sh
 #此脚本用来安装sps服务,并启动、内容如下 
rm -rf build/ 
rm -rf /usr/lib/python2.6/site-packages/sps/ 
rm -rf /usr/bin/sps-* 
python setup.py install 
rm -rf /etc/sps/* 
cp -r /sps-2014-12-4/etc/* /etc/sps/ 


2、#数据库表增加(参照如下Demo数据库表的格式定义) 
图2-1


3 .完成步骤2后执行命令:sps-manage db_sync #生成数据库(同步数据库表到数据库,) 
图2-2

查看数据库表:(注数据库database sps油自己提前手动创建,否则将会保存,找不到sps数据库)
图2-3

此处发现demo数据库执行完db_sync则自动创建好了。


4、  #发布自定义的 route API: (假若需要增加发布新的api,请自行参考demo发布自定义的api)
此处的作用就是当前面有http请求时候,根据对应规则自动映射到对应controller的增伤查改函数。
关于route 如何 对应  controller 下面函数,更多详细请参考以下博文系列:



5、此处附上本demo的route 映射url地址:
增: 
curl -i -H 'Content-Type: application/json' -H 'User-Agent: python-spsclient' -X 'POST' http://192.168.10.31:9898/v1/demos -d '{"demo": {"name": "ttx", "type": "1"}}' 

查all: 
curl -i -H 'Content-Type: application/json' -H 'User-Agent: python-spsclient' -X 'GET' http://192.168.10.31:9898/v1/demos 

查某个: 
curl -i -H 'Content-Type: application/json' -H 'User-Agent: python-spsclient' -X 'GET' http://192.168.10.31:9898/v1/demos/1 

更新: 
curl -i -H 'Content-Type: application/json' -H 'User-Agent: python-spsclient' -X 'PUT' http://192.168.10.31:9898/v1/demos/25 -d '{"demo": {"name": "ttx---25--", "type": "1"}}' 

删 
curl -i -H 'Content-Type: application/json' -H 'User-Agent: python-spsclient' -X 'DELETE' http://192.168.10.31:9898/v1/demos/1

注:此处记得一定要有:-H 'Content-Type: application/json'


三、以增加为例对demo调用流程进行讲解:

1、请求url:
curl -i -H 'Content-Type: application/json' -H 'User-Agent: python-spsclient'  -X 'POST'  http://192.168.10.31:9898/v1/demos  -d '{"demo": {"name": "ttx", "type": "1"}}' 

2、根据第二部分的4 api 发布可知:对应匹配的mapper为:
注:匹配原则为:1、url匹配到/demos    2、看-X 参数 为POST (1、2分别匹配到对应下图中红色标记处)
图3-1

3、根据匹配的mapper找到对应的controller方法:
从第三部分 图3-1的黄色标注可知,
controller=demos_resource,
action='create',
跟进代码 controller,找到对应controller类:
图3-2
在根据上述的 action='create',说明是调用该controller的create方法:
图3-3


4、根据图3-3可知,接下来调用db模块的add_demo:
(注:业务逻辑代码应该写在/sps/api/v1/demos.py中,不应该写在db层,db层只能写和数据库交互及事务等操作代码)

此处的models.Demo即为sqlalchemy映射到底层数据库表demo。( sqlalchemy为一个ORM框架
接下来看看 models.Demo:

到此整个 增加为例对demo操作流程结束,感觉还是多简单。框架的好处就是,可以很好的节省效率。


四、api启动,及增删查改(CUID)测试:

1 . #启动服务 
sps-api --debug     #调试模式启动
 

假若提示sps-api端口9898被占用,则脚本kill掉,重启即可:
========================================================================== 
ps aux | grep sps | grep -v grep | awk '{print $2}' | xargs kill -9 
========================================================================== 

2. #数据库的增删查改API 测试



curl -i -H 'Content-Type: application/json' -H 'User-Agent: python-spsclient'  -X 'POST'  http://192.168.10.31:9898/v1/demos  -d '{"demo": {"name": "ttx", "type": "1"}}' 
curl -i -H 'Content-Type: application/json' -H 'User-Agent: python-spsclient'  -X 'POST' http://192.168.10.31:9898/v1/demos -d '{"demo": {"name": "ttx2", "type": "2"}}' 
curl -i -H 'Content-Type: application/json' -H 'User-Agent: python-spsclient'  -X 'POST' http://192.168.10.31:9898/v1/demos -d '{"demo": {"name": "ttx3", "type": "3"}}' 





curl -i -H 'Content-Type: application/json' -H 'User-Agent: python-spsclient'  -X 'PUT'  http://192.168.10.31:9898/v1/demos/124 -d '{"demo": {"name": "ttx-update", "type": "1"}}'





curl -i -H 'Content-Type: application/json' -H 'User-Agent: python-spsclient'  -X 'GET'  http://192.168.10.31:9898/v1/demos  



curl -i -H 'Content-Type: application/json' -H 'User-Agent: python-spsclient'  -X 'DELETE'  http://192.168.10.31:9898/v1/demos/124


完!

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值