CN104702469B - 监控网络数据的方法、实体机虚拟设备及网络*** - Google Patents

监控网络数据的方法、实体机虚拟设备及网络*** Download PDF

Info

Publication number
CN104702469B
CN104702469B CN201510142443.9A CN201510142443A CN104702469B CN 104702469 B CN104702469 B CN 104702469B CN 201510142443 A CN201510142443 A CN 201510142443A CN 104702469 B CN104702469 B CN 104702469B
Authority
CN
China
Prior art keywords
virtual unit
virtual
network
monitored
machine
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Active
Application number
CN201510142443.9A
Other languages
English (en)
Other versions
CN104702469A (zh
Inventor
李珂
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Beijing Qihoo Technology Co Ltd
Original Assignee
Beijing Qihoo Technology Co Ltd
Qizhi Software Beijing Co Ltd
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Beijing Qihoo Technology Co Ltd, Qizhi Software Beijing Co Ltd filed Critical Beijing Qihoo Technology Co Ltd
Priority to CN201510142443.9A priority Critical patent/CN104702469B/zh
Priority to CN201811621677.1A priority patent/CN109450742B/zh
Publication of CN104702469A publication Critical patent/CN104702469A/zh
Application granted granted Critical
Publication of CN104702469B publication Critical patent/CN104702469B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Landscapes

  • Data Exchanges In Wide-Area Networks (AREA)

Abstract

本发明公开了一种监控网络数据的方法、实体机虚拟设备及网络***。其中,所述方法包括:对网络中的待监控虚拟设备进行监控,并将监控过程中获取到的属于所述待监控虚拟设备的网络数据进行保存;接收虚拟机通过其上设置的虚拟设备发送的查询请求;从保存的网络数据中查找属于所述虚拟设备的网络数据;当查找到有属于所述虚拟设备的网络数据时,向所述虚拟机反馈查询响应。本发明实施例提供的技术方案节省了***资源,且极大的降低了实体机虚拟设备的压力。

Description

监控网络数据的方法、实体机虚拟设备及网络***
技术领域
本发明涉及一种计算机领域,特别是涉及一种监控网络数据的方法、实体机虚拟设备及网络***。
背景技术
为了提高服务端处理能力,企业中经常在实体机上搭建虚拟设备集群,提高事务处理能力。虚拟设备中处理事务,通常需要监控处理过程中产生的网络数据,每个虚拟设备启动一个监控本虚拟设备产生的网络数据的程序,多个虚拟设备并发执行时会给实体机的网卡造成非常大的网络压力,严重时会导致实体机与虚拟设备之间的网络带宽被占满,失去连接。
虚拟设备集群经常使用的是NAT(Network Address Translation,网络地址转换)模式(共享主机的IP)。该模式下,如图1所示,虚拟机10中的网络请求都是经过虚拟机网卡11(虚拟机与外界进行网络数据交换的虚拟化网络设备)发送给实体机虚拟网卡21(实体机20安装虚拟设备软件后虚化出来的网络设备),实体机虚拟网卡21再发送给实体机硬件网卡22(实体机与外网进行数据交换的网络硬件设备),再经过实体机硬件网卡22发送到公网机30上。同样道理,公网机器30的网络数据先发送到实体机硬件网卡22上,实体机硬件网卡22发送到实体机虚拟网卡21,实体机虚拟网卡21根据本地网络路由规则,发送到指定的虚拟机10上。
多并发下,同一台实体机20上所有的虚拟设备网络数据都是经过实体机20上的同一个实体机硬件网卡和同一个实体机虚拟网卡进行数据交换。虚拟机10里启动监控网络数据的程序,监控的是实体机20上同一个实体机虚拟网卡21,因此在高并发下,多个虚拟机10启动多个监控网络数据的程序,给实体机20的实体机虚拟网卡21造成了非常大的压力。虚拟机1中由于监控的是实体机20中的实体机虚拟网卡的网络数据,因此会捕获到虚拟机n中的网络数据而造成干扰。尤其是,当虚拟设备集群中虚拟机的个数达到10个以上时,实体机20的实体机虚拟网卡21的压力尤其显著,导致虚拟机10内部***环境变慢,影响虚拟机10内部程序运行甚至死机。此外,虚拟设备中启动的监控程序需要占用***资源,数目较大时,占用资源多,造成浪费。
发明内容
鉴于上述问题,提出了本发明以便提供一种克服上述问题或者至少部分地解决上述问题的监控网络数据的方法、实体机虚拟设备及网络***。
依据本发明一个方面,提供了一种监控网络数据的方法,包括:
对网络中的待监控虚拟设备进行监控,并将监控过程中获取到的属于所述待监控虚拟设备的网络数据进行保存;
接收虚拟机通过其上设置的虚拟设备发送的查询请求;
从保存的网络数据中查找属于所述虚拟设备的网络数据;
当查找到有属于所述虚拟设备的网络数据时,向所述虚拟机反馈查询响应。
依据本发明另一个方面,提供了一种实体机虚拟设备,包括:
监控保存模块,用于对网络中的待监控虚拟设备进行监控,并将监控过程中获取到的属于所述待监控虚拟设备的网络数据进行保存;
接收模块,用于接收虚拟机通过其上设置的虚拟设备发送的查询请求;
查找模块,用于从保存的网络数据中查找属于所述虚拟设备的网络数据;
反馈模块,用于当查找到有属于所述虚拟设备的网络数据时,向所述虚拟机反馈查询响应。
依据本发明另一个方面,还提供了一种网络***,包括:
公网机;
实体机,其上设有实体机硬件设备以及实体机虚拟设备,其中,所述实体机硬件设备与所述公网机通信连接,所述实体机硬件设备与所述实体机虚拟设备通信连接;
虚拟设备集群,其包括两个以上的虚拟机,所述虚拟机上设有虚拟设备,所述虚拟设备与所述实体机虚拟设备通信连接;
其中,所述实体机虚拟设备包括:
监控保存模块,用于对网络中的待监控虚拟设备进行监控,并将监控过程中获取到的属于所述待监控虚拟设备的网络数据进行保存;
接收模块,用于接收虚拟机通过其上设置的虚拟设备发送的查询请求;
查找模块,用于从保存的网络数据中查找属于所述虚拟设备的网络数据;
反馈模块,用于当查找到有属于所述虚拟设备的网络数据时,向所述虚拟机反馈查询响应。
借由上述技术方案,本发明实施例提供的技术方案至少具有下列优点:
本发明实施例提供的技术方案将现有技术中每个虚拟机中启动的网络监控程序改为集中监控的方案,即统一对网络中的待监控虚拟设备进行监控,并将监控过程中获取到的属于所述待监控虚拟设备的网络数据进行保存,当虚拟机中需要查看本机产生的网络数据时,再通过发送查询请求的方式来获取,由此监控程序的个数不再依赖于虚拟机启动的个数,监控程序任何时候只启动一个,节省了***资源,且极大的降低了实体机虚拟设备的压力,进而解决或部分解决现有技术因实体机虚拟设备的压力过大而导致的虚拟机内部***环境变慢,影响虚拟机内部程序运行甚至死机的问题。
上述说明仅是本发明技术方案的概述,为了能够更清楚了解本发明的技术手段,而可依照说明书的内容予以实施,并且为了让本发明的上述和其它目的、特征和优点能够更明显易懂,以下特举本发明的具体实施方式。
附图说明
通过阅读下文优选实施方式的详细描述,各种其他的优点和益处对于本领域普通技术人员将变得清楚明了。附图仅用于示出优选实施方式的目的,而并不认为是对本发明的限制。而且在整个附图中,用相同的参考符号表示相同的部件。在附图中:
图1示出了现有技术中网络架构示意图;
图2示出了本发明实施例一提供的监控网络数据的方法的流程示意图;
图3示出了本发明实施例二提供的监控网络数据的方法的流程示意图;
图4示出了本发明实施例三提供的实体机虚拟设备的组成框图;
图5示出了本发明实施例四提供的网络结构的组成框图。
具体实施方式
下面将参照附图更详细地描述本公开的示例性实施例。虽然附图中显示了本公开的示例性实施例,然而应当理解,可以以各种形式实现本公开而不应被这里阐述的实施例所限制。相反,提供这些实施例是为了能够更透彻地理解本公开,并且能够将本公开的范围完整的传达给本领域的技术人员。
如图2所示,本发明实施例一提供的监控网络数据的方法的流程示意图。本实施例提供的所述方法的执行主体可以是实体机虚拟设备,如实体机虚拟网卡。具体的,本实施例一提供的所述方法,包括:
步骤101、对网络中的待监控虚拟设备进行监控,并将监控过程中获取到的属于所述待监控虚拟设备的网络数据进行保存。
其中,所述属于所述待监控虚拟设备的网络数据为自所述待监控虚拟设备发出的数据和/或自公网机发送至所述待监控虚拟设备的数据。所述虚拟设备可以是设置在虚拟机上的虚拟机网卡。本实施例可直接使用winpcap的接口进行网络数据监控。winpcap(windows packet capture,Windows网络数据包捕获)是windows平台下一个免费,公共的网络访问***。开发winpcap这个项目的目的在于为win32应用程序提供访问网络底层的能力。Winpcap提供了一个强大的编程接口,它很容易地在各个操作***之间进行移植,也很方便程序员进行开发。
网络数据通常情况下是以数据包的形式在网络中传输的。为了能更加准确的对网络数据进行监控,方便查询,在保存时可先对网络数据进行解包,将解包后的网络数据进行保存。当然,直接将未解包的网络数据直接进行数据存储也可以。在后续查询后,可边解包边查询。若本步骤采用保存解包后的网络数据的方案,则,本步骤可采用如下步骤实现:
首先,对网络中的待监控虚拟设备进行监控,并获取监控到的属于所述待监控虚拟设备的网络数据。
然后,对所述网络数据进行解包。
随后,从解包后的网络数据中提取待保存的信息。
其中,提取出的所述信息可以是数据包中的所有数据,也可以是部分数据。例如,提取出的所述信息可包括:目的IP地址和端口、源IP和端口、请求类型、URI(UniformResource Identifier,统一资源标识符)请求、时间戳以及请求数据。所述请求类型可以包括:UDP(User Datagram Protocol,用户数据包协议)请求类型、HTTP(Hypertext transferprotocol,超文本传送协议)请求类型和TCP(Transmission Control Protocol,传输控制协议)请求类型。
最后,将提取到的所述信息进行保存。
步骤102、接收虚拟机通过其上设置的虚拟设备发送的查询请求。
在具体实施时,本实施例还可包括如下步骤:为虚拟机提供用于发送查询请求或反馈查询响应的Http接口。
有了Http接口后,虚拟机在需要查看本机产生的网络数据时,就可通过该Http接口向实体机虚拟设备发送查询请求。查询请求中可携带有唯一标识虚拟机的信息,如IP地址、虚拟机名称、虚拟机编号等等。
步骤103、从保存的网络数据中查找属于所述虚拟设备的网络数据。
在一种可实现的技术方案中,网络数据可保存在网络数据列表中。查询时,可从网络数据列表中查找出虚拟设备所要的网络数据。通过虚拟机发送的查询请求中携带的唯一标识自身的标识信息,如IP地址,名称或编号等等,从网络数据列表中找出包含该标识信息的网络数据。本发明实施例对所述查询请求中携带的标识信息不作具体限定。
例如,当所述查询请求中携带有所述虚拟设备的IP地址时,本可具体为:
根据所述IP地址,从保存的网络数据中查找出包含有所述IP地址的网络数据。
步骤104、当查找到有属于所述虚拟设备的网络数据时,向所述虚拟机反馈查询响应。
这里需要说明的是:本实施例步骤104仅示出了当查找到有属于所述虚拟设备的网络数据时,才向所述虚拟机反馈查询响应。当然,在实际应用中,即便是没有查找到属于所述虚拟设备的网络数据,也可向虚拟机反馈没有查找到的查询响应。即本实施例提供的所述方法,还包括:
当未查找到有属于所述虚拟设备的网络数据时,向所述虚拟机反馈未查到响应。
或者,不管查找到还是未查找到,均向所述虚拟机反馈携带有查询结果的响应信息。其中,当查找到时,查询结果可以是查找到的网络数据,当未找到时,查询结果可以是未找到提示信息。
本实施例提供的技术方案将现有技术中每个虚拟机中启动的网络监控程序改为集中监控的方案,即统一对网络中的待监控虚拟设备进行监控,并将监控过程中获取到的属于所述待监控虚拟设备的网络数据进行保存,当虚拟机中需要查看本机产生的网络数据时,再通过发送查询请求的方式来获取,由此监控程序的个数不再依赖于虚拟机启动的个数,监控程序任何时候只启动一个,节省了***资源,且极大的降低了实体机虚拟设备的压力,进而解决或部分解决现有技术因实体机虚拟设备的压力过大而导致的虚拟机内部***环境变慢,影响虚拟机内部程序运行甚至死机的问题。
进一步的,本发明实施例提供的所述方法还可包括:
首先,获取网络内所有虚拟设备的设备标识。
在具体实施时,本步骤可采用Winpcap中的pcap_findalldevs函数获取网络内所有虚拟设备的设备标识。采用pcap_findalldevs函数可枚举出网络中所有虚拟设备。
然后,根据所述设备标识,识别出所述所有虚拟设备中需监控的虚拟设备,作为所述待监控虚拟设备。
其中,所述设备标识可以是设备名称或其他能表征其为虚拟机上的虚拟设备的属性参数。相应的,本步骤可具体为:
将所述设备名称中包含有指定字符的虚拟设备作为所述待监控虚拟设备。
在具体实施时,上述的指定字符可以为“vmware”,本发明实施例对此不作具体限定。当然,除了通过设备名称来识别待监控虚拟设备外,还可通过其他能表征其是虚拟机中的虚拟网卡的属性参数,本发明实施例对此也不作具体限定。
如图3所示,本发明实施例二提供的监控网络数据的方法的流程示意图。本实施例二提供的所述方法,包括:
步骤201、实体机虚拟设备通过pcap_findalldevs函数枚举出网络中所有网卡。
步骤202、实体机虚拟设备获取所有网卡的名称,从所有网卡的名称中过滤出包含有指定字符的名称,将过滤出的名称对应的网卡标识为待监控虚拟网卡。
在具体实施时,上述的指定字符可以为“vmware”,本发明实施例对此不作具体限定。当然,除了通过设备名称来识别待监控虚拟设备外,还可通过其他能表征其是虚拟机中的虚拟网卡的属性参数,本发明实施例对此也不作具体限定。
步骤203、实体机虚拟设备对待监控虚拟网卡进行监控,并获取监控到的属于所述待监控虚拟设备的网络数据。
步骤204、实体机虚拟设备对获取到的网络数据进行解包,并从解包后的网络数据中提取目的IP地址和端口、源IP和端口、请求类型、统一资源标识符URI请求、时间戳以及请求数据等信息,并进行保存。
步骤205、虚拟机通过虚拟网卡向实体机虚拟设备发送携带有本机IP地址的查询请求。
步骤206、实体机虚拟设备根据查询请求中携带的IP地址,从保存的网络数据中查找所述虚拟机的网络数据,并通过http接口反馈查询响应。
其中,所述查询响应中携带有查询结果,如查找到的所述虚拟机的网络数据,或没有查找到。
这里需要说明的是,本发明各实施例提供的技术方案中网络结构均采用的是NAT模式。NAT模式即虚拟机拥有一个C类地址,192.168网段,不占用公司的真实IP地址,每个实体机内部形成一个虚拟机局域网,实体机的虚拟网卡作为网关,对于虚拟机的网络数据进行路由转发。公司内部通常采用NAT模式,鉴于该模式的特点,所有虚拟机的网络数据都会经过实体机虚拟网卡进行转发,因此本发明各实施例提供的技术方案仅监控该实体机虚拟网卡即可。
从上面的技术方案可知,本发明实施例是将监控程序移植到实体机中,监控实体机中的实体机虚拟网卡,资源消耗极大降低;而现有技术是在每个虚拟机内部启动监控程序,监控本虚拟机产生的网络数据;即较现有技术,本发明实施例将之前的每个虚拟设备内部启动监控程序,优化成实体机启动一个监控程序,监控实体机上的虚拟网卡的网络数据。大大降低了服务器的网络压力,提高虚拟设备并发执行的效率。
需要说明的是:对于前述的各方法实施例,为了简单描述,故将其都表述为一系列的动作组合,但是本领域技术人员应该知悉,本发明并不受所描述的动作顺序的限制,因为依据本发明,某些步骤可以采用其他顺序或者同时进行。其次,本领域技术人员也应该知悉,说明书中所描述的实施例均属于优选实施例,所涉及的动作和模块并不一定是本发明所必须的。
如图4所示,本发明实施例三提供的实体机虚拟设备的组成框图。本实施例三提供的所述实体机虚拟设备可实现上述实施例一和实施例二提供的方法。具体的,如图4所示,本实施例三所述的实体机虚拟设备,包括:监控保存模块1、接收模块2、查找模块3和反馈模块4。监控保存模块1用于对网络中的待监控虚拟设备进行监控,并将监控过程中获取到的属于所述待监控虚拟设备的网络数据进行保存;其中,所述属于所述待监控虚拟设备的网络数据为自所述待监控虚拟设备发出的数据和/或自公网机发送至所述待监控虚拟设备的数据。接收模块2用于接收虚拟机通过其上设置的虚拟设备发送的查询请求。查找模块3用于从保存的网络数据中查找属于所述虚拟设备的网络数据。反馈模块4用于当查找到有属于所述虚拟设备的网络数据时,向所述虚拟机反馈查询响应。
本实施例提供的技术方案将现有技术中每个虚拟机中启动的网络监控程序改为集中监控的方案,即统一对网络中的待监控虚拟设备进行监控,并将监控过程中获取到的属于所述待监控虚拟设备的网络数据进行保存,当虚拟机中需要查看本机产生的网络数据时,再通过发送查询请求的方式来获取,由此监控程序的个数不再依赖于虚拟机启动的个数,监控程序任何时候只启动一个,节省了***资源,且极大的降低了实体机虚拟设备的压力,进而解决或部分解决现有技术因实体机虚拟设备的压力过大而导致的虚拟机内部***环境变慢,影响虚拟机内部程序运行甚至死机的问题。
上述实施例中的提到的虚拟设备可具体为设置在虚拟机上的虚拟机网卡。
进一步的,上述的实体机虚拟设备,还包括:获取模块和识别模块。其中,获取模块,用于获取网络内所有虚拟设备的设备标识。识别模块,用于根据所述设备标识,识别出所述所有虚拟设备中需监控的虚拟设备,作为所述待监控虚拟设备。
再进一步的,所述设备标识为设备名称。相应的,识别模块,具体用于:将所述设备名称中包含有指定字符的虚拟设备作为所述待监控虚拟设备。
在具体实施时,上述的指定字符可以为“vmware”,本发明实施例对此不作具体限定。当然,除了通过设备名称来识别待监控虚拟设备外,还可通过其他能表征其是虚拟机中的虚拟网卡的属性参数,本发明实施例对此也不作具体限定。
进一步的,所述获取模块,具体用于:采用Windows网络数据包捕获Winpcap中的pcap_findalldevs函数获取网络内所有虚拟设备的设备标识。
进一步的,所述监控保存模块可采用如下结构实现。具体的,所述监控保存模块,包括:监控获取单元、解包单元、解包单元和保存模块。其中,监控获取单元,对网络中的待监控虚拟设备进行监控,并获取监控到的属于所述待监控虚拟设备的网络数据。解包单元,用于对所述网络数据进行解包。提取单元,用于从解包后的网络数据中提取待保存的信息。保存单元,用于将提取到的所述信息进行保存。
在具体实施时,所述信息可以包括:目的IP地址和端口、源IP和端口、请求类型、统一资源标识符URI请求、时间戳以及请求数据。
进一步的,所述查询请求中携带有所述虚拟设备的IP地址。相应的,所述查找模块,具体用于:根据所述IP地址,从保存的网络数据中查找出包含有所述IP地址的网络数据。
进一步的,所述实体机虚拟设备还包括:接口模块。其中,接口模块,用于为虚拟机提供用于发送查询请求或反馈查询响应的超文本传送协议Http接口。
如图5所示,本发明实施例四提供的网络结构的组成框图。本实施例四所述的网络结构包括:公网机5、实体机6和虚拟设备集群。实体机6上设有实体机硬件设备61以及实体机虚拟设备62,其中,所述实体机硬件设备61与所述公网机5通信连接,所述实体机硬件设备61与所述实体机虚拟设备62通信连接。虚拟设备集群包括两个以上的虚拟机7,所述虚拟机7上设有虚拟设备70,所述虚拟设备70与所述实体机虚拟设备62通信连接。所述实体机虚拟设备62包括:监控保存模块1、接收模块2、查找模块3和反馈模块4。所述监控保存模块1用于对网络中的待监控虚拟设备进行监控,并将监控过程中获取到的属于所述待监控虚拟设备的网络数据进行保存;其中,所述属于所述待监控虚拟设备的网络数据为自所述待监控虚拟设备发出的数据和/或自公网机发送至所述待监控虚拟设备的数据。接收模块2用于接收虚拟机通过其上设置的虚拟设备发送的查询请求。查找模块3用于从保存的网络数据中查找属于所述虚拟设备的网络数据。反馈模块4用于当查找到有属于所述虚拟设备的网络数据时,向所述虚拟机反馈查询响应。
这里需要说明的是:本实施例四中实体机虚拟设备可采用上述实施例三中的结构实现,具体的,实体机虚拟设备的实现结构和工作原理可参见上述各实施例中的对应内容,此处不再赘述。
本实施例提供的技术方案将现有技术中每个虚拟机中启动的网络监控程序改为集中监控的方案,即统一对网络中的待监控虚拟设备进行监控,并将监控过程中获取到的属于所述待监控虚拟设备的网络数据进行保存,当虚拟机中需要查看本机产生的网络数据时,再通过发送查询请求的方式来获取,由此监控程序的个数不再依赖于虚拟机启动的个数,监控程序任何时候只启动一个,节省了***资源,且极大的降低了实体机虚拟设备的压力,进而解决或部分解决现有技术因实体机虚拟设备的压力过大而导致的虚拟机内部***环境变慢,影响虚拟机内部程序运行甚至死机的问题。
在上述实施例中,对各个实施例的描述都各有侧重,某个实施例中没有详述的部分,可以参见其他实施例的相关描述。
可以理解的是,上述方法及装置中的相关特征可以相互参考。另外,上述实施例中的“第一”、“第二”等是用于区分各实施例,而并不代表各实施例的优劣。
所属领域的技术人员可以清楚地了解到,为描述的方便和简洁,上述描述的***,装置和单元的具体工作过程,可以参考前述方法实施例中的对应过程,在此不再赘述。
在此提供的算法和显示不与任何特定计算机、虚拟***或者其它设备固有相关。各种通用***也可以与基于在此的示教一起使用。根据上面的描述,构造这类***所要求的结构是显而易见的。此外,本发明也不针对任何特定编程语言。应当明白,可以利用各种编程语言实现在此描述的本发明的内容,并且上面对特定语言所做的描述是为了披露本发明的最佳实施方式。
在此处所提供的说明书中,说明了大量具体细节。然而,能够理解,本发明的实施例可以在没有这些具体细节的情况下实践。在一些实例中,并未详细示出公知的方法、结构和技术,以便不模糊对本说明书的理解。
类似地,应当理解,为了精简本公开并帮助理解各个发明方面中的一个或多个,在上面对本发明的示例性实施例的描述中,本发明的各个特征有时被一起分组到单个实施例、图、或者对其的描述中。然而,并不应将该公开的方法解释成反映如下意图:即所要求保护的本发明要求比在每个权利要求中所明确记载的特征更多的特征。更确切地说,如下面的权利要求书所反映的那样,发明方面在于少于前面公开的单个实施例的所有特征。因此,遵循具体实施方式的权利要求书由此明确地并入该具体实施方式,其中每个权利要求本身都作为本发明的单独实施例。
本领域那些技术人员可以理解,可以对实施例中的设备中的模块进行自适应性地改变并且把它们设置在与该实施例不同的一个或多个设备中。可以把实施例中的模块或单元或组件组合成一个模块或单元或组件,以及此外可以把它们分成多个子模块或子单元或子组件。除了这样的特征和/或过程或者单元中的至少一些是相互排斥之外,可以采用任何组合对本说明书(包括伴随的权利要求、摘要和附图)中公开的所有特征以及如此公开的任何方法或者设备的所有过程或单元进行组合。除非另外明确陈述,本说明书(包括伴随的权利要求、摘要和附图)中公开的每个特征可以由提供相同、等同或相似目的的替代特征来代替。
此外,本领域的技术人员能够理解,尽管在此所述的一些实施例包括其它实施例中所包括的某些特征而不是其它特征,但是不同实施例的特征的组合意味着处于本发明的范围之内并且形成不同的实施例。例如,在下面的权利要求书中,所要求保护的实施例的任意之一都可以以任意的组合方式来使用。
本发明的各个部件实施例可以以硬件实现,或者以在一个或者多个处理器上运行的软件模块实现,或者以它们的组合实现。本领域的技术人员应当理解,可以在实践中使用微处理器或者数字信号处理器(DSP)来实现根据本发明实施例的实体机虚拟设备中的一些或者全部部件的一些或者全部功能。本发明还可以实现为用于执行这里所描述的方法的一部分或者全部的设备或者装置程序(例如,计算机程序和计算机程序产品)。这样的实现本发明的程序可以存储在计算机可读介质上,或者可以具有一个或者多个信号的形式。这样的信号可以从因特网网站上下载得到,或者在载体信号上提供,或者以任何其他形式提供。
应该注意的是上述实施例对本发明进行说明而不是对本发明进行限制,并且本领域技术人员在不脱离所附权利要求的范围的情况下可设计出替换实施例。在权利要求中,不应将位于括号之间的任何参考符号构造成对权利要求的限制。单词“包含”不排除存在未列在权利要求中的元件或步骤。位于元件之前的单词“一”或“一个”不排除存在多个这样的元件。本发明可以借助于包括有若干不同元件的硬件以及借助于适当编程的计算机来实现。在列举了若干装置的单元权利要求中,这些装置中的若干个可以是通过同一个硬件项来具体体现。单词第一、第二、以及第三等的使用不表示任何顺序。可将这些单词解释为名称。
本发明公开了A1、一种监控网络数据的方法,包括:
对网络中的待监控虚拟设备进行监控,并将监控过程中获取到的属于所述待监控虚拟设备的网络数据进行保存;
接收虚拟机通过其上设置的虚拟设备发送的查询请求;
从保存的网络数据中查找属于所述虚拟设备的网络数据;
当查找到有属于所述虚拟设备的网络数据时,向所述虚拟机反馈查询响应。
A2、如A1所述的方法,所述虚拟设备为设置在虚拟机上的虚拟机网卡。
A3、如A1所述的方法,还包括:
获取网络内虚拟设备的设备标识;
根据所述设备标识,识别出所述虚拟设备中需监控的虚拟设备,作为所述待监控虚拟设备。
A4、如A3所述的方法,所述设备标识为设备名称;
相应的,根据所述设备标识,识别出所述虚拟设备中需监控的虚拟设备,作为所述待监控虚拟设备,具体为:
将所述设备名称中包含有指定字符的虚拟设备作为所述待监控虚拟设备。
A5、如A3所述的方法,所述获取网络内虚拟设备的设备标识,具体为:
采用Windows网络数据包捕获Winpcap中的pcap_findalldevs函数获取网络内虚拟设备的设备标识。
A6、如A1~A5中任一项所述的方法,所述对网络中的待监控虚拟设备进行监控,并将监控过程中获取到的属于所述待监控虚拟设备的网络数据进行保存,包括:
对网络中的待监控虚拟设备进行监控,并获取监控到的属于所述待监控虚拟设备的网络数据;
对所述网络数据进行解包;
从解包后的网络数据中提取待保存的信息;
将提取到的所述信息进行保存。
A7、如A6所述的方法,所述信息包括:目的IP地址和端口、源IP和端口、请求类型、统一资源标识符URI请求、时间戳以及请求数据。
A8、如A7所述的方法,所述查询请求中携带有所述虚拟设备的IP地址;
相应的,所述从保存的网络数据中查找属于所述虚拟设备的网络数据,具体为:
根据所述IP地址,从保存的网络数据中查找出包含有所述IP地址的网络数据。
A9、如A1~A5中任一项所述的方法,还包括:
为虚拟机提供用于发送查询请求或反馈查询响应的超文本传送协议Http接口。
A10、如A1~A5中任一项所述的方法,所述属于所述待监控虚拟设备的网络数据为自所述待监控虚拟设备发出的数据和/或自公网机发送至所述待监控虚拟设备的数据。
本发明还公开了B11、一种实体机虚拟设备,包括:
监控保存模块,用于对网络中的待监控虚拟设备进行监控,并将监控过程中获取到的属于所述待监控虚拟设备的网络数据进行保存;
接收模块,用于接收虚拟机通过其上设置的虚拟设备发送的查询请求;
查找模块,用于从保存的网络数据中查找属于所述虚拟设备的网络数据;
反馈模块,用于当查找到有属于所述虚拟设备的网络数据时,向所述虚拟机反馈查询响应。
B12、如B11所述的实体机虚拟设备,所述虚拟设备为设置在虚拟机上的虚拟机网卡。
B13、如B11所述的实体机虚拟设备,还包括:
获取模块,用于获取网络内虚拟设备的设备标识;
识别模块,用于根据所述设备标识,识别出所述虚拟设备中需监控的虚拟设备,作为所述待监控虚拟设备。
B14、如B13所述的实体机虚拟设备,所述设备标识为设备名称;
相应的,识别模块,具体用于:
将所述设备名称中包含有指定字符的虚拟设备作为所述待监控虚拟设备。
B15、如B13所述的实体机虚拟设备,所述获取模块,具体用于:
采用Windows网络数据包捕获Winpcap中的pcap_findalldevs函数获取网络内虚拟设备的设备标识。
B16、如B11~B15中任一项所述的实体机虚拟设备,所述监控保存模块,包括:
监控获取单元,对网络中的待监控虚拟设备进行监控,并获取监控到的属于所述待监控虚拟设备的网络数据;
解包单元,用于对所述网络数据进行解包;
提取单元,用于从解包后的网络数据中提取待保存的信息;
保存单元,用于将提取到的所述信息进行保存。
B17、如B16所述的实体机虚拟设备,所述信息包括:目的IP地址和端口、源IP和端口、请求类型、统一资源标识符URI请求、时间戳以及请求数据。
B18、如B17所述的实体机虚拟设备,所述查询请求中携带有所述虚拟设备的IP地址;
相应的,所述查找模块,具体用于:
根据所述IP地址,从保存的网络数据中查找出包含有所述IP地址的网络数据。
B19、如B11~B15中任一项所述的实体机虚拟设备,还包括:
接口模块,用于为虚拟机提供用于发送查询请求或反馈查询响应的超文本传送协议Http接口。
B20、如B11~B15中任一项所述的方法,所述属于所述待监控虚拟设备的网络数据为自所述待监控虚拟设备发出的数据和/或自公网机发送至所述待监控虚拟设备的数据。
本发明还公开了C21、一种网络***,包括:
公网机;
实体机,其上设有实体机硬件设备以及实体机虚拟设备,其中,所述实体机硬件设备与所述公网机通信连接,所述实体机硬件设备与所述实体机虚拟设备通信连接;
虚拟设备集群,其包括两个以上的虚拟机,所述虚拟机上设有虚拟设备,所述虚拟设备与所述实体机虚拟设备通信连接;
其中,所述实体机虚拟设备采用上述B 10~B 18中任一项所述的实体机虚拟设备。

Claims (21)

1.一种监控网络数据的方法,其特征在于,包括:
实体机虚拟设备对网络中的待监控虚拟设备进行监控,并将监控过程中获取到的属于所述待监控虚拟设备的网络数据进行保存;
接收虚拟机通过其上设置的虚拟设备发送的查询请求;
从保存的网络数据中查找属于所述虚拟设备的网络数据;
当查找到有属于所述虚拟设备的网络数据时,向所述虚拟机反馈查询响应。
2.根据权利要求1所述的方法,其特征在于,所述虚拟设备为设置在虚拟机上的虚拟机网卡。
3.根据权利要求1所述的方法,其特征在于,还包括:
获取网络内虚拟设备的设备标识;
根据所述设备标识,识别出所述虚拟设备中需监控的虚拟设备,作为所述待监控虚拟设备。
4.根据权利要求3所述的方法,其特征在于,所述设备标识为设备名称;
相应的,根据所述设备标识,识别出所述虚拟设备中需监控的虚拟设备,作为所述待监控虚拟设备,具体为:
将所述设备名称中包含有指定字符的虚拟设备作为所述待监控虚拟设备。
5.根据权利要求3所述的方法,其特征在于,所述获取网络内虚拟设备的设备标识,具体为:
采用Windows网络数据包捕获Winpcap中的pcap_findalldevs函数获取网络内虚拟设备的设备标识。
6.根据权利要求1~5中任一项所述的方法,其特征在于,所述实体机虚拟设备对网络中的待监控虚拟设备进行监控,并将监控过程中获取到的属于所述待监控虚拟设备的网络数据进行保存,包括:
对网络中的待监控虚拟设备进行监控,并获取监控到的属于所述待监控虚拟设备的网络数据;
对所述网络数据进行解包;
从解包后的网络数据中提取待保存的信息;
将提取到的所述信息进行保存。
7.根据权利要求6所述的方法,其特征在于,所述信息包括:目的IP地址和端口、源IP和端口、请求类型、统一资源标识符URI请求、时间戳以及请求数据。
8.根据权利要求7所述的方法,其特征在于,所述查询请求中携带有所述虚拟设备的IP地址;
相应的,所述从保存的网络数据中查找属于所述虚拟设备的网络数据,具体为:
根据所述IP地址,从保存的网络数据中查找出包含有所述IP地址的网络数据。
9.根据权利要求1~5中任一项所述的方法,其特征在于,还包括:
为虚拟机提供用于发送查询请求或反馈查询响应的超文本传送协议Http接口。
10.根据权利要求1~5中任一项所述的方法,其特征在于,所述属于所述待监控虚拟设备的网络数据为自所述待监控虚拟设备发出的数据和/或自公网机发送至所述待监控虚拟设备的数据。
11.一种实体机虚拟设备,其特征在于,包括:
监控保存模块,用于对网络中的待监控虚拟设备进行监控,并将监控过程中获取到的属于所述待监控虚拟设备的网络数据进行保存;
接收模块,用于接收虚拟机通过其上设置的虚拟设备发送的查询请求;
查找模块,用于从保存的网络数据中查找属于所述虚拟设备的网络数据;
反馈模块,用于当查找到有属于所述虚拟设备的网络数据时,向所述虚拟机反馈查询响应。
12.根据权利要求11所述的实体机虚拟设备,其特征在于,所述虚拟设备为设置在虚拟机上的虚拟机网卡。
13.根据权利要求11所述的实体机虚拟设备,其特征在于,还包括:
获取模块,用于获取网络内虚拟设备的设备标识;
识别模块,用于根据所述设备标识,识别出所述虚拟设备中需监控的虚拟设备,作为所述待监控虚拟设备。
14.根据权利要求13所述的实体机虚拟设备,其特征在于,所述设备标识为设备名称;
相应的,识别模块,具体用于:
将所述设备名称中包含有指定字符的虚拟设备作为所述待监控虚拟设备。
15.根据权利要求13所述的实体机虚拟设备,所述获取模块,具体用于:
采用Windows网络数据包捕获Winpcap中的pcap_findalldevs函数获取网络内虚拟设备的设备标识。
16.根据权利要求11~15中任一项所述的实体机虚拟设备,其特征在于,所述监控保存模块,包括:
监控获取单元,对网络中的待监控虚拟设备进行监控,并获取监控到的属于所述待监控虚拟设备的网络数据;
解包单元,用于对所述网络数据进行解包;
提取单元,用于从解包后的网络数据中提取待保存的信息;
保存单元,用于将提取到的所述信息进行保存。
17.根据权利要求16所述的实体机虚拟设备,其特征在于,所述信息包括:目的IP地址和端口、源IP和端口、请求类型、统一资源标识符URI请求、时间戳以及请求数据。
18.根据权利要求17所述的实体机虚拟设备,其特征在于,所述查询请求中携带有所述虚拟设备的IP地址;
相应的,所述查找模块,具体用于:
根据所述IP地址,从保存的网络数据中查找出包含有所述IP地址的网络数据。
19.根据权利要求11~15中任一项所述的实体机虚拟设备,其特征在于,还包括:
接口模块,用于为虚拟机提供用于发送查询请求或反馈查询响应的超文本传送协议Http接口。
20.根据权利要求11~15中任一项所述的实体机虚拟设备,其特征在于,所述属于所述待监控虚拟设备的网络数据为自所述待监控虚拟设备发出的数据和/或自公网机发送至所述待监控虚拟设备的数据。
21.一种网络***,其特征在于,包括:
公网机;
实体机,其上设有实体机硬件设备以及实体机虚拟设备,其中,所述实体机硬件设备与所述公网机通信连接,所述实体机硬件设备与所述实体机虚拟设备通信连接;
虚拟设备集群,其包括两个以上的虚拟机,所述虚拟机上设有虚拟设备,所述虚拟设备与所述实体机虚拟设备通信连接;
其中,所述实体机虚拟设备采用上述权利要求11~20中任一项所述的实体机虚拟设备。
CN201510142443.9A 2015-03-27 2015-03-27 监控网络数据的方法、实体机虚拟设备及网络*** Active CN104702469B (zh)

Priority Applications (2)

Application Number Priority Date Filing Date Title
CN201510142443.9A CN104702469B (zh) 2015-03-27 2015-03-27 监控网络数据的方法、实体机虚拟设备及网络***
CN201811621677.1A CN109450742B (zh) 2015-03-27 2015-03-27 监控网络数据的方法、实体机虚拟设备及网络***

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201510142443.9A CN104702469B (zh) 2015-03-27 2015-03-27 监控网络数据的方法、实体机虚拟设备及网络***

Related Child Applications (1)

Application Number Title Priority Date Filing Date
CN201811621677.1A Division CN109450742B (zh) 2015-03-27 2015-03-27 监控网络数据的方法、实体机虚拟设备及网络***

Publications (2)

Publication Number Publication Date
CN104702469A CN104702469A (zh) 2015-06-10
CN104702469B true CN104702469B (zh) 2019-02-12

Family

ID=53349259

Family Applications (2)

Application Number Title Priority Date Filing Date
CN201811621677.1A Expired - Fee Related CN109450742B (zh) 2015-03-27 2015-03-27 监控网络数据的方法、实体机虚拟设备及网络***
CN201510142443.9A Active CN104702469B (zh) 2015-03-27 2015-03-27 监控网络数据的方法、实体机虚拟设备及网络***

Family Applications Before (1)

Application Number Title Priority Date Filing Date
CN201811621677.1A Expired - Fee Related CN109450742B (zh) 2015-03-27 2015-03-27 监控网络数据的方法、实体机虚拟设备及网络***

Country Status (1)

Country Link
CN (2) CN109450742B (zh)

Families Citing this family (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN105099822A (zh) * 2015-08-04 2015-11-25 北京瑞汛世纪科技有限公司 一种测量网络性能的方法和物理机
CN105610639A (zh) * 2015-12-17 2016-05-25 北京奇虎科技有限公司 全量日志抓取方法及装置
CN109104426B (zh) * 2018-08-21 2020-05-22 西安交通大学 一种基于发包速率的加密流量分析防御方法
CN109639793A (zh) * 2018-12-10 2019-04-16 广东浪潮大数据研究有限公司 一种集群nas***监控方法、装置、设备及介质

Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN101436966A (zh) * 2008-12-23 2009-05-20 北京航空航天大学 虚拟机环境下的网络监控与分析***
CN101557420A (zh) * 2009-03-31 2009-10-14 北京航空航天大学 虚拟机监控器高效网络通信的实现方法
CN102147840A (zh) * 2010-02-05 2011-08-10 中国长城计算机深圳股份有限公司 一种通过虚拟机实现网络控制的方法
CN103746860A (zh) * 2013-10-25 2014-04-23 中国科学院计算技术研究所 一种虚拟化环境下的网络监控***及其方法
CN104462194A (zh) * 2014-10-28 2015-03-25 北京国双科技有限公司 一种业务数据的处理方法、装置及服务器

Family Cites Families (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN104021028B (zh) * 2014-05-16 2017-05-24 深圳市深信服电子科技有限公司 虚拟机环境下的web缓存方法及装置

Patent Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN101436966A (zh) * 2008-12-23 2009-05-20 北京航空航天大学 虚拟机环境下的网络监控与分析***
CN101557420A (zh) * 2009-03-31 2009-10-14 北京航空航天大学 虚拟机监控器高效网络通信的实现方法
CN102147840A (zh) * 2010-02-05 2011-08-10 中国长城计算机深圳股份有限公司 一种通过虚拟机实现网络控制的方法
CN103746860A (zh) * 2013-10-25 2014-04-23 中国科学院计算技术研究所 一种虚拟化环境下的网络监控***及其方法
CN104462194A (zh) * 2014-10-28 2015-03-25 北京国双科技有限公司 一种业务数据的处理方法、装置及服务器

Non-Patent Citations (1)

* Cited by examiner, † Cited by third party
Title
"基于WinPcap的以太网协议捕获和分析技术的研究";金定 等;《电脑知识与技术》;20110705;第4548-4549页

Also Published As

Publication number Publication date
CN109450742A (zh) 2019-03-08
CN104702469A (zh) 2015-06-10
CN109450742B (zh) 2021-04-16

Similar Documents

Publication Publication Date Title
CN103403707B (zh) 用于数据库代理请求交换的***和方法
CN104702469B (zh) 监控网络数据的方法、实体机虚拟设备及网络***
CN104980309B (zh) 网站安全检测方法及装置
JP2022536787A (ja) ネットワークデータプレーンのエッジデータベース管理
US9473369B2 (en) Application topology based on network traffic
CN104063425B (zh) 通过数据库中间件查询数据的方法和数据库中间件
CN107809383B (zh) 一种基于mvc的路径映射方法及装置
KR20110132973A (ko) 마이그레이션들 동안 네트워크 재구성을 자동화하는 방법
CN105631023B (zh) 分布式锁服务的方法和装置
CN111796858A (zh) Kubernetes集群内部应用程序访问检测的方法、***及相关设备
WO2007054606A2 (en) Method for the construction and execution of a distributed workflow in a communication system
CN101426000A (zh) 一种通用协议解析方法及***
CN106790601B (zh) 服务地址的读取装置、***和方法
CN108664613A (zh) 数据查询方法、装置、计算机设备及存储介质
JP2010117957A (ja) 構成管理サーバ、名称特定方法および名称特定プログラム
CN107463453A (zh) 同一终端不同应用间通信的方法、装置、设备和存储介质
CN108241496A (zh) 应用程序的平滑升级方法及装置
CN104732145A (zh) 一种虚拟机中的寄生进程检测方法和装置
Marchetto et al. A framework for verification-oriented user-friendly network function modeling
US10367785B2 (en) Software defined traffic modification system
Wan et al. Retina: analyzing 100GbE traffic on commodity hardware
CN103036895B (zh) 一种状态跟踪方法及***
EP3097662B1 (en) Methods, systems and computer readable media for testing network devices using simulated application traffic
CN109150844A (zh) 确定数字证书的方法、装置和***
CN102223266A (zh) 一种协议代理检测方法和装置

Legal Events

Date Code Title Description
C06 Publication
PB01 Publication
C10 Entry into substantive examination
SE01 Entry into force of request for substantive examination
GR01 Patent grant
GR01 Patent grant
TR01 Transfer of patent right
TR01 Transfer of patent right

Effective date of registration: 20220718

Address after: Room 801, 8th floor, No. 104, floors 1-19, building 2, yard 6, Jiuxianqiao Road, Chaoyang District, Beijing 100015

Patentee after: BEIJING QIHOO TECHNOLOGY Co.,Ltd.

Address before: 100088 room 112, block D, 28 new street, new street, Xicheng District, Beijing (Desheng Park)

Patentee before: BEIJING QIHOO TECHNOLOGY Co.,Ltd.

Patentee before: Qizhi software (Beijing) Co.,Ltd.