cloudstack java api_CloudStack API编程指引

article/2025/9/10 3:46:22

前言

本文阐述为CloudStack编写新API或者更新已存在API时应遵循的约定和编程指引。

参考文档

(暂略)

介绍

当你需要为CS添加新的API时,需要创建一个Request类和Response类(或者在扩展CS API功能时它的API Responese已经定义的情况下重用已经存在的API Response类)。

编写CS API Request类

1、request继承自*Cmd抽象类

CUD(新增/更新/删除 命令)

7beaaede886ce3fcbc75965ccbf15e5a.png

R(读取列表)命令

5e52aa0e8a8435f1fc4a8883f9d3f4b1.png

重要-从2.x开始,新的CUD API命令不再继承自BaseCmd 类,它们被看做是异步命令,继承自BaseAsyncCmd或者BaseAsyncCreateCmd。

扩展BaseAsyncCmd或者BaseAsyncCreateCmd,创建新的CS实体命令扩展BaseAsyncCreateCmd,UD命令扩展BaseAsyncCmd。

2、新添加的command类应以“*Cmd”结尾且标注@ApiCommand。更多请阅参考文档Annotations use in the API中的@ parameters。

3、定义所有的请求参数,且所有的都用@Parameter标注。

4、为RUD命令实现execute()方法,为R命令实现execute()/create()。

5、增加s_name--响应的名字,并且为小写。

6、在为命令命名时,根据含义优先使用create/delete/update/list,只有当这些前缀不能满足你的逻辑时才考虑用你自己的(如assign)。

编写CS API Response类

1、让你的类继承自BaseResponse。

2、用@EntityReference标注Response类,并设定关联的CloudStack接口,它是你返回给API用户的对象。比如VolumeResponse 用EntityReference 标注关联Volume接口。

3、将每个参数用@SerializedName 和 @Param注解。 请阅在Annotations use in the API中关于这些注解的细节。

4、参数名称都是小写。

5、确保没有将真实的DB id设置到id字段将其暴漏,请用UUID值代替。

API位置和注册

命令的位置取决于该命令将是可用/禁用插件或者CloudStack核心的一部分。

当命令是CS核心的一部分

位置:Reque/Response代码放在cloud-api/cloud-engine-api下。

访问权限:命令的访问控制权限(谁有能调用它)在commands.properties.in里注册。

命令注册:命令应添加到CS支持的所有的API列表中,该列表由ManagementServerImpl.getCommands()获得

注意当命令调用完成时,它们关联的只能是cloud-api 或 cloud-util包里的接口

ca0b793b0187ad2a63096de11d36d6c7.png

当命令是插件/服务的一部分

位置:Reque/Response代码放在plugin包下。

访问权限:在Cmd文件里定义权限,使用@APICommand 注解"authorized"字段,如authorized = {RoleType.Admin}) 。

命令注册:让插件管理类继承自PluggableService 接口,增加到命令列表的命令由getCommands()返回。

定义在插件中的命令只关联位于cloud-api/cloud-utils/中的接口。

83c8932543b6753cce0a05029c568ecd.png

修改已存在API的规则

1、对Request:不要将参数从可选改为必需的;

2、对Request:不要在已存在的命令里增加一个required=true的参数;

3、对Request:不要降低command的权限,从对普通用户可用降到只对管理员可用;

4、对Request/Response:不要重命名已有的参数;

5、对Request/Response:不要更改参数的类型(如从String改为Map)

6、对Response:不要删除Response的参数,由于第三方软件会依赖它。

其它规则:

1、当新增一个参数时,应该在它的@Parameter 里标注"since=release #" 字段;

2、如果你认为有些参数会在未来被删除掉,请标注@Deprecated,并确保在第n版本里记录。当它发布后,客户有机会去检查/修改代码以去掉这个参数。于是可以在第n+1个版本去除该参数。


http://chatgpt.dhexx.cn/article/pRmPpxaq.shtml

相关文章

CloudStack 4.17 安装部署

市面上cloudstack大多部署教程都比较旧,这里写一篇最新版本的部署安装教程(4.17),为了方便解释相关配置以及进行相关配置,本篇会把管理节点和计算节点分开写 1.管理节点部署(admin) 管理节点ip&…

Cloudstack

1、cloudstack介绍 一个开源具有高可用性及扩展性的云计算平台,Cloudstack是一个开源的云操作系统; cloudstack支持管理大部分主流的hypervisors,如:VMware,KVM,Citrix XenServer,Xen Cloud Pla…

【私有云架构】Cloudstack 与 OpenStack:哪个更适合您?

创建云管理平台是因为云计算几乎已成为大多数日常业务使用的必需品。CloudStack 与 OpenStack 之争并不是很重要,而是在控制大量数据的高级云管理平台之间进行选择。 对于许多组织而言,重要的一步是实施逻辑云管理,该管理拥有许多用于控制各种…

CloudStack那些事儿1 : 初识CloudStack

CloudStack是什么呢?百科上对CloudStack的定义如下: CloudStack是一个开源的具有高可用性及扩展性的云计算平台,同时是一个开源云计算解决方案。可以加速高伸缩性的公共和私有云(IaaS)的部署、管理、配置。使用CloudSt…

OpenStack与CloudStack

目录 一、云计算 二、IaaS 三、OpenStack与CloudStack (一)概述 (二)项目历史与运营团队 (三)架构 (四)计算 (五)网络 (六)存…

CloudStack(二)基础网络模式安装部署

概述: 在CloudStack(一)简介及相关理论介绍里面简单的介绍了下cloudstack的相关概念好让我们安装部署的时候好理解一点,在cloudstack的区域里面有两种网络模式, 基础模式 基础网络模式只提供了简单的网络模型,管理网络、来宾网络(只支持1个来宾网络)、存储网络、V-Route(只提供…

CloudStack 云计算平台框架

前言 CloudStack 和OpenStack 一样都是IaaS层 开源框架,可以管理XenServer、ESXI、KVM、OVM等主流虚拟机,相对OpenStack比较简单、稳定; 二、Cloud Stack架构 Zone:相当于现实中的1个数据中心,它是CloudStack中最大的一…

【大数据实验1】cloudstack安装部署(小白式傻瓜教学)

cloudstack安装部署 0 说明1 Prerequisites 先决条件2 Environment 环境2.0 先看看有没有KVM2.1 Operating System 操作系统2.2 Configuring the network 配置网络2.3 Hostname2.4 SELinux2.5 NTP2.6 Configuring the CloudStack Package Repository 配置CloudStack软件包存储库…

Java线程池

目录 一、什么是线程池 二、线程池有哪些好处? ①降低资源的消耗 ②提高响应速度 ③提高线程的可管理能力 三、线程池如何使用 ①创建线程池​编辑 工厂模式: 工厂模式代码实现: ②往线程池当中添加任务 四、Java当中有哪些线程池 ​编辑 ①Executors.newFixedThreadPool …

线程池(一)线程池的基本使用

一、线程池简介 线程池的概念 线程池就是首先创建一些线相衬,它们的集合称为线程池,使用线程池可以很好的提高性能,线程池在系统启动时既创建大量空闲的线程,程序将一个任务传给线程池。线程池就会启动一条线程来执行这个任务&…

线程池介绍及创建线程池的4种方式

1. 什么是线程池 Java中的线程池是运用场景最多的并发框架,几乎所有需要异步或并发执行任务的程序 都可以使用线程池。在开发过程中,合理地使用线程池能够带来3个好处。 第一:降低资源消耗。通过重复利用已创建的线程降低线程创建和销毁造成…

线程池的使用

1.线程池使用场景 java中经常需要用到多线程来处理一些业务,我们非常不建议单纯使用继承Thread或者实现Runnable接口的方式来创建线程,那样势必有创建及销毁线程耗费资源、线程上下文切换问题。同时创建过多的线程也可能引发资源耗尽的风险,这…

线程池_线程池详解

1 线程池使用场景? java中经常需要用到多线程来处理一些业务,我们非常不建议单纯使用继承Thread或者实现Runnable接口的方式来创建线程,那样势必有创建及销毁线程耗费资源、线程上下文切换问题。同时创建过多的线程也可能引发资源耗尽的风险&…

Netty 线程池

Netty的线程池有什么样的特性 Java 原生线程池 Java 原生的线程池主要有三种:ThreadPoolExecutor、ScheduledThreadPoolExecutor、ForkJoinPool。 ThreadPoolExecutor 是最古老的类,我们通常说的线程池,也是指这个类。 ScheduledThreadPoo…

Linux —— 线程池

目录 一、什么是线程池 二、线程池的优点 三、线程池的应用 四、实现一个简单的线程池 五、单例模式 1. 饿汉实现方式 2. 懒汉实现方式 3. 单例模式实现线程池(懒汉方式) 六、其他常见的各种锁 一、什么是线程池 线程池是线程的一种使用模式。在…

线程池的实现原理

系统学习性,移步 IT-BLOG 线程池做的工作主要是控制运行的线程数量,处理过程中将任务放入队列,然后在线程创建后启动这些任务,如果线程数超过了最大数量超出数量的线程排队等候,等其他线程执行完毕,再从队列…

java——线程池

一、线程池 线程池可以看做是线程的集合。它的工作主要是控制运行的线程的数量,处理过程中将任务放入队列,然后在线程创建后 启动这些任务,如果线程数量超过了最大数量超出数量的线程排队等候,等其它线程执行完毕, 再…

java线程池(详解)

线程池介绍 线程池(thread pool):一种线程使用模式。线程过多会带来调度开销,进而影响缓存局部性和整体性能。而线程池维护着多个线程,对线程统一管理。 线程池就是存放线程的池子,池子里存放了很多可以复…

Java线程池详解

本文包含知识点 线程池的使用场景分析线程池的创建及重要参数线程池实现线程复用的原理springboot中使用线程池Callabel与Runnable任务在基于spring体系的业务中正确地关闭线程池实现优先使用运行线程及调整线程数大小的线程池(线程池的优化)在java web项目中慎用Executors以及…

C++线程池

1.基础概念 线程池:一种线程的使用模式,线程过多会带来调度开销,进而影响缓存局部性和整体性。而线程池维护着多个线程,等待监督管理者分配可并行执行的任务。这样避免了在短时间内创建和销毁线程的代价。线程池不仅能够内核的充分…