我正在对Client Server套接字示例进行一些C编程。 假设服务器侦听端口4321上的客户端Port80.元组用于区分多个连接。但是服务器如何区分来自同一客户端的连接?我的意思是肯定会有多个来自客户端的应用程序在同一端口上访问同一个服务器。
任何人都可以解释一下吗?
由于
答案 0 :(得分:4)
正常的答案是你首先不要那样做。
客户端通常会连接到具有未绑定套接字的服务器,这意味着它尚未指定将接收回复的本地端口。服务器将使用bind
指定本地端口,然后它将在该端口上侦听来自客户端的连接。
当客户端连接未绑定的套接字时,TCP堆栈将选择当前未使用的端口号,并将其分配给该连接。当它向服务器发送请求时,服务器将回复已分配的端口号。在客户端,TCP堆栈将查看数据包中的端口号,并将其路由到分配了该端口号的任何进程。
因此,客户端将不使用端口4321 - 它将使用堆栈分配给它的任何端口。当同一台机器上的另一个进程连接到同一台服务器时,它也不会使用端口4321 - 它将使用分配给它的另一个端口。网络堆栈负责确保每个都获得唯一的端口号。
对于它的价值,TCP端口分为三个范围。从0到1023是FTP,SMTP,HTTP,POP等服务器的“众所周知”端口。这些端口供服务器使用,操作系统可能会采取一些特殊步骤来保护这些。例如,典型的操作系统需要某种管理员/根级别权限才能使用这些端口。
从1024到49151是注册的端口号。这些通常比众所周知的端口更松散地控制。几乎任何人都可以设置监听它们,但IANA维护着针对特定端口的特定用途的注册表。根据注册表,端口4321用于远程whois协议。
从49152到65535是动态端口 - 当客户端连接到服务器时,它通常会获得此范围内的本地端口号。当然,您可以编写服务器并将其绑定到此范围内的端口号(如果您愿意)(例如,用于测试)。当/如果你这样做,堆栈将跟踪它,因此它不会尝试将该端口用于其他目的。
答案 1 :(得分:3)
两个客户端无法使用同一个端口。如果一个客户端使用端口4321,则另一个客户端必须使用不同的端口。
答案 2 :(得分:2)
连接由元组(协议,源IP,源端口,dest IP,dest端口)标识。这就是你如何区分联系。
答案 3 :(得分:1)
两个客户端不能使用相同的端口,所以没有用。
但是,如果您要定义自己的协议,为什么不在客户端和服务器之间来回传递ClientID?客户端可以使用无效的client_id发出请求,服务器可以在ack中分配一个请求。
答案 4 :(得分:1)
TCP侦听器端口根据套接字区分连接,套接字是 IP:端口的组合。
对于客户端多次连接到同一台服务器,来自同一台机器,它使用多个端口(通常是临时的)到同一个已知(侦听器)端口。
然后,服务器迭代连接套接字,这可能包括来自同一台机器甚至应用程序的多个连接。
当您使用connect()TCP函数时,操作系统会自动完成客户端端口绑定,因此您根本不需要管理这些内容。
服务器然后将数据发送到IP:端口(可能仍在同一个应用程序中)的不同组合的客户端,因此它实际上不会混淆。