陈斌彬的技术博客

Stay foolish,stay hungry

什么是端口

在Internet上,各主机间通过TCP/TP协议发送和接收数据报,各个数据报根据其目的主机的ip地址来进行互联网络中的路由选择。可见,把数据报顺利的传送到目的主机是没有问题的。问题出在哪里呢?我们知道大多数操作系统都支持多程序(进程)同时运行,那么目的主机应该把接收到的数据报传送给众多同时运行的进程中的哪一个呢?显然这个问题有待解决,端口机制便由此被引入进来。

本地操作系统会给那些有需求的进程分配协议端口(protocal port,即我们常说的端口),每个协议端口由一个正整数标识,如:80,139,445,等等。当目的主机接收到数据报后,将根据报文首部的目的端口号,把数据发送到相应端口,而与此端口相对应的那个进程将会领取数据并等待下一组数据的到来。说到这里,端口的概念似乎仍然抽象,那么继续跟我来,别走开。

端口其实就是队,操作系统为各个进程分配了不同的队,数据报按照目的端口被推入相应的队中,等待被进程取用,在极特殊的情况下,这个队也是有可能溢出的,不过操作系统允许各进程指定和调整自己的队的大小。 不光接受数据报的进程需要开启它自己的端口,发送数据报的进程也需要开启端口,这样,数据报中将会标识有源端口,以便接受方能顺利的回传数据报到这个端口

端口映射的常用端口有

21        文件传输协议(FTP)
22        SSH远程登录协议
23        telnet 终端仿真协议
25        smtp 简单邮件发送协议
80        全球信息网超文本传输协议(www)
81        HOST2名称服务
99        Telnet服务
110       Pop3 服务器(邮箱发送服务器)
135       查询服务 DNS
139       共享资源端口(NetBios-SSN)
3128      Squid HTTP代理服务器的默认端口
3306      mysql的端口
3389      Win2000以上操作系统远程登陆端口
4899      Remote Administrator [远程控制]