当我在笔记本电脑上启动服务器时,我得到以下信息
server Server started at http://0.0.0.0:8000
server Documentation at http://0.0.0.0:8000/docs
我能够使用localhost:8000/docs
以及来访问它<my-private-ip>:8000/docs
。
但是当我使用动态 IP时,我无法访问它。这是为什么?当我通过 Web 浏览器访问页面时,我的动态 IP 用于访问 Web 内容。这意味着路由器将来自服务器的传入流量转发到我的笔记本电脑。那么为什么我不能使用我的动态 IP来访问我笔记本电脑上托管的应用程序呢?
在大多数情况下,IP 地址并不属于您的笔记本电脑 - 它属于附近的路由器,该路由器使用其 IP 地址来“伪装”您的笔记本电脑的实际地址(以及连接到它的所有其他设备的地址)。
因此,您没有连接到您的笔记本电脑;您正尝试连接到您的路由器。
当路由器收到发往其 IP 地址的回复数据包时,如果这些数据包属于已建立的连接,它就会知道将它们转换回笔记本电脑的真实地址。(这与“UPnP”无关。)但对于新连接,它不会这样做,因为它不知道将它们转发到哪个设备。
每当没有任何特定的 NAT 规则来转换数据包时,它都会被视为发往路由器本身的数据包,并且由于路由器没有在 TCP 端口 8000 上监听任何内容,因此它会拒绝连接。
为了使笔记本电脑能够使用路由器的 IP 地址接收连接,需要为路由器配置针对该特定端口号的手动 NAT 转换规则 - “端口转发”或“虚拟服务器”或“DNAT”规则。
您需要打开路由器上的一个端口,以便将流量从外部转发到您的笔记本电脑。大多数消费级路由器无法理解 NAT 发夹技术,因此尽管端口已打开,您仍然无法从笔记本电脑对其进行测试。
为了测试它,请关闭手机上的 wifi,这样你就可以使用蜂窝网络,然后打开网络浏览器访问你的动态 ip 并在那里进行测试。
请注意,如果您要创建热点并将笔记本电脑连接到该热点进行测试,您的网络服务器不再位于路由器的网络中,因此它无法再将流量转发到那里。