[发明专利]提高虚拟机资源利用率的装置及方法有效
申请号: | 201611129930.2 | 申请日: | 2016-12-09 |
公开(公告)号: | CN106648832B | 公开(公告)日: | 2020-01-14 |
发明(设计)人: | 田松;王振宇 | 申请(专利权)人: | 武汉烽火信息集成技术有限公司 |
主分类号: | G06F9/455 | 分类号: | G06F9/455;G06F9/50 |
代理公司: | 42225 武汉智权专利代理事务所(特殊普通合伙) | 代理人: | 沈林华 |
地址: | 430073 湖*** | 国省代码: | 湖北;42 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 提高 虚拟机 资源利用率 装置 方法 | ||
1.一种提高虚拟机资源利用率的装置,其特征在于:该装置包括若干代理模块和一个执行模块,其中,代理模块位于虚拟机内部,执行模块位于虚拟机外部;
所述代理模块用于:作为虚拟机进程的一部分,对虚拟机提供的IO接口保持不变,只通过一个单线程接收虚拟机磁盘的IO请求,不处理IO请求,不连接到所有的OSD;当虚拟机需要访问存储时,将需要访问的IO请求转发给执行模块;
所述执行模块用于:启动时创建用于处理IO请求的线程池,并与每一个对象存储设备OSD建立链接,用于将IO请求发送到OSD节点;启用多线程并发处理代理模块发送过来的IO请求,将代理模块发来的IO请求数据按照固定长度进行分片,对分片后的IO请求数据进行计算,计算出分片后的IO请求数据需要保存到的OSD的位置,然后通过已经建立的链接,将分片后的IO请求数据发送到对应的OSD上。
2.如权利要求1所述的提高虚拟机资源利用率的装置,其特征在于:所述执行模块与每一个OSD建立传输控制协议链接。
3.一种应用于权利要求1所述装置的提高虚拟机资源利用率的方法,其特征在于,包括以下步骤:
S1、在虚拟机访问存储之前,执行模块先启用执行服务,创建用于处理输入/输出IO请求的线程池,并与每一个OSD建立链接,用于将IO请求发送到OSD节点;
S2、用户创建虚拟机时,生成一个虚拟机进程,虚拟机进程中包括代理模块,代理模块仅仅作为一个虚拟机进程中的一个线程存在,且代理模块对虚拟机提供的IO接口保持不变;
S3、代理模块不处理IO请求,不连接到所有的OSD,接收虚拟机的IO请求后,直接将IO请求放入队列中,当虚拟机需要访问存储时,代理模块将队列中的IO请求按照顺序逐一取出,发送给执行模块;
S4、执行模块启用多线程并发处理代理模块发送过来的IO请求,将代理模块发来的IO请求数据按照固定长度进行分片,对分片后的IO请求数据进行计算,计算出分片后的IO请求数据需要保存到的OSD的位置,然后通过已经建立的链接,将分片后的IO请求数据发送到对应的OSD上。
4.如权利要求3所述的提高虚拟机资源利用率的方法,其特征在于:步骤S1中,所述执行模块与每一个OSD建立传输控制协议链接。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于武汉烽火信息集成技术有限公司,未经武汉烽火信息集成技术有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201611129930.2/1.html,转载请声明来源钻瓜专利网。