相关文章推荐
完美的脸盆  ·  js ...·  1 年前    · 
博学的枇杷  ·  Laravel whereHas and ...·  1 年前    · 

本课题来源于计算机网络实践与应用课程的创新型实验,题目为“TCP和UDP数据流的带宽竞争分析”。实验的主要目的是通过编程实现多进程TCP和UDP数据传输模块,编写相关的TCP/UDP流利用带宽测量软件,设计实验,让多个TCP和UDP流竞争有限带宽,分析结果,进而掌握TCP和UDP流传输的特点,了解工作原理和工作过程,并通过测试验证其竞争机制。


1.2 项目意义


在实际应用中,一个端设备往往同时存在多个TCP和UDP的连接。通过此项目,我们可以了解多连接情况下TCP和UDP的运行性能与特点,从而在实际的应用中合理分配混合数据流的TCP和UDP的连接数,从而提高数据流的传输性能,充分利用有限的带宽,提高传输效率。


1.3 项目创新分析


该项目通过实现编程代码来进行TCP和UDP的传输和监听,创新性地将TCP和UDP的相关内容特点与现实问题(有限带宽竞争)相联系,可以让我们从新的角度理解课程中以及书本上的TCP和UDP的特点,增强了我们用实践来检验理论知识的创新意识。


第2章 与项目相关的主要技术及其分析


2.1 socket编程(python)


Socket套接字是网络通信过程中端点的抽象表示,是程序进行网络通信的基础,使应用层能使用传输层提供的服务(TCP和UDP),进而实现TCP和UDP的数据传输模块。


本次实验中,我们使用python中的socket包,分别在client和server中将socket与IP地址和端口号建立对应关系,进而实现TCP和UDP的发送和监听。


2.2 多线程技术


多线程技术建立多个线程来收发数据,可以用来同时建立多个连接,进而可以在一个程序中进行TCP和UDP的同时收发,进而实现可控的连接数对网络带宽的竞争。

使用python中的threading包来实现函数在多个线程的同时运行。


2.3 流量的实时计算与可视化(python)


通过调用pyshark(基于wireshark的Python库)来进行实时捕获,分析每秒内不同目的端口接收的TCP和UDP数据包,计算流量。

使用python中的matplotlib来实时绘制TCP和UDP的流量曲线图,从而进行流量的可视化,体现TCP和UDP的竞争关系。


2.4 GUI编程(python)


Tkinter 是 Python 的标准 GUI 库。Python 使用 Tkinter 可以快速的创建 GUI 应用程序,从而使整个操作过程直接明了,易于控制。


第3章 混合数据流带宽竞争分析实现


3.1 实验方案


用python实现客户端与服务器端的应用程序client.py与server.py,以及在服务器端运行的流量监听工具Monitor.py。


使用两台计算机设备,分别作为服务器端和客户端。


先在服务器端运行程序Server.exe(生成的可执行文件)与Monitor.py,再在客户端指定服务器IP地址与要发送的文件,进行多种情况下的TCP和UDP的竞争传输,在服务器端查看传输过程以及monitor的流量图像。


3.2 客户端程序的实现


用来向服务器指定端口发送数据包,TCP的目的端口是10241,UDP的目的端口是10240。


TCP套接字connect服务器的10241端口,建立连接,再从本地读取文件,发送文件大小后,再发送数据包(分组大小设置为BATCH_SIZE),在发送数据的同时打印已发送数据的大小


UDP进行无连接传输,直接向服务器的10240端口发送文件(如果先发送文件大小, 可能丢包)


为TCP和UDP传输分别启用一个线程,用户自行选择传输方式(只进行TCP传输,只进行UDP传输,两者同时进行)


运行效果

8ffef57792fa99b5a216d07cff13362c.png


3.3 服务器端程序的实现


3.3.1 服务器端程序Server.py


用来接收数据包,在10240接收UDP数据包,在10241接收TCP数据包。

实现效果

89006b5a891793d8fc99e26fd57961ad.png


3.3.2 流量计算工具Monitor.py


通过调用pyshark(基于wireshark的Python库)进行实时捕获 ,分析每秒内目的端口为10240的UDP数据包和10241的TCP数据包,计算流量,使用matplotlib实时绘制TCP和UDP流量曲线图。


3.4 带宽竞争的实现


按照3.1中的实验方案进行操作,Client端要发送大量数据来竞争带宽,因此在操作过程中选择一个较大的文件进行TCP和UDP的传输,确保达到有限带宽内的竞争。


第4章 项目测试


4.1 测试方案



4.2 测试结果


TCP和UDP同时启动时,流量监听界面如下

b9f7aa337be95f7213ba19936d32a253.png


g)


发现在同时启动的情况下,TCP传输相对于UDP传输有一个滞后的过程,UDP发送很多数据后TCP才会进行发送。TCP是面向连接的传输层服务,开始时需要建立连接(三次握手),而UDP是无连接的,直接进行数据的发送。因此会出现这种现象。


TCP先启动时,UDP后启动时,流量监听界面如下


3c189c93dcc089efd43ac5188813e0f3.png


3c90f79a8b31c11d19c6c94ef1727999.png


UDP先启动时,TCP后启动时,流量监听界面如下


25fcfd33ec616643764cd7b2ce98d99b.png

aa256017584a927b4514f45bc59effa8.png


经过以上监测到的竞争过程,我们可以发现:

在TCP和UDP竞争中,UDP会占用更多的带宽。(还可能出现UDP完全压制TCP传输的现象,如下图所示)只有在UDP传输完成后,TCP才能恢复到较高的速率进行传输。


742a23960073553ea28d9ca5445109b9.png

第5章 结论


在测试中,带宽占用率过高时,TCP和UDP竞争中,由于二者对网络拥塞的反应是不同的。TCP具有拥塞控制机制,对拥塞的处理是降低自身的传输速率,从而避免丢包的发生。而UDP缺少端到端的拥塞控制,进而在链路带宽的占用上处于优势,但会丢失一些数据包,其传输是不可靠的。


竞争会使TCP流得不到公平的带宽,因此应当探索一种机制,来处理TCP和UDP的竞争过程。


完整代码: https://download.csdn.net/download/weixin_55771290/87398318

Python分析指定商品的所有页面
中国商家为了提高在www.amazon.com卖家的竞争力和利润,他们应该如何选择和优化商品呢?其中,最重要的工作就是定期分析同类商品的相关信息,用于分析市场前景和商品信息等关键因素。下面提供数据分析demo,用于对www.amazon.cn指定商品的全部页面进行采集
python机器学习数据建模与分析——决策树详解及可视化案例
你是否玩过二十个问题的游戏,游戏的规则很简单:参与游戏的一方在脑海里想某个事物,其他参与者向他提问题,只允许提20个问题,问题的答案也只能用对或错回答。问问题的人通过推断分解,逐步缩小待猜测事物的范围。决策树的工作原理与20个问题类似,用户输人一系列数据,然后给出游戏的答案。我们经常使用决策树处理分类问题,近来的调查表明决策树也是最经常使用的数据挖掘算法。它之所以如此流行,一个很重要的原因就是使用者基本上不用了解机器学习算法,也不用深究它是如何工作的。