gpt4 book ai didi

python - 带python套接字的端口,它们是随机的吗?

转载 作者:太空宇宙 更新时间:2023-11-04 10:33:24 25 4
gpt4 key购买 nike

我正在尝试学习python套接字,但对网站(found here)中示例代码的结果感到非常困惑。

我所做的唯一修改是用服务器的本地IP替换了服务器中的socket.gethostname(),以允许我在两台计算机上运行它。

当我尝试连接示例中的端口12345时,得到以下输出:
Got connection from ('10.0.1.10', 37492)
这使我相信它在端口37492上进行连接。我希望它在我告诉它的端口上进行连接,以便我可以进行端口转发。我是不是误会了,还是有一个额外的命令来指定它。

编辑:我正在上传我的代码:

客户端

#!/usr/bin/python           # This is client.py file

import socket # Import socket module

s = socket.socket() # Create a socket object
host = socket.gethostname() # Get local machine name
port = 12345 # Reserve a port for your service.

s.connect(("10.0.1.42", port))
print s.recv(1024)
s.close # Close the socket when done

Server.py
import socket

s = socket.socket() # Create a socket object
host = "10.0.1.42" # Get local machine name
port = 12345 # Reserve a port for your service.
s.bind((host, port)) # Bind to the port

s.listen(5) # Now wait for client connection.
while True:
c, addr = s.accept() # Establish connection with client.
print 'Got connection from', addr
c.send('Thank you for connecting')
c.close() # Close the connection

最佳答案

您已经达到了网络生活中需要了解协议(protocol)多路复用的地步。对你有益。

考虑一下TCP/IP堆栈。应用程序通过将应用程序层数据传递到传输(端到端)层,再将其传递到网络层(网络层),与应用程序进行远程通信,网络层(网络层)尝试不保证数据包到达IP目标主机由合作路由器确定的一系列跃点,这些路由器通过与连接的路由器进行通信来动态更新其路由表。每个路由器对话都经过某种物理传输(ISDN,以太网,PPP-在TCP/IP中创建数据包并传输适当的位流的任务被视为单个“子网”层,但最终将其分为两层)当需要像DHCP这样的协议(protocol)在OSI物理层(第1层)和数据链路层(第2层)之间进行区分时。

在设计TCP和UDP时,设计人员想象每个服务器都将监听特定端口。这通常具有固有的局限性,即该端口只能处理您的服务协议(protocol)的一个版本(尽管像HTTP这样的协议(protocol)会注意向后兼容,以便旧服务器/客户端通常可以与较新的服务器/客户端进行互操作)。通常在端口111上运行一个名为portmapper的服务,该服务允许服务器注册它们在其上运行的端口号,而客户端可以通过服务(程序)号和协议(protocol)版本来查询已注册的服务器。这是Sun设计的RPC协议(protocol)的一部分,该协议(protocol)旨在将监听端口的范围扩展到仅由标准预先分配的端口之外。由于预分配的端口号为1到1023,并且由于这些端口通常(在明智的操作系统上)需要高级别的特权,因此RPC还启用了非特权服务器进程,并允许服务器响应多个版本网络应用程序协议(protocol)(例如NFS)。

无论服务器端如何工作,事实仍然是网络层必须有某种方法来确定将特定数据包传递到哪个TCP连接(或UDP监听器)。对于传输层也是如此(我将仅考虑TCP,因为它是面向连接的-UDP类似,但不介意丢失数据包)。假设我是服务器,并且从同一台计算机上的两个不同客户端进程获得了两个连接。如果客户端使用的是同一协议(protocol)的相同版本,或者服务仅在单个端口上监听,则目的地(IP地址,端口号)将相同。

服务器的网络层查看传入的IP数据报,并查看将其寻址到特定的服务器端口。因此,它将其传递到传输层(网络层上方的层)中的该端口。服务器是一个受欢迎的目的地,可能在同一台计算机上具有来自不同客户端进程的多个连接。这就是短暂端口的魔力出现的地方。

当客户端请求用于连接服务的端口时,TCP层保证该机器上的其他进程(从技术上来说,是该接口(interface),因为不同的接口(interface)具有唯一的IP地址,但这很详细)不会分配给同一端口客户端进程继续使用它时的编号。

因此,协议(protocol)复用和解复用依赖于五项信息:

(发送方IP,发送方端口,协议(protocol),接收方IP,接收方端口)

协议(protocol)是IP header 中的一个字段,源IP地址和目标IP地址也是如此。发送和接收端口号在传输层段头中。

当传入的数据包到达时,来自同一客户端(端点)的不同临时端口的保证唯一性允许传输层区分来自同一客户端IP地址和端口的与同一服务器IP地址的不同连接(用于多路分解的最坏情况)通过其源IP地址和端口。包含(传输)协议(protocol)以确保TCP和UDP流量不会混淆。 TCP/UDP对临时端口的唯一性的约束确保任何服务器只能从(IP address, port number)的特定组合接收一个连接,并且这允许将来自同一台计算机的连接多路分解为与不同来源相对应的单独流。

在Python中,当您将套接字连接到远程端点时,socket.accept()调用返回远程端点的(IP地址,端口号)对。您可以使用它来发现与您进行通讯的人,但是如果您只想讲回话,则可以简单地用write()套接字。

关于python - 带python套接字的端口,它们是随机的吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25026910/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com