novaclient的api调用流程与开发

时间:2021-03-31 15:41:56

novaclient的api调用流程与开发

2015年07月05日 19:27:17 qiushanjushi 阅读数:3915
 

http://blog.csdn.net/tpiperatgod/article/details/18375387?utm_source=tuicool

另一个地址:http://neuromancer.sinaapp.com/?p=64

从nova client的入口查看

cat /usr/bin/nova

  1. #!/usr/bin/python
    # PBR Generated from 'console_scripts'

    import

    fromimport

    if:

  2. sys.exit(main())

其中导入了novaclient.shell这个文件中导入了main方法,进入novaclient.shell.py查看

  1. def
    try
    :]))
  2. except
    )
  3. print"ERROR: %s"

    )

  4. .cs = client.Client(options.os_compute_api_version, os_username,
  5. .extensions, service_type=service_type,
  6. cacert=cacert, timeout=timeout)

self.cs是从client中创建出的一个Client实例,进入novaclient.client.py查看这个实例的具体方法

  1. def

    : ,

  2. : ,
  3. : ,
  4. try

    except

    .join(version_map.keys())))

  5. raise

    return

    def

    return client_class(*args, **kwargs)

用的是v1_1这个版本的api,对应的是novaclient.v1_1.client.py里的Client类

  1. class

    Top-level object to access the OpenStack Compute API.

  2. Create an instance with your creds::
  3. >>> client = Client(USERNAME, PASSWORD, PROJECT_ID, AUTH_URL)
  4. Then call methods on its managers::
  5. >>> client.servers.list()
  6. ...
  7. >>> client.flavors.list()
  8. ...
  9. """

注释里讲了怎么使用python命令行调用nova的client

client里给流入的指令分了很多类,以flavors为例,看nova flavor-list这个命令的流程

  1. self)
  2. class

    Manage :class:`Flavor` resources.

  3. """
  4. def, detailed=, is_public=):
  5. Get a list of all flavors.
  6. :rtype: list of :class:`Flavor`.
  7. """
  8. ifnot
    ] = is_public
  9. % urlutils.urlencode(qparams) ifelse<span "  <="" span="">
  10. <span "  <="" span="">
  11. if
  12. return._list( % (detail, query_string), )

self._list进入novaclient.base.py

  1. class

    Managers interact with a particular type of API (servers, flavors, images,

  2. etc.) and provide CRUD operations for them.
  3. """
  4. def, api):
  5. .api = api
  6. def, url, response_key, obj_class=, body=):
  7. if
    .api.client.post(url, body=body)
  8. else
    .api.client.get(url)
  9. ifis:
  10. .resource_class
  11. if
    try
    ]
  12. except
    pass

    .completion_cache(, obj_class, mode=):

  13. .completion_cache(, obj_class, mode=):
  14. return, res, loaded=)
  15. forinif res]

novaclient.v1_1.flavors.py里FlavorManager的resource_class = Flavor即class Flavor(base.Resource)
所以最后obj_class为Flavor

调用api的过程:

  1. if
    .api.client.post(url, body=body)
  2. else
    .api.client.get(url)
  1. 通过.api到了nova的api里nova.api.openstack.compute.__init__.py
  2. ifis or in
    .resources[] = flavors.create_resource()
  3. , ,
  4. .resources[],
  5. : },
  6. : })

找到nova.api.openstack.flavors.py

  1. @wsgi
    def, req):
  2. ._get_flavors(req)
  3. return._view_builder.index(req, limited_flavors)

它最后会返回一个存放flavors信息的字典,这些原始数据经过提取和加工,最后在终端被打印出来

nova.api.openstack.compute.views.flavors.py

  1. def, func, request, flavors):
  2. ] forin
    ._get_collection_links(request,
  3. ._collection_name,
  4. )
  5. if
    ] = flavors_links
  6. return flavors_dict

添加一个新的client流程:

功能:快速备份虚拟机,三个参数,虚拟机uuid、备份的名字、备份的描述,调用地方和方法如下:

novaclient.shell.py
class OpenStackComputeShell(object) 的get_subcommand_parser 方法里指定了actions_module

转到novaclient.v1_1.shell.py

增加一个新的方法,装饰器里是需要的参数,有顺序,和执行时的参数顺序一致

  1. @utils'server', help=)
  2. @utils'displayname'
    ,
  3. )
  4. @utils'description'
    ,
  5. ,
  6. )
  7. def

    args.description)

这个功能是加在servers部分里的,转到novaclient.v1_1.servers.py

在ServerManager类里添加

  1. def, server, backup_name, backup_description):
  2. Backup a server instance quickly.
  3. :param server: The :class:`Server` (or its ID) to share onto.
  4. :param backup_name: Name of the backup image
  5. :param backup_description: The backup description
  6. """
    : backup_name,
  7. : backup_description}
  8. return._create( % base.getid(server),
  9. )

response_key是指返回数据里的key,这里返回的数据是{'id': "*****"},所以response_key = "id"

因为这个api返回的是一个json字符串,不能通过novaclient.base.py里Manager类里的方法把数据提取出来(它需要字典),于是把return_raw这个参数设置为True

然后就可以在nova的命令行里看到这个新的功能了:nova
backup-instance;使用方法:nova backup-instance <server_id>
<bak_name> <bak_description>