我正在编写几个使用 Boost.ASIO 与网络通信的应用程序。由于错误,他们中的两个突然在配置中获得了相同的端口,并且他们都成功地开始在同一个端口上侦听。这是来自netstat -na
输出
TCP 0.0.0.0:40000 0.0.0.0:0监听 TCP 0.0.0.0:40000 0.0.0.0:0
监听
怎么会这样?两个不同的应用程序使用同一个 TCP 端口!
我正在编写几个使用 Boost.ASIO 与网络通信的应用程序。由于错误,他们中的两个突然在配置中获得了相同的端口,并且他们都成功地开始在同一个端口上侦听。这是来自netstat -na
输出
TCP 0.0.0.0:40000 0.0.0.0:0监听 TCP 0.0.0.0:40000 0.0.0.0:0
监听
怎么会这样?两个不同的应用程序使用同一个 TCP 端口!
如果在 Windows 上使用标志SO_REUSEADDR打开套接字,这是可能的。不幸的是,SO_REUSEADDR 标志在 Windows 上的语义与在 *nix 上的语义不同,这允许这种行为。
如果您担心另一个应用程序可能会尝试侦听您正在使用的端口,您可以使用 SO_EXCLUSIVEADDRUSE 标志。如果您可以控制所有打开套接字的应用程序,请确保您没有使用 SO_REUSEADDR 标志。