您的位置:首页 > 其它

运输层概述与运输层的端口

2015-06-13 10:20 211 查看
运输层协议概述

从通信和信息处理的角度看,运输层向它上面的应用层提供通信服务,它属于面向通信部分的最高层,同时也是用户功能中的最低层。当网络的边缘部分中的两个主机使用网络的核心部分的功能进行端到端的通信时,只有位于网络边缘部分的主机的协议栈才有运输层,而网络核心部分中的路由器在转发分组时都只用到下三层的功能。

两个主机进行通信实际上就是两个主机中的应用进程互相通信,应用进程之间的通信又称为端到端的通信。“运输层提供应用进程间的逻辑通信”。“逻辑通信”的意思是:运输层之间的通信好像是沿水平方向传送数据。但事实上这两个运输层之间并没有一条水平方向的物理连接。运输层向高层用户屏蔽了下面网络核心的细节(如网络拓扑、所采用的路由选择协议等),它使应用进程看见的就是好像在两个运输层实体之间有一条端到端的逻辑通信信道。



当 运输层采用面向连接的TCP协议时,尽管下面的网络是不可靠的(只提供尽最大努力服务),但这种逻辑通信信道就相当于一条全双工的可靠信道。TCP报文段是在运输层抽象的端到端逻辑信道中传送,这种信道是可靠的全双工信道。但这样的信道却不知道究竟经过了哪些路由器,而这些路由器也根本不知道上面的运输层是否建立了
TCP连接。当运输层采用无连接的UDP协议时,这种逻辑通信信道是一条不可靠信道。运输层的一个很重要的功能就是复用和分用。应用层不同进程的报文通过不同的端口向下交到运输层,再往下就共用网络层提供的服务。

运输层的端口

1.遇到的问题
运行在计算机中的进程是用进程标识符来标志的。但运行在应用层的各种应用进程却不应当让计算机操作系统指派它的进程标识符。这是因为在因特网上使用的计算机的操作系统种类很多,而不同的操作系统又使用不同格式的进程标识符,因此发送方非常可能无法识别其他机器上的进程。为了使运行不同操作系统的计算机的应用进程能够互相通信,就必须用统一的方法对
TCP/IP体系的应用进程进行标志。而且由于进程的创建和撤销都是动态的,有时我们会改换接收报文的进程,但并不需要通知所有发送方。还有在实际应用中我们往往需要利用目的主机提供的功能来识别终点,而不需要知道实现这个功能的进程。

2.解决办法:端口的提出

解决这个问题的方法就是在运输层使用协议端口号(protocolport number),或通常简称为端口(port),端口用一个16位端口号进行标志。端口号只具有本地意义,即端口号只是为了标志本计算机应用层中的各进程。在因特网中不同计算机的相同端口号是没有联系的。虽然通信的终点是应用进程,但我们可以把端口想象是通信的终点,因为我们只要把要传送的报文交到目的主机的某一个合适的目的端口,剩下的工作(即最后交付目的进程)就由TCP来完成。

3.端口的分类

端口号的范围是从1~65535,一般分为3类端口:熟知端口号,登记端口号,客户端口号或短暂端口号。

熟知端口号,数值一般为0~1023,每个端口号应用于特定熟知的应用协议。

登记端口号,数值为1024~49151,为没有熟知端口号的应用程序使用的。使用这个范围的端口号必须在IANA(The
Internet Assigned NumbersAuthority,互联网数字分配机构)登记,以防止重复。

客户端口号或短暂端口号,数值为49152~65535,留给客户进程选择暂时使用。当服务器进程收到客户进程的报文时,就知道了客户进程所使用的动态端口号。通信结束后,这个端口号可供其他客户进程以后使用。

一些常见的端口号及其用途如下:

TCP21端口:FTP文件传输服务

TCP23端口:TELNET终端仿真服务

TCP25端口:SMTP简单邮件传输服务

UDP53端口:DNS域名解析服务

TCP80端口:HTTP超文本传输服务

TCP110端口:POP3“邮局协议版本3”使用的端口

TCP443端口:HTTPS加密的超文本传输服务

TCP1521端口:Oracle数据库服务

TCP1863端口:MSNMessenger的文件传输功能所使用的端口

TCP3389端口:MicrosoftRDP
微软远程桌面使用的端口

TCP5631端口:SymantecpcAnywhere
远程控制数据传输时使用的端口

UDP5632端口:SymantecpcAnywhere
主控端扫描被控端时使用的端口

TCP5000端口:MSSQL Server使用的端口

UDP8000端口:腾讯QQ
4.socket

TCP 把连接作为最基本的抽象。每一条TCP连接有两个端点。TCP连接的端点不是主机,不是主机的IP地址,不是应用进程,也不是运输层的协议端口。TCP连接的端点叫做套接字(socket)或插口。端口号拼接到(contatenatedwith)
IP 地址即构成了套接字。
套接字(socket) = (IP地址:端口号)

每一条TCP连接唯一地被通信两端的两个端点(即两个套接字)所确定。即:

TCP 连接 = {socket1, socket2} = {(IP1:
port1), (IP2: port2)}

注:同一个名词socket有多种不同的意思:

应用编程接口API称为socketAPI,
简称为socket。

socketAPI 中使用的一个函数名也叫作socket。

调用socket函数的端点称为socket。

调用socket函数时其返回值称为socket描述符,可简称为socket。

在操作系统内核中连网协议的Berkeley实现,称为socket实现。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: