端口到底是个什么鬼?回答我!

目录

日常中听到的端口

[TCP封包的端口 与 UPD的端口](#TCP封包的端口 与 UPD的端口)

UDP与TCP使用相当的端口号时,是否是同一个端口

端口的验证

服务有多种协议,不同协议端口一般配置相同

日常中听到的端口

当我们谈论端口时,经常会通说什么的服务会是什么端口号。例如安全外壳协议(SSH,端口22)、 FTP (端 口20和21)、 Telnet远程终端协议(端口23)、电子邮件/简单邮件传输协议(SMTP,端 口25)、域名系统(DNS,端口53)、超文本传输协议或Web(HTTP和HTTPS,端口80 和443)、交互式邮件访问协议(IMAP和IMAPS,端口43和993)、简单网络管理协议 (SNMP,端口161和162)、轻量级目录访问协议(LDAP,端口389),以及其他几种服务。

这是什么东西?好像是有叫服务的东西,它具有特有的端口号。

下图是TCP/IP的协议族(TCP/IP协议族是里面有很多协议,不是仅仅只有TCP协议与IP协议,这些协议构成了Internet使用的协议。),在图中可以看到,端口号分解出现在传输层指向应用层,也就是端口用于应用服务的区分。

注:1)这个图容易引起误解,TCP有端口分解,UDP没有端口分解,但实际上是除了(ICMP、IGMP)之外,(UDP、TCP、STCP、DCCP)都是有端口的。

在下图可以看到如果按照ISO七层模型划分,ICMP与ICMP在划分时是在网络层与传输层之间,它是3.5层。而在TCP/IP四层里面,它被划分为网络层。

为什么,在上图ICMP、IGMP与TCP它们放在同一层?因为它们的报文内容被IPv4 与IPv6的数据部分,在IPv4存在协议字段(在IPv6中称为下一个头部字段),以决定接下来调用哪个协议来处理。常见的值包括1 (ICMP)、 2 (IGMP)、 4 (IPv4)、 6 (TCP)和17 (UDP)。为了方便理解数据的流向,出现了上图。

TCP封包的端口 与 UPD的端口

图中所示,TCP 16位,UDP2字节,因为1字节 = 8位,因此UDP的2字节,也就是16位。

可以看到无论TCP的端口号还是UDP的端口号数量都是一样的。

UDP与TCP使用相当的端口号时,是否是同一个端口

我们也经常听到这样的话,端口号只有65536个。这句话听起来的感觉就像是,哎呀,65536个端口,那么UDP与TCP的端口一共有65536端口一样。

在讨论这个之前,先回到TCP/IP协议族中,可以看到 IPv4协议中,在头部字段会有不同协议的标记。然后用来标识ICMP 、UDP、TCP、IGMP,SCTP、DCCP... 不同类型的协议。

在IPv4中,会有8位标记是什么类型的协议

最常见的是TCP的值6与UDP的值17

完整列表见IANA维护的协议号标准

因为IP层根据IPv4头部中的协议字段或IPv6头部中的下一个头部字段的值将进人的IP数
据报分离到特定的传输协议,这意味着端口号在不同的传输协议之间是独立的。

正确的的是:TCP有65536个端口号,UDP也有65536个端口号!!!它们是独立的资源

注:STCP 与DCCP也有16位的端口号,它们分别有65535个端口号

端口的验证

采用node.js验证。

server.js

javascript 复制代码
// server.js
const net = require('net');
const dgram = require('dgram');

const PORT = 8080;

// 创建 TCP 服务器
const tcpServer = net.createServer((socket) => {
  console.log('TCP 客户端连接');
  socket.on('data', (data) => {
    console.log(`TCP 收到: ${data}`);
    socket.write(`TCP 回复: ${data}`);
  });
});

tcpServer.listen(PORT, '127.0.0.1', () => {
  console.log(`TCP 服务器监听 ${PORT} 端口`);
});

// 创建 UDP 服务器
const udpServer = dgram.createSocket('udp4');

udpServer.on('message', (msg, rinfo) => {
  console.log(`UDP 收到 ${rinfo.address}:${rinfo.port}: ${msg}`);
  udpServer.send(`UDP 回复: ${msg}`, rinfo.port, rinfo.address);
});

udpServer.bind(PORT, '127.0.0.1', () => {
  console.log(`UDP 服务器监听 ${PORT} 端口`);
});

// 错误处理
tcpServer.on('error', (err) => console.error('TCP 错误:', err));
udpServer.on('error', (err) => console.error('UDP 错误:', err));

在服务端,创建一个TCP服务,同时也创建一个UDP服务,它们的端口都是8080;当它们收到信息,将信息打印出来,并且将信息回传给客户端。

client.js

javascript 复制代码
// client.js
const net = require('net');
const dgram = require('dgram');

const PORT = 8080;
const HOST = '127.0.0.1';

// 测试 TCP 客户端
const tcpClient = net.connect(PORT, HOST, () => {
  console.log('TCP 已连接服务器');
  tcpClient.write('Hello TCP!');
});

tcpClient.on('data', (data) => {
  console.log(`TCP 收到回复: ${data}`);
  tcpClient.end();
});

tcpClient.on('end', () => console.log('TCP 连接关闭'));

// 测试 UDP 客户端
const udpClient = dgram.createSocket('udp4');
const udpMessage = Buffer.from('Hello UDP!');

udpClient.send(udpMessage, PORT, HOST, (err) => {
  if (err) console.error('UDP 发送错误:', err);
  else console.log('UDP 消息已发送');
});

udpClient.on('message', (msg) => {
  console.log(`UDP 收到回复: ${msg}`);
  udpClient.close();
});

udpClient.on('close', () => console.log('UDP 客户端关闭'));

在客户端,创建两个客户端,一个是TCP客户端,一个是UDP客户端,当它们连接成功是分别发送"Hello TCP "与"Hello,UDP",

服务端

javascript 复制代码
UDP 服务器监听 8080 端口
TCP 服务器监听 8080 端口
TCP 客户端连接
UDP 收到 127.0.0.1:56157: Hello UDP!
TCP 收到: Hello TCP!

客户端

javascript 复制代码
UDP 消息已发送
TCP 已连接服务器
UDP 收到回复: UDP 回复: Hello UDP!
UDP 客户端关闭
TCP 收到回复: TCP 回复: Hello TCP!
TCP 连接关闭

虽然它们都是使用了8080端口号,但是因为它们的协议不一样,并不会将UDP的数据发送给TCP。

服务有多种协议,不同协议端口一般配置相同

尽管有这种独立性,但是如果某个众所周知的服务可同时由TCP和UDP提供(或者可信服地提供),那么这两个传输协议的端口号通常被分配成一样的。关于如何规范地分配端口号,详见[IPORT]

例如在ftp服务使用到的三种协议TCP,UDP,SCTP,使用的端口都被配置成为21

相关推荐
小马哥编程33 分钟前
【软考架构】网络规划与设计,三层局域网模型和建筑物综合布线系统PDS
网络·计算机网络·架构·系统架构
zmjjdank1ng1 小时前
Linux 流编辑器 sed 详解
linux·运维·前端·网络·入门
搬码临时工1 小时前
使用frp内网穿透实现远程办公
服务器·网络
FairyDiana1 小时前
解锁Node.js核心装备库:全局API通关指南
面试·node.js·trae
鹧鸪云光伏2 小时前
[鹧鸪云]光伏AI设计平台解锁电站开发新范式
运维·服务器·人工智能·光伏·光伏设计
Zfox_2 小时前
Redis应⽤-缓存与分布式锁
服务器·数据库·redis·分布式·缓存
云和数据.ChenGuang2 小时前
Raft协议 一种专为分布式系统设计的共识算法
运维·服务器·算法·区块链·共识算法
Moment2 小时前
面试官:为什么文件上传时要用 MD5 重命名,而不是时间戳❓❓❓
前端·后端·node.js
岚天start3 小时前
阿里云Web应用防火墙(WAF)与云防火墙的核心区别
网络·阿里云·云计算·防火墙·waf
若水晴空初如梦3 小时前
QT聊天项目DAY18
运维·服务器