`
zhengdl126
  • 浏览: 2546166 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类

网络管理之TCP/UDP篇

 
阅读更多

 

我们学习过什么是“数据包”。理解数据包,对于网络管理的网络安全具有至关重要的意义。比如,防火墙的作用本质就是检测网络中的数据包,判断其是否违反了预先设置的规

 

则,如果违反就加以阻止。图1就是瑞星个人版防火墙软件设置规则的界面。细心的读者会发现,图1中的“协议”栏中有“TCP”、“UDP”等名词,它们是什么意思呢?现在我们

 

就来讲讲什么是TCP和UDP。

 

 

==========================面向连接的TCP

 

“面向连接”就是在正式通信前必须要与对方建立起连接。比如你给别人打电话,必须等线路接通了、对方拿起话筒才能相互通话。

 

 

 

 TCP(Transmission Control Protocol,传输控制协议)是基于连接的协议,也就是说,在正式收发数据前,必须和对方建立可靠的连接。一个TCP连接必须要经过三次“对话”

 

才能建立起来,其中的过程非常复杂,我们这里只做简单、形象的介绍,你只要做到能够理解这个过程即可。我们来看看这三次对话的简单过程:主机A向主机B发出连接请求数据

 

包:“我想给你发数据,可以吗?”,这是第一次对话;主机B向主机A发送同意连接和要求同步(同步就是两台主机一个在发送,一个在接收,协调工作)的数据包:“可以,你

 

什么时候发?”,这是第二次对话;主机A再发出一个数据包确认主机B的要求同步:“我现在就发,你接着吧!”,这是第三次对话。三次“对话”的目的是使数据包的发送和接

 

收同步,经过三次“对话”之后,主机A才向主机B正式发送数据。

 

 

TCP协议能为应用程序提供可靠的通信连接,使一台计算机发出的字节流无差错地发往网络上的其他计算机,对可靠性要求高的数据通信系统往往使用TCP协议传输数据。

 

我们来做一个实验,用计算机A(安装Windows 2000 Server操作系统)从“网上邻居”上的一台计算机B拷贝大小为8,644,608字节的文件,通过状态栏右下角网卡的发送和接收指

 

标就会发现:虽然是数据流是由计算机B流向计算机A,但是计算机A仍发送了3,456个数据包,如图2所示。这些数据包是怎样产生的呢?因为文件传输时使用了TCP/IP协议,更确切

 

地说是使用了面向连接的TCP协议,计算机A接收数据包的时候,要向计算机B回发数据包,所以也产生了一些通信量。

 

 

 

如果事先用网络监视器监视网络流量,就会发现由此产生的数据流量是9,478,819字节,比文件大小多出10.96%(如图3所示),原因不仅在于数据包和帧本身占用了一些空间,而

 

且也在于TCP协议面向连接的特性导致了一些额外的通信量的产生。

 

 

============================面向非连接的UDP协议

 

 

  “面向非连接”就是在正式通信前不必与对方先建立连接,不管对方状态就直接发送。这与现在风行的手机短信非常相似:你在发短信的时候,只需要输入对方手机号就OK了

 

 

  UDP(User Data Protocol,用户数据报协议)是与TCP相对应的协议。它是面向非连接的协议,它不与对方建立连接,而是直接就把数据包发送过去

 

 

 

  UDP适用于一次只传送少量数据、对可靠性要求不高的应用环境。比如,我们经常使用“ping”命令来测试两台主机之间TCP/IP通信是否正常,其实“ping”命令的原理就是向对方主机发送UDP数据包,然后对方主机确认收到数据包,如果数据包是否到达的消息及时反馈回来,那么网络就是通的。例如,在默认状态下,一次“ping”操作发送4个数据包。大家可以看到,发送的数据包数量是4包,收到的也是4包(因为对方主机收到后会发回一个确认收到的数据包)。这充分说明了UDP协议是面向非连接的协议,没有建立连接的过程。正因为UDP协议没有连接的过程,所以它的通信效果高;但也正因为如此,它的可靠性不如TCP协议高。QQ就使用UDP发消息,因此有时会出现收不到消息的情况

 

 

 

  TCP协议和UDP协议各有所长、各有所短,适用于不同要求的通信环境。TCP协议和UDP协议之间的差别如附表所示。 

 

 

 

 

 

 

 

 

 

 

 

 

列出当前socket详细信息:

[root@www ~]# ss -s

Total: 1372 (kernel 1503)

TCP:   1896 (estab 1192, closed 379, orphaned 319, synrecv 0, timewait 379/0), ports 215

Transport Total     IP        IPv6

*      1503      -         -        

RAW      0         0          0        

UDP      0         0          0        

TCP      1517      1517       0        

INET      1517      1517      0        

FRAG      0         0         0        

显示所有打开的网络端口

[root@www ~]# ss -l

Recv-Q Send-Q                                             Local Address:Port                                              Peer Address:Port   

0      0                                                   127.0.0.1:9000                                                         *:*       

0      0                                                           *:mysql                                                        *:*       

0      0                                                           *:http                                                         *:*       

0      0                                                           *:ssh                                                          *:* 

显示每个进程具体打开的socket

# ss -pl

显示所有的TCP Socket

#ss -t -a 

显示所有的UDP Socekt

# ss -u -a

显示所有已建立的SMTP连接

# ss -o state established '( dport = :smtp or sport = :smtp )'

显示所有已建立的HTTP连接

# ss -o state established '( dport = :http or sport = :http )'

找出所有连接X服务器的进程

# ss -x src /tmp/.X11-unix/*

 

 

 

 

 

 

 

 

 

 

 

 

 

 

分享到:
评论

相关推荐

    Socket网络TCP/UDP通信调试工具

    SocketTool调试工具最新版可以有效地帮助网络管理员检测各种网络通信状永久,集成了TCP服务器/客户端、UDP服务器/客户端和UDP广播/组播等功能。SocketTool调试工具官方版可以帮助网络编程人员、网络维护人员检查所...

    tcpudp 2.1.1 TCP/UDP 调试软件

    - tcpudp_2.1.exe、tcpudp_2.1.1.exe:这两个文件是软件的执行程序,版本号不同可能代表软件的不同更新版本。 - 安装说明.txt:提供软件的安装步骤和注意事项,对于用户来说是非常重要的指南。 通过这款软件,你...

    TCP/UDP调试助手

    TCP/IP协议是互联网通信的基础,其中TCP...安装完成后,按照软件的引导进行操作,开始你的TCP/UDP网络编程调试之旅。记住,深入理解TCP和UDP的工作原理,将有助于你更好地利用这款工具,解决实际开发中的网络问题。

    tcp/udp测试工具

    标题中的“tcp/udp测试工具”指的是在网络开发过程中用于测试TCP和UDP协议的辅助软件。这类工具对于开发者来说至关重要,因为它们能帮助检测和调试网络应用程序的通信问题,确保数据的正确传输。TCP(传输控制协议)...

    MFC TCP/UDP最经典例子

    TCP(Transmission Control Protocol)和UDP(User Datagram Protocol)是网络通信中的两种主要协议,分别代表了面向连接的可靠传输和无连接的快速传输。这个"MFC TCP/UDP最经典例子"很可能是为了帮助开发者学习如何...

    TCP/UDP工具

    总的来说,TCP/UDP工具是网络管理员和开发者的重要辅助工具,它们可以帮助理解和优化网络通信,确保数据的正确传输,以及排查和解决网络相关的问题。通过提供直观的界面和多样化的功能,这些工具使得网络调试工作变...

    Nginx配置TCP/UDP调度器.doc

    通过上述配置,Nginx不仅可以作为HTTP/HTTPS服务器,还能作为一个强大的TCP/UDP负载均衡器,帮助管理和优化网络服务的流量分布。这种设置可以轻松扩展到多个后端服务器,通过Nginx实现更复杂的负载均衡策略,例如...

    TCP/UDP Socket 调试工具

    4. **连接管理**:可以管理多个TCP连接,或者向多个UDP目标地址发送数据。 5. **日志记录**:记录通信过程中的关键信息,便于分析问题。 6. **性能监控**:展示网络连接的带宽使用、延迟等性能指标。 在压缩包...

    VB编写的TCP/UDP协议网口通讯调试助手源代码

    本篇将深入探讨基于VB编写的TCP/UDP协议网口通讯调试助手源代码的知识点。 1. **VB基础** VB是微软公司推出的可视化编程工具,以其易学易用的特点,深受初学者和企业级开发者的喜爱。VB源代码通常包含窗体(Form)...

    TCP&UDP测试工具_tcp&udp_TCP/UDP测试工具_TCP工具_

    TCP/UDP测试工具是用于评估网络性能和调试网络问题的软件,它们可以帮助开发者和网络管理员了解网络通信的质量和效率。这些工具通常包含以下功能: 1. **服务器和客户端模拟**:工具可以模拟TCP或UDP服务器和客户端...

    TCP和UDP socket调试工具V2.2

    总的来说,TCP和UDP Socket调试工具V2.2是一款实用的开发辅助软件,它简化了网络编程中复杂的数据传输和连接管理,帮助开发者快速定位问题,优化网络应用的性能。无论你是初学者还是经验丰富的程序员,都能从中受益...

    TCP/UDP服务管理v2.0.1

    1. **TCP Server**:允许开发者创建和管理TCP服务,可以自定义监听端口,处理来自客户端的连接请求,实现数据的收发。 2. **UDP Server**:支持设置广播或单播,能够发送和接收UDP数据包,适用于需要快速传输、低...

    网络TCP/UDP 调试工具.rar

    TCP/UDP通信调试工具,该工具可以有效地帮助网络管理员检测各种网络通信状永久,集成了TCP服务器/客户端、UDP服务器/客户端和UDP广播/组播等功能,并且支持对发送和接收的字节进行统计操作。1、全面集成 TCP服务器/...

    TCP/UDP协议

    在计算机网络通信中,传输控制协议(TCP)与用户数据报协议(UDP)是最为常见的两种传输层协议,它们位于OSI七层模型中的第四层——传输层,同时也属于TCP/IP协议族的一部分。这两种协议在实际应用中各有特点和适用...

    TCP_UDP_PerformanceTest 测试工具

    总结来说,TCP_UDP_PerformanceTest工具是评估和比较TCP与UDP性能的实用工具,通过对两种协议的实际测试,帮助开发者和网络管理员理解不同协议在实际环境中的表现,优化网络服务的性能和效率。对于从事网络编程和...

    TCP/UDP网络调试工具(9个)

    对于网络管理或安全审计来说,它是一个实用的工具。 8. **UDP Test Tool**:专门针对UDP协议设计的测试工具,可以发送和接收UDP数据包,用于测试UDP通信的稳定性和性能。对于开发基于UDP的应用,这是一个很好的辅助...

    TCP/UDP服务管理器

    【TCP/UDP服务管理器】是一款实用的网络通信测试工具,专为IT专业人士设计,用于管理和测试基于TCP和UDP协议的网络服务。该工具具备双重功能,既可以作为服务器端进行监听,等待客户端的连接,也可以作为客户端主动...

    ubuntu下好用的TCP/UDP调试工具

    在Ubuntu操作系统中,进行TCP和UDP网络调试是开发者和系统管理员日常工作中不可或缺的一部分。为了高效地排查网络问题,选择一款合适的工具至关重要。标题提到的"ubuntu下好用的TCP/UDP调试工具"很可能是`mNetAssist...

    TCP/UDP测试工具

    这类工具可以帮助开发者、网络管理员或测试人员检查网络连接的稳定性、速度和丢包率。它们可以用来模拟TCP或UDP连接,发送和接收数据包,并分析结果以找出可能存在的问题。 例如,"TCPUDPDebug102_Setup.exe"很可能...

Global site tag (gtag.js) - Google Analytics