CN115037516A - 一种应用使用流量的统计方法、计算设备及存储介质 - Google Patents
一种应用使用流量的统计方法、计算设备及存储介质 Download PDFInfo
- Publication number
- CN115037516A CN115037516A CN202210470162.6A CN202210470162A CN115037516A CN 115037516 A CN115037516 A CN 115037516A CN 202210470162 A CN202210470162 A CN 202210470162A CN 115037516 A CN115037516 A CN 115037516A
- Authority
- CN
- China
- Prior art keywords
- application
- network
- preset time
- determining
- time period
- 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.)
- Granted
Links
- 238000007619 statistical method Methods 0.000 title claims abstract description 18
- 238000000034 method Methods 0.000 claims abstract description 196
- 230000008569 process Effects 0.000 claims abstract description 153
- 238000004891 communication Methods 0.000 claims abstract description 42
- 230000015654 memory Effects 0.000 claims description 22
- 238000012544 monitoring process Methods 0.000 abstract description 2
- 238000010586 diagram Methods 0.000 description 6
- 238000005516 engineering process Methods 0.000 description 3
- 230000006870 function Effects 0.000 description 3
- 238000012545 processing Methods 0.000 description 3
- 230000008901 benefit Effects 0.000 description 2
- 238000001914 filtration Methods 0.000 description 2
- 230000003287 optical effect Effects 0.000 description 2
- 230000026676 system process Effects 0.000 description 2
- 230000007723 transport mechanism Effects 0.000 description 2
- 230000008859 change Effects 0.000 description 1
- 238000001514 detection method Methods 0.000 description 1
- 238000011161 development Methods 0.000 description 1
- 238000004519 manufacturing process Methods 0.000 description 1
- 238000012986 modification Methods 0.000 description 1
- 230000004048 modification Effects 0.000 description 1
- 230000006855 networking Effects 0.000 description 1
- 230000003068 static effect Effects 0.000 description 1
- 238000011144 upstream manufacturing Methods 0.000 description 1
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L63/00—Network architectures or network communication protocols for network security
- H04L63/14—Network architectures or network communication protocols for network security for detecting or protecting against malicious traffic
- H04L63/1408—Network architectures or network communication protocols for network security for detecting or protecting against malicious traffic by monitoring network traffic
- H04L63/1425—Traffic logging, e.g. anomaly detection
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L63/00—Network architectures or network communication protocols for network security
- H04L63/14—Network architectures or network communication protocols for network security for detecting or protecting against malicious traffic
- H04L63/1441—Countermeasures against malicious traffic
- H04L63/145—Countermeasures against malicious traffic the attack involving the propagation of malware through the network, e.g. viruses, trojans or worms
Landscapes
- Engineering & Computer Science (AREA)
- Computer Security & Cryptography (AREA)
- Computer Hardware Design (AREA)
- Computing Systems (AREA)
- General Engineering & Computer Science (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Health & Medical Sciences (AREA)
- General Health & Medical Sciences (AREA)
- Virology (AREA)
- Data Exchanges In Wide-Area Networks (AREA)
Abstract
本发明涉及系统安全领域,公开了一种应用使用流量的统计方法、计算设备及存储介质。方法包括步骤:确定计算设备中每个应用行的一个或多个进程;确定计算设备中运行的每个进程进行网络通信所使用的套接字;调用数据包抓取模块获取预设时间段内通信的多个网络数据包;根据网络数据包所属的套接字,确定每个套接字在预设时间段内通信的一个或多个网络数据包;根据每个套接字在预设时间段内通信的一个或多个网络数据包,确定套接字对应进程在预设时间段内使用的网络流量;根据应用中每个进程在预设时间段使用的网络流量确定所述应用在预设时间段内使用的网络流量。本发明能够实现对应用使用流量的情况进行监控。
Description
技术领域
本发明涉及系统安全领域,特别涉及一种应用使用流量的统计方法、计算设备及存储介质。
背景技术
随着计算机技术的发展,人们越来越多地在计算机中使用各种应用完成工作,并且大多数应用都需要联网进行工作。大多数安全的应用在运行过程中会正常的进程网络通信,实现必要的数据的上传和下载;而一些恶意的应用可能会使用大量流量进行通信,损害计算机安全,占用计算机通信资源。
因此,需要对应用的流量负载进行监控。通过对应用的流量监控和联网控制能够对应用的通信进行管理,并实现恶意程序的检测。现有技术中只能对进程对于计算机的负载进行查询,判断进程使用了计算机的多少通信资源,而不能确定计算机中运行的每个应用具体使用的流量。
为此,需要一种新的应用使用流量的统计方法。
发明内容
为此,本发明提供一种应用使用流量的统计方法,以力图解决或者至少缓解上面存在的问题。
根据本发明的一个方面,提供一种应用使用流量的统计方法,适于在计算设备中执行,计算设备中运行有一个或多个应用,方法包括步骤:确定计算设备中每个应用所运行的一个或多个进程;确定计算设备中运行的每个进程进行网络通信所使用的套接字;调用数据包抓取模块获取预设时间段内通信的多个网络数据包;根据网络数据包所属的套接字,确定每个套接字在预设时间段内通信的一个或多个网络数据包;根据每个套接字在预设时间段内通信的一个或多个网络数据包,确定套接字对应进程在预设时间段内使用的网络流量;根据应用中每个进程在预设时间段使用的网络流量确定应用在预设时间段内使用的网络流量。
可选地,在根据本发明的方法中,确定计算设备中每个应用所运行的一个或多个进程包括步骤:确定计算设备中每个应用的一个或多个文件路径,并创建应用路径表,应用路径表包括计算设备中每个应用及对应的文件路径;获取计算设备中运行的所有进程,并根据进程的进程信息创建进程路径表,进程路径表包括计算设备中每个进程及对应的文件路径;根据应用路径表和进程路径表确定每个应用所对应的进程。
可选地,在根据本发明的方法中,确定计算设备中每个应用的一个或多个文件路径,并创建应用路径表包括步骤:获取应用的一个或多个应用文件;判断应用的每个应用文件是否为可执行文件;如果应用文件是可执行文件,则将应用文件的文件路径加入应用路径表。
可选地,在根据本发明的方法中,根据应用路径表和进程路径表确定每个应用所对应的进程包括步骤:根据应用路径表和进程路径表中包括的文件路径确定每个应用对包括的一个或多个进程。
可选地,在根据本发明的方法中,确定计算设备中运行的每个进程进行网络通信所使用的套接字包括步骤:获取进程的进程信息;根据进程的进程信息确定该进程进行网络通信所使用的套接字。
可选地,在根据本发明的方法中,计算设备连接有通信设备,调用数据包抓取模块获取预设时间段内通信的多个网络数据包包括步骤:数据包抓取模块从通信设备获取在预设时间段内通信的多个网络数据包。
可选地,在根据本发明的方法中,根据网络数据包所属的套接字,确定每个套接字在预设时间段内通信的一个或多个网络数据包包括步骤:根据网络数据包中数据信息的进程标识确定网络数据包所属的进程;根据每个网络数据包所属的进程确定每个进程在预设时间端内通信的一个或多个网络数据包。
可选地,在根据本发明的方法中,根据每个套接字在预设时间段内通信的一个或多个网络数据包,确定套接字对应进程在预设时间段内使用的网络流量包括步骤:根据每个网络数据包的数据包大小确定套接字对应进程在预设时间段内使用的网络流量。
可选地,在根据本发明的方法中,根据应用中每个进程在预设时间段使用的网络流量确定应用在预设时间段内使用的网络流量包括步骤:将应用的每个进程在预设时间段使用的网络流量相加得到应用在预设时间段内使用的网络流量。
根据本发明的另一个方面,提供了一种计算设备,包括:一个或多个处理器;存储器;以及一个或多个程序,其中一个或多个程序存储在存储器中并被配置为由一个或多个处理器执行,一个或多个程序包括用于执行根据本发明的应用使用流量的统计方法。
根据本发明的再一个方面,提供了一种存储一个或多个程序的计算机可读存储介质,一个或多个程序包括指令,该指令当由计算设备执行时,使得计算设备执行根据本发明的应用使用流量的统计方法。
本发明公开了一种应用使用流量的统计方法,适于在计算设备中执行。计算设备中运行有一个或多个应用,方法包括步骤:确定计算设备中每个应用行的一个或多个进程;确定计算设备中运行的每个进程进行网络通信所使用的套接字;调用数据包抓取模块获取预设时间段内通信的多个网络数据包;根据网络数据包所属的套接字,确定每个套接字在预设时间段内通信的一个或多个网络数据包;根据每个套接字在预设时间段内通信的一个或多个网络数据包,确定套接字对应进程在预设时间段内使用的网络流量;根据应用中每个进程在预设时间段使用的网络流量确定所述应用在预设时间段内使用的网络流量。本发明通过调用数据包抓取模块对网络数据包进行抓取,能够确定每个进程在预设时间端内使用的网络流量;接着统计应用所有进程使用的网络流量,即能够统计应用使用的流量,实现对应用使用流量的情况进行监控。
附图说明
为了实现上述以及相关目的,本文结合下面的描述和附图来描述某些说明性方面,这些方面指示了可以实践本文所公开的原理的各种方式,并且所有方面及其等效方面旨在落入所要求保护的主题的范围内。通过结合附图阅读下面的详细描述,本发明公开的上述以及其它目的、特征和优势将变得更加明显。遍及本公开,相同的附图标记通常指代相同的部件或元素。
图1示出了根据本发明一个示范性实施例的计算设备100的示意图;
图2示出了根据本发明一个示范性实施例的应用使用流量的统计方法200的流程示意图;
图3示出了根据本发明的一个示范性实施例的确定应用使用网络流量的示意图。
具体实施方式
下面将参照附图更详细地描述本公开的示例性实施例。虽然附图中显示了本公开的示例性实施例,然而应当理解,可以以各种形式实现本公开而不应被这里阐述的实施例所限制。相反,提供这些实施例是为了能够更透彻地理解本公开,并且能够将本公开的范围完整的传达给本领域的技术人员。相同的附图标记通常指代相同的部件或元素。
首先参考图1,图1示出了根据本发明一个示范性实施例的计算设备100的示意图。如图1所示,计算设备100中包括内部存储器111、外部存储器112、中央处理器113和图形处理器114。内部存储器111包括但不限于易失性存储(例如,随机存取存储器)、非易失性存储(例如,只读存储器)、闪速存储器、或者这样的存储器的任何组合。外部存储器112是指除内部存储器111及中央处理器113缓存以外的储存器,具体可实现为硬盘、软盘、光盘、U盘等。中央处理器113是计算设备100的运算核心和控制和核心,用于解析计算机指令以及处理计算机软件中的数据。图形处理器114是计算设备中做图像和图形相关运算工作的微处理器。
计算设备100基于上述部件还运行有操作系统120,适合于控制计算设备100的操作。此外,示例结合图形库、其他操作系统、或任何其他应用程序而被实践,并且不限于任何特定的应用或系统。本发明对操作系统120的具体类型不做限制。
计算设备100中还可基于操作系统120运行有一个或多个应用,如图1中所示的应用131~应用133。本发明对计算设备100中运行的应用数量及种类不做限制,例如应用可实现为:电子邮件和联系人应用程序、文字处理应用程序、电子表格应用程序、数据库应用程序、幻灯片展示应用程序、绘画或计算机辅助应用程序、网络浏览器应用程序等。
操作系统120中包括为操作系统120或所运行应用提供网络通信服务的网络接口层121。网络接口层121中包括网络接口122和通信驱动程序123。网络接口122为用于被调用进行通信的接口。计算设备100还可与通信设备143通信连接。本发明对计算设备100与通信设备143进行通信连接的方式不做限制。根据本发明的一个实施例,通信设备143具体可实现为网卡设备,本发明对通信设备143的具体实现方式不做限制。操作系统120可通过网络接口122调用通信驱动程序123,以便使计算设备100能够通过通信设备143与其他设备进行通信。
操作系统120中还包括内核层124,内核层124中包括内核缓冲区125,可用于缓存网络借口要发送或返回的网络数据。
根据一个方面,计算设备100还可以连接一个或多个输入设备141,例如键盘、鼠标、笔、语音输入设备、触摸输入设备等。还可以连接一个或多个输出设备114,例如显示器、扬声器、打印机等。前述设备是示例并且也可以使用其他设备。计算设备100可以包括允许与其他计算设备进行通信的一个或多个通信连接。合适的通信连接的示例包括但不限于:RF发射机、接收机和/或收发机电路;通用串行总线(USB)、并行和/或串行端口。
本发明实施方式还提供一种非暂态可读存储介质,存储有指令,所述指令用于使所述计算设备执行根据本发明实施方式的方法。本实施例的可读介质包括永久性和非永久性、可移动和非可移动介质,可以由任何方法或技术来实现信息存储。信息可以是计算机可读指令、数据结构、程序的模块或其他数据。可读存储介质的例子包括但不限于:相变内存(PRAM)、静态随机存取存储器(SRAM)、动态随机存取存储器(DRAM)、其他类型的随机存取存储器(RAM)、只读存储器(ROM)、电可擦除可编程只读存储器(EEPROM)、快闪记忆体或其他内存技术、只读光盘只读存储器(CD-ROM)、数字多功能光盘(DVD)或其他光学存储、磁盒式磁带,磁带磁盘存储或其他磁性存储设备或任何其他非暂态可读存储介质。
根据一个方面,通信介质是由计算机可读指令、数据结构、程序模块、或者经调制的数据信号(例如,载波或其他传输机制)中的其他数据实施的,并且包括任何信息传递介质。根据一个方面,术语“经调制的数据信号”描述了具有一个或多个特征集或者以将信息编码在信号中的方式改变的信号。作为示例而非限制,通信介质包括诸如有线网络或直接有线连接之类的有线介质,以及诸如声学、射频(RF)、红外线的、以及其他无线介质之类的无线介质。
本发明中为了实现对计算设备中运行应用的使用流量进行统计,构建了数据包抓取模块134,用于抓取用于通信的网络数据包。本发明还提供了一种应用使用流量的统计方法200,用于统计应用的使用流量。本发明的应用使用流量的统计方法适于在计算设备中执行,如在计算设备100中执行。下面结合图2详细介绍应用使用流量的统计方法200中的各步骤,并对数据包抓取模块134的工作过程进行说明。
图2示出了根据本发明一个示范性实施例的应用使用流量的统计方法200的流程示意图。如图2所示,首先执行步骤S210,确定计算设备中每个应用所运行的一个或多个进程。确定应用对应的进程时:先确定计算设备中每个应用的一个或多个文件路径,并创建应用路径表,应用路径表包括计算设备中每个应用及对应的文件路径。
根据本发明的一个实施例,可建立数据库用于存储应用路径表。应用路径表为数据库中的数据表。应用路径表中包括应用字段和文件路径字段。应用字段用于存储计算设备中所包括的所有应用。文件路径字段用于存储应用的一个或多个文件路径。由于应用可包括一个或多个文件,相应的有一个或多个文件路径。因此应用路径表中,每个应用可包括一条或多条记录用于存储文件路径。
在将应用的文件路径添加到应用路径表时,有选择性的进行添加;具体的:获取应用的一个或多个应用文件;判断应用的每个应用文件是否为可执行文件;如果应用文件是可执行文件,则将应用文件的文件路径加入应用路径表。
为了避免向应用路径表中写入数据时内存占用过高,由于只有可执行文件才能够进行网络通信,因此不将非可执行文件的文件路径添加到应用路径表,避免需要频繁写入应用路径表,以及减少写入的数据量,提高对应用使用流量的统计效率。
根据本发明的一个实施例,在首次进行应用的使用流量统计时,建立数据库和应用路径表。后续当计算设备中所包括的应用发生变化时,根据变化的应用对应用路径表进行更新。
根据本发明的一个实施例,对如图1所示的计算设备100中所运行应用131-133的使用流量进行统计时,创建数据库cache.db,并在数据库cache.db中创建package_app_file应用路径表。通过dpkg命令查询所运行的应用及相关联的应用文件的文件路径。将应用131-应用133作为应用路径表的应用字段;具体的可将各应用的包名写入应用路径表中。本发明对应用路径表记载应用的形式不做限制。将各个应用的应用文件的文件路径写入应用路径表中,以应用131为例,将查询到的应用131的应用文件a和应用文件b的文件路径添加到应用路径表中。
根据本发明的一个实施例,通过dpkg--search‘*.desktop’命令,查询系统中所包括的所有应用对应的包名,从而确定计算设备中所包括的应用;
通过dpkg-L“包名”命令,确定与每个应用相关联的应用文件,再对每个应用文件进行判断,过滤非执行文件,将可执行文件类型的应用文件的文件路径添加到应用路径表中。
根据本发明的一个实施例,过滤非执行文件时,可通过文件后缀名进行判断;具体的非可执行文件的后缀名包括但不限于:.svg.png.qm.htm.gif.jpg等。
根据本发明的一个实施例,为了防止在统计应用的使用流量时,数据库被误删导致无法读取应用路径表时,可在后续每次统计应用的使用流量前判断数据库是否存在,若不存在则及时重新进行创建。
根据本发明的一个实施例,为了降低对应用路径表的写入数据量,以及提高系统运行性能,在卸载应用时只删除所卸载应用的包名;在新安装应用时,只添加该应用相关的应用文件的文件路径。
随后获取计算设备中运行的所有进程,并根据进程的进程信息创建进程路径表,进程路径表包括计算设备中每个进程及对应的文件路径。
根据本发明的一个实施例,获取计算设备中运行的所有进程时,可从计算设备的系统进程目录/proc中获取系统当前运行的所有进程。系统进程目录中还对应存储有每个进程的进程信息,包括进程相对应的应用文件。应用文件相对应的进程是指该应用文件为可执行文件运行时产生的进程;进程与产生该进程的引用文件相关联。根据进程相对应应用文件可确定应用文件的文件路径。
根据本发明的一个实施例,为了统计预设时间段内的应用使用流量情况,可每隔预设时间段获取计算设备中运行的所有进程,得到进程路径表。同时根据后续步骤获取预设时间段进程通信的网络数据包,从而确定应用的使用流量。
最后,根据应用路径表和进程路径表确定每个应用所对应的进程;具体的:根据路径表和进程路径表中包括的文件路径确定每个应用对包括的一个或多个进程。
应用路径表包括应用及对应的一个或多个应用文件的文件路径;进程路径表包括进程及对应应用文件的文件路径,因此比照应用路径表和进程路径表中文件路径,即可确定应用的一个或多个进程。应用对应的文件路径与进程对应的文件路径相同,即可确定该应用与此进程相关联。
随后,执行步骤S220,确定计算设备中运行的每个进程进行网络通信所使用的套接字。根据本发明的一个实施例,计算设备中运行进程需要通信时,会通过建立套接字(socket)进行通信。套接字(socket)是对网络中不同主机上的应用进程之间进行双向通信的端点的抽象。每个进程对应的应用文件是唯一的,而应用文件对应的文件节点(如inode)是唯一的。而每个文件节点会使用唯一套接字(socket)进行通信,因此通过进行的唯一套接字能够确定进程使用的流量情况。
根据本发明的一个实施例,确定进程对应套接字(socket)时,先获取进程的进程信息,再根据进程的进程信息确定该进程进行网络通信所使用的套接字。
随后,执行步骤S230,调用数据包抓取模块获取预设时间段内通信的多个网络数据包。根据本发明的一个实施例,计算设备中预先构建有数据包抓取模块,数据包抓取模块可通过libpcap(packet capture library)数据包捕获函数库实现;具体的:通过调用数据包抓取模块关联并嗅探与计算设备通信连接网络模块,获取网络模块在预设时间段内所收发的多个网络数据包,作为计算设备在预设时间段内通信的多个网络数据包。
根据本发明的一个实施例,计算设备所通信的网络数据包可实现为多种通信协议类型的数据包:如:tcp数据包、tcp6数据包、udp数据包及udp6数据包等。
随后,执行步骤S240,根据网络数据包所属的套接字,确定每个套接字在预设时间段内通信的一个或多个网络数据包。根据本发明的一个实施例,每个网络数据包均包括数据信息,用于存储关于网络数据包的信息。数据信息包括产生该网络数据包或接收该网络数据包的进程标识。确定每个套接字通信的网络数据包时,根据网络数据包中数据信息的进程标识确定网络数据包所属的进程,再根据每个网络数据包所属的进程确定每个进程在预设时间端内通信的一个或多个网络数据包。每个进程在预设时间端内可通信一个或多个数据包。
随后,执行步骤S250,根据每个套接字在预设时间段内通信的一个或多个网络数据包,确定套接字对应进程在预设时间段内使用的网络流量;具体的:根据每个网络数据包的数据包大小确定套接字对应进程在预设时间段内使用的网络流量;即将各数据包的大小相加得到进程在预设时间段内使用的网络流量。
根据本发明的一个实施例,由于每个进程均会产生上行流量或下行流量。上行流量即为应用的上传流量;下行流量即为应用的下载流量。因此在统计每个套接字对应进程在预设时间段内使用的网络流量时,可分别统计上行流量和下行流量:统计上行流量时,可将上传的一个或多个网络数据包的大小相加;统计下行流量时,可将下载的一个或多个网络数据包的大小相加。在统计时,可通过网络数据包中的数据信息确定网络数据包是下载的还是上传的。
根据本发明的一个实施例,在得到每个套接字对应进程在预设时间段内使用的网络流量后,可建立进程流量表存储进程及对应的网络流量。
随后,执行步骤S260,根据应用中每个进程在预设时间段使用的网络流量确定应用在预设时间段内使用的网络流量;具体的:将应用的每个进程在预设时间段使用的网络流量相加得到应用在预设时间段内使用的网络流量。
根据本发明的一个实施例,在统计每个应用使用的网络流量时,可分别对上传流量和下载流量进行统计;在统计上传流量时,将应用所包括各进程的上行流量相加得到应用的上传流量;在统计下载流量时,将应用所包括各进程的下行流量相加得到应用的下载流量。
根据本发明的一个实施例,在统计应用使用的网络流量时,可根据需要对预设时间段进行设置,如将预设时间段设置为2s。并且将预设时间段内使用的网络流量除以预设时间段即可得到应用的网速情况。
图3示出了根据本发明的一个示范性实施例的确定应用使用网络流量的示意图。如图3所示:首次确定应用使用流量时执行步骤1-6:先初始化内核缓冲区,建立缓冲区和应用路径表,随后每预设时间段间隔确定运行的进程,将进程对应的应用文件的文件路径发送到内核缓冲区,制作进程路径表。再根据应用路径表和进程路径表确定应用所包括的一个或多个进程。其中,预设时间段可设置为2s。接着调用数据包抓取模块获取预设时间段内通信的多个网络数据包,再根据网络数据包所属的套接字,确定每个套接字在预设时间段内通信的一个或多个网络数据包。通过对每个套接字在预设时间段内通信的一个或多个网络数据包进行计算得到每个进程的网络流量。通过对应用的每个进程的网络流量进行加和得到每个应用使用的网络流量。
在后续重复确定应用使用流量时,执行步骤7-11。步骤7-11即为重复执行上述步骤2-6。
根据本发明的应用使用流量的统计方法,能够对应用使用流量进行统计,监控计算设备中所有应用的网络使用情况;进一步的判断是都有恶意程序占用带宽网络,提高系统使用安全性。
本发明公开了一种应用使用流量的统计方法,适于在计算设备中执行。计算设备中运行有一个或多个应用,方法包括步骤:确定计算设备中每个应用行的一个或多个进程;确定计算设备中运行的每个进程进行网络通信所使用的套接字;调用数据包抓取模块获取预设时间段内通信的多个网络数据包;根据网络数据包所属的套接字,确定每个套接字在预设时间段内通信的一个或多个网络数据包;根据每个套接字在预设时间段内通信的一个或多个网络数据包,确定套接字对应进程在预设时间段内使用的网络流量;根据应用中每个进程在预设时间段使用的网络流量确定所述应用在预设时间段内使用的网络流量。本发明通过调用数据包抓取模块对网络数据包进行抓取,能够确定每个进程在预设时间端内使用的网络流量;接着统计应用所有进程使用的网络流量,即能够统计应用使用的流量,实现对应用使用流量的情况进行监控。
在此处所提供的说明书中,说明了大量具体细节。然而,能够理解,本发明的实施例可以在没有这些具体细节的情况下被实践。在一些实例中,并未详细示出公知的方法、结构和技术,以便不模糊对本说明书的理解。
类似地,应当理解,为了精简本公开并帮助理解各个发明方面中的一个或多个,在上面对本发明的示例性实施例的描述中,本发明的各个特征有时被一起分组到单个实施例、图、或者对其的描述中。
本领域那些技术人员应当理解在本文所公开的示例中的设备的模块或单元或组间可以布置在如该实施例中所描述的设备中,或者可替换地可以定位在与该示例中的设备不同的一个或多个设备中。前述示例中的模块可以组合为一个模块或者此外可以分成多个子模块。
本领域那些技术人员可以理解,可以对实施例中的设备中的模块进行自适应性地改变并且把它们设置在与该实施例不同的一个或多个设备中。可以把实施例中的模块或单元或组间组合成一个模块或单元或组间,以及此外可以把它们分成多个子模块或子单元或子组间。除了这样的特征和/或过程或者单元中的至少一些是相互排斥之外,可以采用任何组合对本说明书中公开的所有特征以及如此公开的任何方法或者设备的所有过程或单元进行组合。除非另外明确陈述,本说明书中公开的每个特征可以由提供相同、等同或相似目的的替代特征来代替。
此外,本领域的技术人员能够理解,尽管在此所述的一些实施例包括其它实施例中所包括的某些特征而不是其它特征,但是不同实施例的特征的组合意味着处于本发明的范围之内并且形成不同的实施例。
此外,所述实施例中的一些在此被描述成可以由计算机系统的处理器或者由执行所述功能的其它装置实施的方法或方法元素的组合。因此,具有用于实施所述方法或方法元素的必要指令的处理器形成用于实施该方法或方法元素的装置。此外,装置实施例的在此所述的元素是如下装置的例子:该装置用于实施由为了实施该发明的目的的元素所执行的功能。
这里描述的各种技术可结合硬件或软件,或者它们的组合一起实现。从而,本发明的方法和设备,或者本发明的方法和设备的某些方面或部分可采取嵌入有形媒介,例如软盘、CD-ROM、硬盘驱动器或者其它任意机器可读的存储介质中的程序代码(即指令)的形式,其中当程序被载入诸如计算机之类的机器,并被所述机器执行时,所述机器变成实践本发明的设备。
在程序代码在可编程计算机上执行的情况下,计算设备一般包括处理器、处理器可读的存储介质(包括易失性和非易失性存储器和/或存储元件),至少一个输入装置,和至少一个输出装置。其中,存储器被配置用于存储程序代码;处理器被配置用于根据该存储器中存储的所述程序代码中的指令,执行本发明的应用使用流量的统计方法。
以示例而非限制的方式,计算机可读介质包括计算机存储介质和通信介质。计算机可读介质包括计算机存储介质和通信介质。计算机存储介质存储诸如计算机可读指令、数据结构、程序模块或其它数据等信息。通信介质一般以诸如载波或其它传输机制等已调制数据信号来体现计算机可读指令、数据结构、程序模块或其它数据,并且包括任何信息传递介质。以上的任一种的组合也包括在计算机可读介质的范围之内。
如在此所使用的那样,除非另行规定,使用序数词“第一”、“第二”、“第三”等等来描述普通对象仅仅表示涉及类似对象的不同实例,并且并不意图暗示这样被描述的对象必须具有时间上、空间上、排序方面或者以任意其它方式的给定顺序。
尽管根据有限数量的实施例描述了本发明,但是受益于上面的描述,本技术领域内的技术人员明白,在由此描述的本发明的范围内,可以设想其它实施例。此外,应当注意,本说明书中使用的语言主要是为了可读性和教导的目的而选择的,而不是为了解释或者限定本发明的主题而选择的。因此,对于本技术领域的普通技术人员来说许多修改和变更都是显而易见的。对于本发明的范围,对本发明所做的公开是说明性的,而非限制性的。
Claims (11)
1.一种应用使用流量的统计方法,适于在计算设备中执行,所述计算设备中运行有一个或多个应用,所述方法包括步骤:
确定所述计算设备中每个应用所运行的一个或多个进程;
确定所述计算设备中运行的每个进程进行网络通信所使用的套接字;
调用数据包抓取模块获取预设时间段内通信的多个网络数据包;
根据所述网络数据包所属的套接字,确定每个套接字在预设时间段内通信的一个或多个网络数据包;
根据每个套接字在预设时间段内通信的一个或多个网络数据包,确定所述套接字对应进程在预设时间段内使用的网络流量;
根据所述应用中每个进程在预设时间段使用的网络流量确定所述应用在预设时间段内使用的网络流量。
2.如权利要求1所述,其中,所述确定所述计算设备中每个应用所运行的一个或多个进程包括步骤:
确定所述计算设备中每个应用的一个或多个文件路径,并创建应用路径表,所述应用路径表包括计算设备中每个应用及对应的文件路径;
获取所述计算设备中运行的所有进程,并根据所述进程的进程信息创建进程路径表,所述进程路径表包括计算设备中每个进程及对应的文件路径;
根据所述应用路径表和进程路径表确定每个应用所对应的进程。
3.如权利要求2所述的方法,其中,所述确定所述计算设备中每个应用的一个或多个文件路径,并创建应用路径表包括步骤:
获取所述应用的一个或多个应用文件;
判断应用的每个应用文件是否为可执行文件;
如果所述应用文件是可执行文件,则将所述应用文件的文件路径加入所述应用路径表。
4.如权利要求2或3所述的方法,其中,所述根据所述应用路径表和进程路径表确定每个应用所对应的进程包括步骤:
根据所述应用路径表和进程路径表中包括的文件路径确定每个应用对包括的一个或多个进程。
5.如权利要求1-4所述的方法,其中,所述确定所述计算设备中运行的每个进程进行网络通信所使用的套接字包括步骤:
获取所述进程的进程信息;
根据所述进程的进程信息确定该进程进行网络通信所使用的套接字。
6.如权利要求5所述的方法,其中,所述计算设备连接有通信设备,所述调用数据包抓取模块获取预设时间段内通信的多个网络数据包包括步骤:
所述数据包抓取模块从所述通信设备获取在预设时间段内通信的多个网络数据包。
7.如权利要求6所述的方法,其中,根据所述网络数据包所属的套接字,确定每个套接字在预设时间段内通信的一个或多个网络数据包包括步骤:
根据所述网络数据包中数据信息的进程标识确定所述网络数据包所属的进程;
根据每个网络数据包所属的进程确定每个进程在预设时间端内通信的一个或多个网络数据包。
8.如权利要求7所述的方法,其中,所述根据每个套接字在预设时间段内通信的一个或多个网络数据包,确定所述套接字对应进程在预设时间段内使用的网络流量包括步骤:
根据每个网络数据包的数据包大小确定所述套接字对应进程在预设时间段内使用的网络流量。
9.如权利要求8所述的方法,其中,所述根据所述应用中每个进程在预设时间段使用的网络流量确定所述应用在预设时间段内使用的网络流量包括步骤:
将所述应用的每个进程在预设时间段使用的网络流量相加得到所述应用在预设时间段内使用的网络流量。
10.一种计算设备,包括:
一个或多个处理器;
存储器;以及
一个或多个装置,所述一个或多个装置包括用于执行根据权利要求1-9中任一项所述的方法的指令。
11.一种存储一个或多个程序的计算机可读存储介质,所述一个或多个程序包括指令,所述指令当由计算设备执行时,使得所述计算设备执行根据权利要求1-9中任一项所述的方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202210470162.6A CN115037516B (zh) | 2022-04-28 | 2022-04-28 | 一种应用使用流量的统计方法、计算设备及存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202210470162.6A CN115037516B (zh) | 2022-04-28 | 2022-04-28 | 一种应用使用流量的统计方法、计算设备及存储介质 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN115037516A true CN115037516A (zh) | 2022-09-09 |
CN115037516B CN115037516B (zh) | 2024-06-14 |
Family
ID=83118989
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202210470162.6A Active CN115037516B (zh) | 2022-04-28 | 2022-04-28 | 一种应用使用流量的统计方法、计算设备及存储介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN115037516B (zh) |
Citations (8)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20070233876A1 (en) * | 2006-03-30 | 2007-10-04 | Thompson Belinda L | Interprocess communication management using a socket layer |
US9128749B1 (en) * | 2013-06-27 | 2015-09-08 | Emc Corporation | Method and system for lock free statistics collection |
WO2016188166A1 (zh) * | 2015-10-30 | 2016-12-01 | 中兴通讯股份有限公司 | 一种数据流量管控方法和装置 |
US20200028714A1 (en) * | 2018-07-19 | 2020-01-23 | Vmware, Inc. | Per-app virtual private network tunnel for multiple processes |
CN110851334A (zh) * | 2019-11-19 | 2020-02-28 | 深圳市网心科技有限公司 | 流量统计方法、电子设备、系统及介质 |
CN112260889A (zh) * | 2020-09-28 | 2021-01-22 | 中孚安全技术有限公司 | 一种基于Linux的进程流量监控方法、系统及设备 |
CN112583767A (zh) * | 2019-09-29 | 2021-03-30 | 北京安云世纪科技有限公司 | 流量统计方法及装置 |
CN112787828A (zh) * | 2021-01-08 | 2021-05-11 | 重庆创通联智物联网有限公司 | 一种应用程序的流量统计方法、设备、移动电子设备 |
-
2022
- 2022-04-28 CN CN202210470162.6A patent/CN115037516B/zh active Active
Patent Citations (8)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20070233876A1 (en) * | 2006-03-30 | 2007-10-04 | Thompson Belinda L | Interprocess communication management using a socket layer |
US9128749B1 (en) * | 2013-06-27 | 2015-09-08 | Emc Corporation | Method and system for lock free statistics collection |
WO2016188166A1 (zh) * | 2015-10-30 | 2016-12-01 | 中兴通讯股份有限公司 | 一种数据流量管控方法和装置 |
US20200028714A1 (en) * | 2018-07-19 | 2020-01-23 | Vmware, Inc. | Per-app virtual private network tunnel for multiple processes |
CN112583767A (zh) * | 2019-09-29 | 2021-03-30 | 北京安云世纪科技有限公司 | 流量统计方法及装置 |
CN110851334A (zh) * | 2019-11-19 | 2020-02-28 | 深圳市网心科技有限公司 | 流量统计方法、电子设备、系统及介质 |
CN112260889A (zh) * | 2020-09-28 | 2021-01-22 | 中孚安全技术有限公司 | 一种基于Linux的进程流量监控方法、系统及设备 |
CN112787828A (zh) * | 2021-01-08 | 2021-05-11 | 重庆创通联智物联网有限公司 | 一种应用程序的流量统计方法、设备、移动电子设备 |
Also Published As
Publication number | Publication date |
---|---|
CN115037516B (zh) | 2024-06-14 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN108881294B (zh) | 基于网络攻击行为的攻击源ip画像生成方法以及装置 | |
WO2020259003A1 (zh) | 一种链路追踪方法及装置 | |
CN110888838B (zh) | 基于对象存储的请求处理方法、装置、设备及存储介质 | |
CN111131221B (zh) | 接口校验的装置、方法及存储介质 | |
US20160277544A1 (en) | Protocol data unit interface | |
JP2019079492A (ja) | コンボリューションのポピュラリティに基づいて異常なイベントを検出するシステムおよび方法 | |
CN109564502B (zh) | 应用于存储设备中的访问请求的处理方法和装置 | |
CN109951494B (zh) | 仿真数据处理方法、装置、仿真设备及存储介质 | |
CN110069217B (zh) | 一种数据存储方法及装置 | |
US10742668B2 (en) | Network attack pattern determination apparatus, determination method, and non-transitory computer readable storage medium thereof | |
CN108133026B (zh) | 一种多数据的处理方法、系统及存储介质 | |
CN111857600B (zh) | 一种数据读写方法及装置 | |
CN115037516B (zh) | 一种应用使用流量的统计方法、计算设备及存储介质 | |
WO2020224108A1 (zh) | Url拦截转换方法、装置以及计算机设备 | |
CN114979236B (zh) | 数据传输方法、装置、存储介质以及电子设备 | |
CN113282347B (zh) | 插件运行方法、装置、设备及存储介质 | |
CN109726181B (zh) | 一种数据处理方法及数据处理装置 | |
CN111371818B (zh) | 一种数据请求的验证方法、装置及设备 | |
CN113342275B (zh) | 区块链节点存取数据的方法、设备和计算机可读存储介质 | |
CN115242625B (zh) | 服务部署方法、装置、计算机设备及可读存储介质 | |
CN117234792B (zh) | 一种用于dpu的数据校验方法、装置、设备及介质 | |
CN111475171B (zh) | 应用程序组件下载方法、装置、电子设备 | |
CN113132324B (zh) | 样本鉴定方法及系统 | |
CN115186255A (zh) | 工业主机白名单提取方法、装置、终端设备以及存储介质 | |
CN114710334A (zh) | 用于服务器的访问策略调整方法及系统 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
GR01 | Patent grant | ||
GR01 | Patent grant |