如何实现新的 Provider Plugin
截止到目前,OpenPitrix 支持以下几种 Provider Plugin:
- QingCloud
- AWS
- Kubernetes
如果您希望实现一个新的 Provider Plugin,可按照以下几步进行:
实现 ProviderInterface 中所有函数
- pkg/plugins/ 目录下创建一个以该 Provider Plugin 名称命名的文件夹。
- 创建 provider.go 实现 “pkg/plugins/plugin.go” 中 ProviderInterface 的所有函数。如果实现 VM-Based 类型的 Provider Plugin,provider.go 的实现可参考 “pkg/plugins/aws/provider.go” 或者 “pkg/plugins/qingcloud/provider.go”。
type ProviderInterface interface {// 通过 versionId 获取应用配置包,根据用户输入 conf 配置,将真实应用实例信息写入 clusterWrapper,后续会写入 dbParseClusterConf(ctx context.Context, versionId, runtimeId, conf string, clusterWrapper *models.ClusterWrapper) error// 将 job 拆分成多层的 task,以便后续逐层执行SplitJobIntoTasks(ctx context.Context, job *models.Job) (*models.TaskLayer, error)// 处理 taskHandleSubtask(ctx context.Context, task *models.Task) error// 等待 task 执行完成WaitSubtask(ctx context.Context, task *models.Task) error// 获取当前 runtime 所有可部署应用实例的 subnetDescribeSubnets(ctx context.Context, req *pb.DescribeSubnetsRequest) (*pb.DescribeSubnetsResponse, error)// 获取当前 runtime 所有可部署应用实例的 vpcDescribeVpc(ctx context.Context, runtimeId, vpcId string) (*models.Vpc, error)// 校验当前 runtime 资源情况,比如 quota 信息等CheckResource(ctx context.Context, clusterWrapper *models.ClusterWrapper) error// 校验当前 runtime 下 api server 的 url,credential 信息,可用区(zone)ValidateCredential(ctx context.Context, url, credential, zone string) error// 获取用户在当前 runtime 下所有可用区(zone)DescribeRuntimeProviderZones(ctx context.Context, url, credential string) ([]string, error)// 更新应用实例状态,根据 runtime 中资源情况,更新应用实例或应用实例节点的状态UpdateClusterStatus(ctx context.Context, job *models.Job) error// 获取应用实例更多详情信息,可在 DescribeClusters 时调用展示更多信息DescribeClusterDetails(ctx context.Context, cluster *models.ClusterWrapper) error}
实现 ProviderHandlerInterface 中所有函数 [可选]
如果实现 VM-Based 类型的 Provider Plugin,需要完成此步,应用实例的所有生命周期会自动按照 FrameInterface 中定义的方式操作。
- 创建 provider_handler.go 实现 “pkg/plugins/vmbased/handler_interface.go” 中 ProviderHandlerInterface 的所有函数。
type ProviderHandlerInterface interface {// 创建主机RunInstances(task *models.Task) error// 等待创建主机完成WaitRunInstances(task *models.Task) error// 关闭主机StopInstances(task *models.Task) error// 等待关闭主机完成WaitStopInstances(task *models.Task) error// 启动主机StartInstances(task *models.Task) error// 等待启动主机完成WaitStartInstances(task *models.Task) error// 删除主机DeleteInstances(task *models.Task) error// 等待删除主机完成WaitDeleteInstances(task *models.Task) error// 扩容主机ResizeInstances(task *models.Task) error// 等待扩容主机完成WaitResizeInstances(task *models.Task) error// 创建硬盘CreateVolumes(task *models.Task) error// 等待创建硬盘完成WaitCreateVolumes(task *models.Task) error// 卸载硬盘DetachVolumes(task *models.Task) error// 等待卸载硬盘完成WaitDetachVolumes(task *models.Task) error// 挂载硬盘AttachVolumes(task *models.Task) error// 等待挂载硬盘完成WaitAttachVolumes(task *models.Task) error// 删除硬盘DeleteVolumes(task *models.Task) error// 等待删除硬盘完成WaitDeleteVolumes(task *models.Task) error// 扩容硬盘ResizeVolumes(task *models.Task) error// 等待扩容硬盘完成WaitResizeVolumes(task *models.Task) error// 等待 frontgate 可用,该方法已在 FrameHandler 中实现WaitFrontgateAvailable(task *models.Task) error}
配置中增加该 Provider Plugin 支持
- “pkg/plugins/plugin.go” 中 init 函数部分注册该 Provider Plugin。
func init() {RegisterProvider(constants.ProviderKubernetes, helm.NewProvider())RegisterProvider(constants.ProviderQingCloud, qingcloud.NewProvider())RegisterProvider(constants.ProviderAWS, aws.NewProvider())}
当前内容版权归 OpenPitrix 或其关联方所有,如需对内容或内容相关联开源项目进行关注与资助,请访问 OpenPitrix .