[发明专利]一种支持高并发命令执行通道的系统有效
申请号: | 201711434933.1 | 申请日: | 2017-12-26 |
公开(公告)号: | CN107896230B | 公开(公告)日: | 2020-04-10 |
发明(设计)人: | 吴秀民 | 申请(专利权)人: | 车智互联(北京)科技有限公司 |
主分类号: | H04L29/06 | 分类号: | H04L29/06;H04L29/08 |
代理公司: | 北京市盛峰律师事务所 11337 | 代理人: | 席小东 |
地址: | 100080 北京市海淀区*** | 国省代码: | 北京;11 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 一种 支持 并发 命令 执行 通道 系统 | ||
技术领域
本发明属于信息处理技术领域,具体涉及一种支持高并发命令执行通道的系统。
背景技术
随着互联网公司自建机房规模的不断扩大,服务器集群管理方案的需求越来越大。现有服务器集群管理方案,基本为C/S架构,主要分为两种,即Agent模式和Agentless模式。Agent模式是指:需要在客户端部署agent来完成代理工作。服务端和客户端的通信操作完全由agent负责,主要基于SSL实现通信和认证。Agentless模式是指:无需在客户端部署agent。服务端与客户端通过SSH来通信,服务端直接通过SSH协议来控制客户端的工作执行。
Agent模式具体通过以下方法实现:采用SaltStack集群管理解决方案,基于Python语言实现,结合轻量级消息队列(ZeroMQ)与Python第三方模块(Pyzmq、PyCrypto、Pyjinjia2、python-msgpack和PyYAML等)构建。其中,其中,SaltStack为一种管理工具,允许管理员对多个操作系统创建一个一致的管理系统,包括VMware vSphere环境。通过部署SaltStack环境,可以实现在成千上万的服务器上执行命令。
其中,SaltStack的操作入口有2个,一个是命令行模式,一个是基于服务端的HTTP的API接口。通过操作入口,向服务端传入对某个客户端相关操作的命令,服务端再通过消息队列与客户端通信,向客户端下发命令,由客户端的agent来执行命令,最后将操作命令的结果通过消息队列返回给服务端,回显给用户。过程如图1所示。在图1中,Salt Master代表:SaltStack的服务端。Salt Minion代表:SaltStack的客户端。
该种技术方案,主要具有以下缺点:
(1)命令下发的入口和服务端绑定,无法做到服务端无状态的扩展,因此,无法适配更大规模的集群。
(2)入口权限控制较弱,不可控制用户操作的客户端对象及可操作的功能。
(3)单台服务端所能管理的客户端数量有限,当客户端增多时,服务端性能会有所影响。
Agentless模式具体通过以下方法实现:采用Ansible集群管理方案,也是基于python开发,使用SSH通信,客户端无需部署Agent。Ansible更适合于小型的服务器集群的管理,对于大型的服务器集群,性能方便是其一大劣势。由于是基于SSH通信,对Windows系统的支持也不太友好。
因此,该种技术方案,主要具有以下缺点:
(1)基于SSH通信,当大批量客户端同时操作时,服务端性能存在问题;
(2)对于windows系统的支持不好。
发明内容
针对现有技术存在的缺陷,本发明提供一种支持高并发命令执行通道的系统,可有效解决上述问题。
本发明采用的技术方案如下:
本发明提供一种支持高并发命令执行通道的系统,包括:接收模块、负载均衡模块、连接器模块、发布订阅模块、代理服务端和客户端;
所述接收模块,用于接收管理员下发的操作命令,所述操作命令携带有具体操作命令信息、需要被操作的客户端ID以及管理员ID;然后,所述接收模块将所述操作命令发送给所述负载均衡模块;
所述负载均衡模块与若干个连接器模块连接,各个连接器模块为独立并列的模块,所述负载均衡模块基于负载均衡策略,选择最佳的连接器模块,并调用所选择的连接器模块的HTTP接口,将所述操作命令通过所述HTTP接口传入到所选择的所述连接器模块;
所述连接器模块,用于通过所述HTTP接口接收到所述操作命令时,解析所述操作命令,得到具体操作命令信息、需要被操作的客户端ID以及管理员ID;然后,所述连接器模块根据所述管理员ID,获取对应的管理员操作权限;再对所述管理员操作权限进行验证,如果验证不通过,则返回拒绝操作的通知消息;如果验证通过,则将所述操作命令发送到所述发布订阅模块;
所述发布订阅模块,用于发布接收到的来自于所述连接器模块的所述操作命令;
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于车智互联(北京)科技有限公司,未经车智互联(北京)科技有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201711434933.1/2.html,转载请声明来源钻瓜专利网。