openstack-nova源码分析(五)flavor extra_specs 扩展属性

本文深入分析了OpenStack Nova中关于Flavor扩展属性(extra-specs)的操作,包括创建、更新和删除。Flavor extra-specs用于对虚拟机设置额外限制,API提供了GET、POST、PUT、DELETE方法。文章详细阐述了相关URL、命令行以及源码实现,指出创建和更新操作中的关键步骤,并提醒在使用novaclient时,删除extra-specs应使用unset_keys而非delete,以避免误删Flavor。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Flavors extra-specs (flavors, os-flavor-extra-specs)
Flavor 扩展属性设置, 扩展属性可以用来对虚拟机做一些额外的限制设置,具体的参数,将在后面的博客中做统一列出,这里暂时不做列出

openstack api 定义如下:
Lists, creates, deletes, and updates the extra-specs or keys for a flavor.
Refer to Compute Flavors for available built-in extra specs.

一. url及命令行
  1. url
    API为标准的restful API 风格 支持GET , POST, PUT, DELETE 方法:
    /flavors/{flavor_id}/os-extra_specs
    /flavors/{flavor_id}/os-extra_specs/{flavor_extra_spec_key}

  2. 命令行
    nova flavor-key

二. 源码分析

对应的方法在: flavors_extraspecs = nova.api.openstack.compute.flavors_extraspecs:FlavorsExtraSpecs

FlavorsExtraSpecs定义如下:

class FlavorsExtraSpecs(extensions.V21APIExtensionBase):
    """Flavors extra specs support."""
    name = 'FlavorExtraSpecs'
    alias = ALIAS
    version = 1

    def get_resources(self):
        extra_specs = extensions.ResourceExtension(
                'os-extra_specs',
                FlavorExtraSpecsController(),
                parent=dict(member_name='flavor', collection_name='flavors'))

        return [extra_specs]

get_resources 将os-extra_specs 注册到collection flavors 下, 处理方法映射到FlavorExtraSpecsController

查看FlavorExtraSpecsController 为标准的restful api处理方法

   def index(self, req, flavor_id):
        """Returns the list of extra specs for a given flavor."""
        context = req.environ['nova.context']
        context.can(fes_policies.POLICY_ROOT % 'index')
        return self._get_extra_specs(context, flavor_id)

index实际处理_get_extra_specs函数

  def _get_extra_specs(self, context, flavor_id):
        flavor = common.get_flavor(context, flavor_id)
        return dict(extra_specs=flavor.extra_specs)

flavor.extra_specs获取扩展属性,并转换为dict
get_flavor 实际调用的是Flavor show一样的方法,这里不做重复分析

1. 创建接口:

    @extensions.expected_errors((400, 404, 409))
 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值