华为云Stack南向开放框架,帮助生态伙伴高效入云
摘要:CloudBonder的生态社区通过一系列生态项目,解决提交叉组合、架构分层不清晰、运维界面不清晰等问题,简化对接流程,降低生态伙伴对接成本,缩短对接时间。
本文分享自华为云社区《【华为云Stack】【大架光临】第12期:华为云Stack南向开放框架,帮助生态伙伴高效入云》,作者: 大架光临 。
背景
从外部环境来看,政企客户存在软硬件分层的诉求;且南向开放能力也是竞争要求,能促进市场生态的繁荣。
从自身来看,华为云Stack不依靠单一封闭来参与竞争,而是追求硬件设备的效率最大化。华为云Stack要定义云平台下硬件需满足的功能、性能以及接口规范,是为了形成一个南向规范。通过开源社区来定义南向规范,让所有的硬件厂商都能参与进来,共同制定标准规范。
这个标准规范,包括各厂商实现的能力对接驱动,都是开源的、可以参考的,没有独家秘密可行。
南向规范的总体方案
华为云Stack南向规范的总体要求是,建立一个华为云Stack南向开源社区,通过生态化运作,使华为云Stack和生态伙伴责权清晰,共同制定和建立南向开放标准,构筑全生态差异化竞争力。
生态伙伴来开发自己的驱动包、自检完成后,生成华为云Stack规范包;华为来进行安装部署、并测试通过,和华为云Stack产品一起,安装部署在客户处。也就是说,生态产品本身的部署、扩容、运维和管理员操作,都是生态伙伴自己维护和操作的;华为负责部署华为云Stack系统,并和生态伙伴对接,同时,服务化的操作和运维入口在华为的统一界面。
.png)
南向规范的用户使用流程
南向设备的引入会产生很多复杂的问题,比如引入了海光、飞腾、鲲鹏三种服务器,又引入华为分布式存储和第三方分布式存储两种存储设备,如果设备与业务逻辑不解耦,就需要3*2种交叉组合,导致协同效率低下,影响客户的使用体验。另外,业务逻辑和驱动逻辑解耦不够彻底、设备和系统之间的运维责任界面不清晰等一系列问题也会伴随产生。
为解决这些问题,CloudBonder生态社区通过一系列生态项目来简化对接流程、降低对接成本、缩短对接时间。主要由CloudBonder南向框架、Magpie验证认证体系、Silkworm部署对接模块、Woodpecker监控运维四个子项目组成。
.png)
(1)CloudBonder
CloudBonder的是业务对接的框架,包括API和设备模型抽象,可支持存储、网络、计算数据面等方式的对接。可以对接很多种硬件设备,各厂商只要按照我们的模型和接口,实现自己设备的能力就好。
主要模块有WSGI API框架、统一的API框架、Manager层和Driver层。
• WSGI API框架:提供一个标准的API框架模型,让生态伙伴更多的关注自身的业务逻辑,而不是公共框架模型;
• 统一的API框架:主要负责参数检查等动作,封装API的返回值;
• Manager层:可加载驱动、支持CloudBonder的一些公共逻辑;
• Driver层:实现对接设备的逻辑、实现API定义的能力;不同厂商实现不同的Driver,接口和返回值在API中有规范的定义,而实现的能力是可选和可扩充的。
.png)
(2)Magpie
Magpie是厂商兼容性认证系统,可以规范和验收CloudBonder的能力,主要支持厂商的兼容性认证,其功能包括:
• 功能和性能的本地测试验证:Magpie的Driver测试不需要华为云Stack环境,可减少自身设备环境下的成本。另外,设备测试验证的控制,也都有对应的定义;
• 环境模拟:支持特定的环境模拟,比如DPU和裸机环境的模拟;
• FakeDriver:定义了一些FakeDriver,主要是测试Magpie框架本身
.png)
本地测试验证通过后,可以生成验证结果的报告,直接对比结果来调整。所有测试通过后,还会生成离线和在线的测试报告,证明对接过华为云Stack。
(3)Silkworm架构与技术
生态软件产品(包括驱动)以VM隔离方式部署在华为云Stack上;提供软件包的制作、OS部署升级和补丁推送,运维系统对接,监控告警日志诊断,依赖拓扑关系生成,服务控制启停等能力。
.png)
生态伙伴的软件部署在华为云Stack的系统中,目前有三个原则需要遵守:
一是:生态伙伴提供CloudBonder发行件采用VM部署。
如果部署在HostOS上,HostOS的升级会导致“非必要”的生态伙伴配套,影响现网局点和新部署局点。而HostOS的升级是由华为云Stack的业务规划的,相互之间最好不要影响。
二是:为考虑OS的维护能力,GuestOS采用商用OS,另外至少支持一款非涉A OS。
GuestOS目前由生态伙伴来提供;且必须在华为的兼容性范围内(可通过https://doc.华为云Stack.huawei.com/solution-cqs-gw/#/cqs来查询);同时要满足用户的安全要求;由于安全或者其他问题,给用户带来损失,由生态伙伴负责赔付;建议提供商用OS,而不是生态伙伴自己维护的OS。
三是:安装包的规范,按照DMK的要求来。
DMK是华为云Stack安装部署规范,是华为云Stack IaaS层提供的自动化部署工具,基于Ansible开发,部署脚本由接入方提供,同时需要按照DMK约束提供合规的zip包。DMK包支持安装,部署,升级,并支持界面化操作。
(4)Woodpecker架构和技术
Woodpecker是一套工具链,包含合作厂商运维数据接入ManageOne OC的开发框架和调测工具,目前支持的开发语言为Java。支持接入的数据范围包括:资源、监控(性能)、告警;合作厂商通过基于Woodpecker开发驱动,完成数据接入ManageOne OC侧。
.png)

写在最后
可以看到,CloudBonder的生态社区通过一系列生态项目,解决提交叉组合、架构分层不清晰、运维界面不清晰等问题,简化对接流程,降低生态伙伴对接成本,缩短对接时间。
从而让华为云Stack实现云平台南向设备框架设计分层解耦,生态伙伴设备模型标准化对接。
华为云Stack南向开放框架,帮助生态伙伴高效入云的更多相关文章
- 华为云Stack首席架构师:打造“称手”的数字化工具,答好政企IT数字化转型这道必选题
摘要:数字化转型是一号位工程,数字化的工具本身就是企业的核心竞争力. 本文分享自华为云社区<华为云Stack首席架构师:打造"称手"的数字化工具,答好政企IT数字化转型这道必 ...
- Tapdata 与阿里云 PolarDB 开源数据库社区联合共建开放数据技术生态
近日,阿里云 PolarDB 开源数据库社区宣布将与 Tapdata 联合共建开放数据技术生态.在此之际,一直专注实时数据服务平台的 Tapdata ,也宣布开源其数据源开发框架--PDK(Plu ...
- 阿里云启动视频云V5计划,全面赋能生态合作伙伴
9月25 - 27日,主题为数·智的2019云栖大会在杭州举行.在第三天的智能视频云专场中,阿里云研究员金戈首次对外发布视频云V5计划,释放视频IT基础设施红利,赋能生态合作伙伴,共促大视频产业发展. ...
- Cloud Native Weekly | 华为云抢先发布Redis5.0,红帽宣布收购混合云提供商 NooBaa
1——华为云抢先发布Redis5.0 2——DigitalOcean K8s服务正式上线 3——红帽宣布收购混合云提供商 NooBaa 4——微软发布多项 Azure Kubernetes 服务更新 ...
- phpadmin 装了6666端口只能在IE打开,在阿里云改了 开放端口85好了
phpadmin 装了6666端口只能在IE打开,在阿里云改了 开放端口85好了 非常用端口谷歌浏览器识别不了phpadmin
- 阿里云服务器 端口开放问题 浏览器钟输入ip 访问服务器
在这里先用一堆粗口强烈吐槽阿里云服务器控制台,屎一样的界面,简直非人类的操作.想找一个功能简直无从下手. 场景: 今天刚在阿里云买了个服务器,打算愉快的用五分钟将数据库,apache,安装完毕,然后去 ...
- 微软与阿里云合作推出“开放应用模型(OAM)”
英文原文:Announcing the Open Application Model (OAM) 原文标题:微软与阿里云合作推出“开放应用模型(OAM)” 用于 Kubernetes 及更多平台的应用 ...
- 开放应用模型操作指南(一)| 云服务一键接入 OAM 体系
作者 | 邓洪超 阿里云容器平台软件工程师 导读:Open Application Model(OAM)是阿里云联合微软等国际顶级技术团队联合发布的开放应用模型技术.旨在通过全新的应用定义.运维.分 ...
- dio框架访问云函数参数传递问题(以腾讯云中的云函数为例子)第一部
dd云函数其实比较普及,这里以腾讯云的云函数为例,传递参数完成简单的账号注册. 一.第一步先注册腾讯云账号,这里不过多阐述,接着点击 控制台 进入开发者界面.(注意提前进行实名认证) 二.开发者界面如 ...
随机推荐
- 如何改变函数内部 this 的指向
一.函数内 this 的指向 1. this 的指向是当调用函数时确定的,调用的方式不同,this 的指向也就不同. 1.1 this 一般是指向调用者. 函数类型 this 的指向 普通函数 Win ...
- 架构师必备:Redis的几种集群方案
结论 有以下几种Redis集群方案,先说结论: Redis cluster:应当优先考虑使用Redis cluster. codis:旧项目如果仍在使用codis,可继续使用,但也推荐迁移到Redis ...
- Spring按业务模块输出日志到不同的文件
一.背景 在我们开发的过程中,可能存在如下情况: 1.有些时候我们需要调用第三方的接口,一般情况下,调用接口,我们都会记录请求的入参和响应的.如果我们自己系统的日志和第三方的日志混合到一个日志文件中, ...
- 哈工大软件构造Lab1(2022)
目录 一.实验目标概述 二.实验环境配置 1.安装编写java程序的IDE--IntelliJ IDEA 2.安装Git 3.安装Junit 4.GitHub Lab1仓库的URL地址 三.实验过程 ...
- form表单与CSS选择器和样式操作
form表单 """获取前端用户数据并发送给后端服务器""" <form action=""></fo ...
- Docker容器的数据卷
一.数据卷概念 1.数据卷是宿主机中的一个目录或文件 2.当容器目录和数据卷目录绑定后,对方的修改会立即同步 3.一个数据卷可以被多个容器同时挂载 4.一个容器也可以挂载多个数据卷 简单理解:有点类似 ...
- k8s client-go源码分析 informer源码分析(3)-Reflector源码分析
k8s client-go源码分析 informer源码分析(3)-Reflector源码分析 1.Reflector概述 Reflector从kube-apiserver中list&watc ...
- Spring Security之短信登录
实现短信验证码登录 前面实现了 用户名+密码 的登录方式,现在实现一下短信验证码登录. 开发短信验证码接口 短信验证码和图形验证码类似,用户从手机短信得到验证码和从图片得到验证码类似. 校验短信验证码 ...
- Link-Cut-Tree(1)
参考论文 求解范围:(动态树问题) 树上路径查询.修改 动态连边.删边 换根 lca 算法逻辑 概念: 类似树链剖分,把一棵树拆成许多链,每个链用splay维护(链上的为实边,否则为虚边),splay ...
- Citrix Virtual Apps and Desktops 7 2203 LTSR虚拟云桌面单机教程
哈喽大家好,欢迎来到虚拟化时代君(XNHCYL). 大家好,我是虚拟化时代君,一位潜心于互联网的技术宅男.这里每天为你分享各种你感兴趣的技术.教程.软件.资源.福利--(每天更新不间断) 一 .主要内 ...