V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
推荐学习书目
Learn Python the Hard Way
Python Sites
PyPI - Python Package Index
http://diveintopython.org/toc/index.html
Pocoo
值得关注的项目
PyPy
Celery
Jinja2
Read the Docs
gevent
pyenv
virtualenv
Stackless Python
Beautiful Soup
结巴中文分词
Green Unicorn
Sentry
Shovel
Pyflakes
pytest
Python 编程
pep8 Checker
Styles
PEP 8
Google Python Style Guide
Code Style from The Hitchhiker's Guide
loliordie
V2EX  ›  Python

Python 用 zipfile 在 USB 载体内解压文件为什么速度会持续降低啊....

  •  
  •   loliordie · 2019-08-28 09:48:57 +08:00 · 1459 次点击
    这是一个创建于 1943 天前的主题,其中的信息可能已经有所发展或是发生改变。

    大概 USB 硬盘里面有 5 个 T 的压缩包, 解压出来是几十万个 zip 文件. 直接用 zip 处理不了, 于是用 python 写了个小程序用 zipfile 进行处理. 天知道之前的运维什么要这么处理日志文件...

    结果解压了一天才 1 万个, 于是打了个 log 记录了下, 发现随着时间变长写入速度越来越低.

    一开始稳定在 18 MB/S(解压前大小), 然后处理到第 500 个就降低到 8 MB/S 了.

    解压后有 closed, 变量也有用 gc 手动回收内存...看了下资源监视器没发现什么异常...

    2 条回复    2019-09-03 10:28:25 +08:00
    Kagari
        1
    Kagari  
       2019-08-28 10:05:27 +08:00
    可能是 4k 太低了,你需要 NVME 固态
    lolizeppelin
        2
    lolizeppelin  
       2019-09-03 10:28:25 +08:00
    你读一下 zipfile 的源码就知道了

    根本原因在于 zip 设计本身,每一个文件需要写在这个文件的前分配空间写一段校验信息,文件越多校验的块也越多,zip 的性能自然就差
    加上 python 本来计算就慢,这种方式更放大了 python 的缺陷

    文件数量多非常不适合用 zip,非要用 zip 不如调系统的解压工具解压
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   3161 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 25ms · UTC 00:14 · PVG 08:14 · LAX 16:14 · JFK 19:14
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.