正常的答案是你首先不要那样做。
客户端通常会连接到具有未绑定套接字的服务器,这意味着它尚未指定将接收回复的本地端口。服务器将使用bind指定本地端口,然后它将在该端口上侦听来自客户端的连接。
当客户端连接未绑定的套接字时,TCP堆栈将选择当前未使用的端口号,并将其分配给该连接。当它向服务器发送请求时,服务器将回复已分配的端口号。在客户端,TCP堆栈将查看数据包中的端口号,并将其路由到分配了该端口号的任何进程。
因此,客户端将不使用端口4321 - 它将使用堆栈分配给它的任何端口。当同一台机器上的另一个进程连接到同一台服务器时,它也不会使用端口4321 - 它将使用分配给它的另一个端口。网络堆栈负责确保每个都获得唯一的端口号。
对于它的价值,TCP端口分为三个范围。从0到1023是FTP,SMTP,HTTP,POP等服务器的“众所周知”端口。这些端口供服务器使用,操作系统可能会采取一些特殊步骤来保护这些。例如,典型的操作系统需要某种管理员/根级别权限才能使用这些端口。
从1024到49151是注册的端口号。这些通常比众所周知的端口更松散地控制。几乎任何人都可以设置监听它们,但IANA维护着针对特定端口的特定用途的注册表。根据注册表,端口4321用于远程whois协议。
从49152到65535是动态端口 - 当客户端连接到服务器时,它通常会获得此范围内的本地端口号。当然,您可以编写服务器并将其绑定到此范围内的端口号(如果您愿意)(例如,用于测试)。当/如果你这样做,堆栈将跟踪它,因此它不会尝试将该端口用于其他目的。