Python——如何实现零拷贝(python里面如何拷贝一个对象?)
off999 2024-10-29 15:00 39 浏览 0 评论
传统拷贝跟零拷贝技术流程
传统的拷贝过程可以总结如下:
- 应用调用read函数,向操作系统发起IO调用,上下文从用户态切换到内核态
- DMA 控制器将数据从磁盘读取到内核缓冲区
- CPU读取内核缓冲区并将数据复制到用户应用程序缓冲区,上下文从内核态切换到用户态,read函数返回
- 用户应用进程通过write函数发起IO调用,上下文从用户态切换到内核态
,将数据拷贝到socket缓冲区 - DMA控制器将数据从socket缓冲区复制到网卡设备,上下文从内核态切换到用户态,此时write函数返回
传统的拷贝机制通常有 4 个上下文切换,4 个拷贝数据(两个 CPU 拷贝和两个 DMA 拷贝)。
零拷贝技术的流程如下:
- 用户进程发起sendfile系统调用,上下文从用户态切换到内核态
- DMA 控制器将数据从硬盘复制到内核缓冲区
- CPU 将读缓冲区中的数据复制到套接字缓冲区
- DMA 控制器将数据从套接字缓冲区异步复制到网卡
- 上下文从内核模式切换到用户模式,并且 sendfile 函数返回
sendfile 实现的零拷贝只有 2 个上下文切换和 3 个拷贝(2 个 DMA 拷贝 + 1 个 CPU 拷贝)。
Python 实现文件零拷贝
我们先实现一个简单的文件接收服务器(zerocopy_server.py):
import socket
import hashlib
sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
server_port = 8082
server_addr = ("0.0.0.0", server_port)
print(f"Start server on port {server_port}")
sock.bind(server_addr)
sock.listen(1)
while True:
print("Waiting for connection")
connection, client_addr = sock.accept()
size = 0
try:
i = 0
while True:
data = connection.recv(65536)
i += 1
if data:
size += len(data)
else:
print("完成接收数据")
break
print(f"总大小: {size}")
finally:
connection.close()- 传统拷贝客户端
import socket
import time
sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
server_port = 8082
server_address = ('127.0.0.1', server_port)
sock.connect(server_address)
start = time.time()
try:
with open(r'test.tar.gz', 'rb') as f:
message = f.read()
sock.sendall(message)
finally:
sock.close()
end = time.time()
print('总时间: ', end-start)运行一下传统拷贝客户端的代码看看。
- 零拷贝客户端
import os
import socket
import time
sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
server_port = 8082
server_address = ("127.0.0.1", server_port)
sock.connect(server_address)
start = time.time()
try:
with open(r"test.tar.gz", "rb") as f:
ret = 0
offset = 0
while True:
ret = os.sendfile(sock.fileno(), f.fileno(), offset,65535)
offset += ret
if ret == 0:
break
finally:
sock.close()
end = time.time()
print("Total time: ", end - start)运行一下零拷贝客户端的代码看看。
结论
对比结果可以看到,本地传输一个1.2GB 的文件,零拷贝只需要 0.16 秒,而传统拷贝需要 0.51 秒。
客户端使用零拷贝技术所消耗的传输时间比传统拷贝方式要快。由于是本地测试,所以没有物理网卡。如果是通过网卡,总的传输时间会受到网卡传输速度的限制。
相关推荐
- 163免费邮箱入口(163免费邮箱入口官网)
-
手机163的登录入口163邮箱官网入口是;https://smart.mail.163.com/login.htm网易邮箱注册方法;1在浏览器搜索“网易邮箱”。2进入网易邮箱官网https://sma...
- 一笔签名设计免费版(设计自己的签名免费版)
-
我国法律没有规定签名时要求一笔一划的写,因此,怎么签名这是公民的自由,合同方式协商一致即可。 但是,在实践中,双方当事人签合同时,建议写工整,能让他人认识签名的是谁,另外,最好在名字上按个手印,...
- win10正式版下载官网(win10官网免费下载)
-
先看系统之家之类的系统盘网站提供的系统盘文件,都是Ghost系统盘。所有的Ghost系统盘都是网络上的电脑系统高手以Ghost系统映像文件为基础制作的系统安装盘,在必要的windows安装系统的基础...
- adobe indesign(adobe indesign 下载)
-
在InDesign中,您可以通过使用数据合并功能来快速导入全年日历。首先,您需要准备一个包含所有日期和相应格式的数据表格,然后在InDesign中创建一个日历模板。接下来,使用数据合并功能将数据表格与...
- qq32位版本下载官方(qq3.3.3版本下载)
-
1152活跃天。QQ等级升级需要的活跃天数和自然的日是完全不同的,活跃天并不等于自然天数。活跃天是需要满足加速条件后才能获得的,相当于某些业务的成长值,经验值等,QQ等级由四个标识图展示,从低到高分别...
- 最新版本qq手机版下载安装免费
-
你说的是下载QQ软件吗?现在手机应用市场里都有QQ软件下载的,或者直接百度也可以。不用。苹果手机在appstore里下载手机qq步骤如下:1.在苹果手机中打开自带的AppStore软件进入;2.按...
- 全国34个卫视频道(全国34个卫视频道节目单)
-
全国卫视频道不止34个。全国各地28大省级卫视:北京卫视·天津卫视·河北卫视·山西卫视·内蒙古卫视·辽宁卫视·吉林卫视·黑龙江卫视·江苏卫视·浙江卫视·安徽卫视·江西卫视·山东卫视·河南卫视·湖北卫视...
- 福昕pdf阅读器电脑版(福昕pdf阅读器电脑版怎么用)
-
这是因为你的pdf文件没有与福昕阅读器进行关联。你如果要想双击pdf文档后使用福昕阅读器打开,可以这样设置一下::选中pdf文档,右击鼠标,在快捷菜单中点击属性。点击“属性”对话框中“打开方式”右边的...
- 快吧游戏官网(快吧游戏中心)
-
1.快吧游戏可以通过官方网站或应用商店进行下载。2.官方网站提供了游戏的下载链接,也可以通过扫描二维码进行下载。快吧游戏是一款手机游戏,可以在应用商店中下载安装。以下是在iOS和Android系统...
- 最开放的浏览器下载(最开放的浏览器下载软件)
-
可以直接在浏览器设置内打开下载目录进行查看,步骤如下:所需材料:华为6X、华为浏览器示例。一、因为所有浏览器的设置基本一至,这里以华为浏览器为例,首先点击打开华为浏览器。二、打开浏览器后,点击右下角的...
- 万年历2025最新版(万年历2025最新版属相)
-
2024年正月初十对应的阳历出生日期是2024年2月1日。如果按照周岁来计算,他们属龙。辰龙(甲辰年):在中国传统文化中,龙象征着权力、尊贵和神圣。
- 163邮箱登录网页版(163邮箱登录网页版官网)
-
http://mail.163.com步骤一:输入邮箱官网网址http://mail.163.com/打开163邮箱登录入口界面。步骤二:输入已有的邮箱账号、密码,点击登录即可。步骤三:如果没有邮箱账...
- 青骄第二课堂学生登录入口(青骄第二课堂,登录入口)
-
青骄第二课堂学生账号注册是不需要学生注册的,是经过每个学校的老师就是班主任注册之后,学生才能登录首先我们要打开自己的微信,点击打开微信右上方的加号点击添加好友,点击公众号,搜索青椒第二课堂点...
欢迎 你 发表评论:
- 一周热门
- 最近发表
- 标签列表
-
- python计时 (73)
- python安装路径 (56)
- python类型转换 (93)
- python进度条 (67)
- python吧 (67)
- python的for循环 (65)
- python格式化字符串 (61)
- python静态方法 (57)
- python列表切片 (59)
- python面向对象编程 (60)
- python 代码加密 (65)
- python串口编程 (77)
- python封装 (57)
- python写入txt (66)
- python读取文件夹下所有文件 (59)
- python操作mysql数据库 (66)
- python获取列表的长度 (64)
- python接口 (63)
- python调用函数 (57)
- python多态 (60)
- python匿名函数 (59)
- python打印九九乘法表 (65)
- python赋值 (62)
- python异常 (69)
- python元祖 (57)
