前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >经常打游戏、刷视频,却不了解它们底层的通信机制吗?来我给你聊清楚Python Socket通信原理

经常打游戏、刷视频,却不了解它们底层的通信机制吗?来我给你聊清楚Python Socket通信原理

作者头像
看、未来
发布2021-09-18 10:44:39
7850
发布2021-09-18 10:44:39
举报
文章被收录于专栏:CSDN搜“看,未来”

文章目录

抱歉,我一直坚定选择的是后端,嘿嘿嘿。 就算是Python,我也要绕回后端来。

上图是socket网络编程的流程图


至于数据在网络中是怎么走的,咱先不说,那个太底层了,咱今天见就说如何将数据从咱的屏幕上放到网络流中去。 这可不是键盘敲敲,回车一按的事情,在这背后,那也是百转千回。


打开一个网络接口:套接字

Socket又称"套接字",应用程序通常通过"套接字"向网络发出请求或者应答网络请求,使主机间或者一台计算机上的进程间可以通讯。 Python 中,我们用 socket()函数来创建套接字,语法格式如下:

代码语言:javascript
复制
import socket	# 居然是个内置模块
socket.socket([family[, type[, proto]]])

参数释义:

代码语言:javascript
复制
family: 套接字家族可以使 AF_UNIX(本地协议) 或者 AF_INET(产生IPV4)。
type: 套接字类型可以根据是面向连接的还是非连接分为 
	  SOCK_STREAM(这个协议是按照顺序的、可靠的、数据完整的基于字节流的连接。这是一个使用最多的socket类型,是用TCP协议来传输的。) 
	  或 SOCK_DGRAM(这个协议是无连接的,固定长度的连接调用。该协议是不可靠的,使用UDP来进行它的连接。)。
protocol: 一般不填默认为 0。

返回值:返回一个通信套接字,为本机向网络通信的接口。


绑定IP与端口:bind

bind() 用来关联 socket 到指定的网络接口(IP 地址)和端口号:

代码语言:javascript
复制
bind(hostname,port)

参数释义:

代码语言:javascript
复制
hostname:主机IP
port:进行网络通信的端口

127.0.0.1 是标准的 IPv4 回环地址,只有主机上的进程可以连接到服务器,如果你传了空字符串,服务器将接受本机所有可用的 IPv4 地址。

端口号应该是 1-65535 之间的整数(0是保留的),这个整数就是用来接受客户端链接的 TCP 端口号,如果端口号小于 1024,有的操作系统会要求管理员权限。


监听网络来信:监听套接字

代码语言:javascript
复制
listen(backlog)	#开始 TCP 监听。

参数释义: backlog 指定在拒绝连接之前,操作系统可以挂起的最大连接数量。该值至少为 1,大部分应用程序设为 5 就可以,做并发的话可以设大一些,比方说20。

代码语言:javascript
复制
函数listen用来初始化服务器可连接队列。
服务器处理客户端连接时是顺序处理的,同一时间只能处理一个客户端连接。
当多个客户端的连接请求同时到来的时候,服务器将不能处理的客户端连接请求放入到等待队列中,这个队列的长度由listen()函数来指定。
(这里面包括了还没握手的、一次握手的、两次握手的,只要还没握完,通通进去待着)

大多数系统的设置为20,其实真的没必要太多,真的。
根据系统的可承受负载和程序的需求来确定。
系统有一个最大侦听队列数,一般是128(somaxconn),可以调优。

接收网络来访者:允许连接

代码语言:javascript
复制
accept() #被动接受TCP客户端连接,(阻塞式)等待连接的到来

accept() 方法阻塞并等待传入连接。当一个客户端连接时,它将返回一个新的 socket 对象,对象中有表示当前连接的 conn 和一个由主机、端口号组成的 IPv4/v6 连接的元组。

我们将用这个 socket 对象和客户端进行通信。


客户端方面:申请连接

代码语言:javascript
复制
connect((HOST, PORT))

参数不用我再释义了吧。返回一个通信套接字。

主动初始化TCP服务器连接,。一般address的格式为元组(hostname,port),如果连接出错,返回socket.error错误。

connect_ex() connect()函数的扩展版本,出错时返回出错码,而不是抛出异常。


关闭通信套接字:close()

用于关闭对某一个套接字的函数。


公共用途的套接字函数

代码语言:javascript
复制
s.recv() 	# 接收 TCP 数据,数据以字符串形式返回,bufsize 指定要接收的最大数据量。flag 提供有关消息的其他信息,通常可以忽略。
s.send() 	# 发送 TCP 数据,将 string 中的数据发送到连接的套接字。返回值是要发送的字节数量,该数量可能小于 string 的字节大小。
s.recvfrom() 	# 接收 UDP 数据,与 recv() 类似,但返回值是(data,address)。其中 data 是包含接收数据的字符串,address 是发送数据的套接字地址。
s.sendto() 	# 发送 UDP 数据,将数据发送到套接字,address 是形式为(ipaddr,port)的元组,指定远程地址。返回值是发送的字节数。

这里面函数要拿出来单讲都能写一篇。


服务端/客户端,放码过来

我先打个样儿,后来人可以直接拿去修改了自己用:

服务端

代码语言:javascript
复制
import socket

# create a socket object
serversocket = socket.socket(socket.AF_INET, socket.SOCK_STREAM) 

# get local machine name
host = socket.gethostname()                           

port = 8088

# bind to the port
serversocket.bind((host, port))                                  
print("Server start at port: 8088")
# queue up to 5 requests
serversocket.listen(5)                                           

while True:
    # establish a connection
    clientsocket,addr = serversocket.accept()      

    print("Got a connection from %s" % str(addr))

    msg='Thank you for connecting'+ "\r\n"
    clientsocket.send(msg.encode('utf-8'))
    clientsocket.close()

客户端

代码语言:javascript
复制
import socket

# create a socket object
s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)

# get local machine name
host = socket.gethostname()

port = 8088

# connection to hostname on the port.
s.connect((host, port))

# Receive no more than 1024 bytes
msg = s.recv(1024)

s.close()

print (msg.decode('ascii'))

结果输出

代码语言:javascript
复制
Server start at port: 8088
Got a connection from ('172.28.47.243', 9599)
代码语言:javascript
复制
Thank you for connecting

本文是处理单连接的,这是一种场景,不过更过的场景是处理多连接,大并发的。 后面会出啦,我先去调查一下Python是否支持epoll。

因为这篇主要是为我六月份的那个项目服务的,所以连接足够用啦。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2021/04/19 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 文章目录
  • 打开一个网络接口:套接字
  • 绑定IP与端口:bind
  • 监听网络来信:监听套接字
  • 接收网络来访者:允许连接
  • 客户端方面:申请连接
  • 关闭通信套接字:close()
  • 公共用途的套接字函数
  • 服务端/客户端,放码过来
    • 服务端
      • 客户端
        • 结果输出
        相关产品与服务
        云服务器
        云服务器(Cloud Virtual Machine,CVM)提供安全可靠的弹性计算服务。 您可以实时扩展或缩减计算资源,适应变化的业务需求,并只需按实际使用的资源计费。使用 CVM 可以极大降低您的软硬件采购成本,简化 IT 运维工作。
        领券
        问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档