zoukankan      html  css  js  c++  java
  • ceph rbd 封装api

    1.安装python,uwsgi,nginx环境

      pip安装省略

    yumgroupinstall"Developmenttools"
    yuminstallzlib-develbzip2-develpcre-developenssl-develncurses-develsqlite-develreadline-develtk-devel
    yuminstallpython-devel
    pipinstalluwsgi

    2.明白 Restful API
      http://www.ruanyifeng.com/blog/2014/05/restful_api.html
    3.了解flask框架
      http://www.pythondoc.com/flask-restful/first.html
    4.调用python插件库
      http://docs.ceph.org.cn/rbd/librbdpy/
    5.写接口程序

      

    #!/usr/bin/env python
    # -*- coding: utf-8 -*-
    
    from flask import Flask, jsonify, make_response
    import rados
    import rbd
    from flask.ext.httpauth import HTTPBasicAuth
    import time
    '''
    ceph 接口封装,主要实现 CRD 功能
    curl xxx.xx.xx.xx2/ceph/v1.0/rbd -u admin:d41d8cd98f00b204e9fdsafdsafdasf333f
    curl -X POST xxx.xx.xx.xx/ceph/v1.0/rbd/images/V0/10234556 -u admin:d8cd98f00b204e9fdsafdsafdasf333f
    curl -X DELETE xxx.xx.xx.xx/ceph/v1.0/rbd/images/cai-ceph-a3 -u admin:d8cd98f00b204e9fdsafdsafdasf333f
    作者: 蔡锡生
    '''
    
    auth = HTTPBasicAuth()
    application = Flask(__name__)
    application.debug = True
    
    
    def connect_ceph():
        cluster = rados.Rados(conffile='/etc/ceph/ceph.conf')
        cluster.connect()
        ioctx = cluster.open_ioctx('rbd')
        return ioctx
    
    
    @auth.get_password
    def get_password(username):
        if username == 'admin':
            return 'd8cd98f00b204e9fdsafdsafdasf333f'
        return None
    
    
    @auth.error_handler
    def unauthorized():
        return make_response(jsonify({'error': 'Unauthorized access'}), 401)
    
    
    @application.route('/')
    def index():
        return "Hello, world"
    
    
    @application.route('/ceph/v1.0/rbd', methods=['GET'])
    @auth.login_required
    def get_rbd_list():
        ioctx = connect_ceph()
        rbd_inst = rbd.RBD()
        images = rbd_inst.list(ioctx)
        return jsonify({"code": 200, "info": images})
    
    
    @application.route('/ceph/v1.0/rbd/images/<image_name>/<int:size>', methods=['POST'])
    @auth.login_required
    def create_volume(image_name, size):
        ioctx = connect_ceph()
        rbd_inst = rbd.RBD()
        try:
            rbd_inst.create(ioctx, image_name, size)
            return jsonify({"code": 200, "info": "create volume success"})
        except Exception as e:
            return jsonify({"code": 400, "info": "create volume failure
    "+e.message})
    
    
    @application.route('/ceph/v1.0/rbd/images/<image_name>',methods=['DELETE'])
    @auth.login_required
    def delete_rbd_image(image_name):
        if image_name == '' or len(image_name) == 0:
            return jsonify({"code": 400, "info": "parameter can't be null"})
        ioctx = connect_ceph()
        print dir(rbd)
        rbd_inst = rbd.RBD()
        if image_name in rbd_inst.list(ioctx):
            try:
                time.sleep(3)
                rbd_inst.remove(ioctx, image_name)
                return jsonify({"code": 200, "info": "delete success"})
            except Exception as e:
                if e.message == 'error removing image':
                    delete_rbd_image(image_name)
                return jsonify({"code": 400, "info": e.message})
        else:
            return jsonify({"code": 403, "info": "requests image_name not be exist"})
    
    if __name__ == '__main__':
        application.run(host='0.0.0.0', port=80)
    

     

    6.uwsgi 配置

      vim uwsgi.ini

    [uwsgi]
    master=true
    wsgi-file=manage.py
    callable=application
    socket=/opt/soft/python-ceph-api/ceph-api.sock
    chmod-socket=664
    processes=10
    threads=4
    buffer-size=32768
    touch-reload=/opt/soft/python-ceph-api
    module=rbd_ap
    

      

    7.nginx 配置

    vim  /etc/nging/conf.d/ceph_api.conf

    upstreamscloud_django{
    	#serverunix:///path/to/your/mysite/mysite.sock;#forafilesocket
    	serverunix:///opt/soft/python-ceph-api/ceph-api.sock;#forawebportsocket(we'llusethisfirst)
    }
    
    server{
    	#theportyoursitewillbeservedon
    	listen20000;
    	
    	#thedomainnameitwillservefor
    	#server_namewww.scloud.cn;#substituteyourmachine'sIPaddressorFQDN
    	charsetutf-8;
    	
    	#maxuploadsize
    	client_max_body_size75M;#adjusttotaste
    	
    	#Djangomedia
    	location/media{
    		#alias/opt/soddft/scloud/media;#yourDjangoproject'smediafiles-amendasrequired
    	}
    	
    	location/static{
    		#alias/opt/soft/scloud/static;#yourDjangoproject'sstaticfiles-amendasrequired
    	}
    	
    	#Finally,sendallnon-mediarequeststotheDjangoserver.
    	location/{
    		uwsgi_passscloud_django;
    		include/etc/nginx/uwsgi_params;#theuwsgi_paramsfileyouinstalled
    	}
    
    }
    

      

    没有什么是写一万遍还不会的,如果有那就再写一万遍。
  • 相关阅读:
    通过 curl 命令访问 K8S API
    k8s 调度 Affinity
    golang 定期发送 RA 报文
    Ticker 使用
    查看 host/container veth pair 关系
    Kubernetes 服务 service 的负载均衡分析
    698 TypeScript泛型的使用:泛型实现类型参数化,泛型接口,泛型类,泛型约束
    697 TypeScript接口的使用:接口的声明,可选属性,只读属性,索引类型,函数类型,接口继承,交叉类型,接口的实现,字面量赋值,枚举类型
    696 TypeScript类的使用:类的定义,继承,多态,成员修饰符,readonly,getters/setters,静态成员,抽象类abstract,抽象类演练,类的类型
    695 TypeScript函数类型:可选参数,默认参数,剩余参数,this类型,函数的重载,联合类型和重载
  • 原文地址:https://www.cnblogs.com/waken-captain/p/8322249.html
Copyright © 2011-2022 走看看