news 2026/1/27 22:35:28

服务器运行easyocr报错Could not initialize NNPACK! Reason: Unsupported hardware.——解决方法

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
服务器运行easyocr报错Could not initialize NNPACK! Reason: Unsupported hardware.——解决方法

BG:

之前在另外一台离线服务器(虚拟机),相同的conda环境,运行脚本无报错;conda环境迁移后,使用相同的环境和代码(python==3.9.0 easyocr==1.7.2)运行脚本。

日志发现最后一行报错如下:

[2025-12-16 05:35:53] [WARNING] Neither CUDA nor MPS are available - defaulting to CPU. Note: This module is much faster with a GPU. [W1216 05:36:01.540097613 NNPACK.cpp:61] Could not initialize NNPACK! Reason: Unsupported hardware.

ps -ef | grep 查看py程序已经挂掉。


排查步骤:

1. 可能是easyocr有问题,但脚本执行没有问题;

(ocr) ubuntu@xcznmz-1112:/opt/lung_data$ python -<< 'EOF' >

import torch

> print("torch imported")

> x = torch.randn(2,3)

> y = torch.mm(x, x.T)

> print("torch mm ok")

> EOF

torch imported

torch mm ok

(ocr) ubuntu@xcznmz-1112:/opt/lung_data$ python -<< 'EOF' >

import easyocr

> reader = easyocr.Reader(['en'], model_storage_directory='./model', user_network_directory='./model', download_enabled =False, gpu =False)

> print("easyocr ok")

> EOF Using CPU. Note: This module is much faster with a GPU.

easyocr ok


2. github发现有相似报错,推荐降低torch版本

但是我是离线服务器,不好修改conda环境,不想动环境。


3. 排查CPU 指令集兼容性

lscpu | grep -E "Model name|Flags"

发现缺少CPU指令集 AVX,尝试脚本开头增加环境变量设置:

# @-*- coding: utf-8 -*-
import os
import sys
os.environ['NNPACK_DISABLE'] = '1'
os.environ['OMP_NUM_THREADS'] = '2' # 对于双核CPU
os.environ['MKL_NUM_THREADS'] = '2'
os.environ['OPENBLAS_NUM_THREADS'] = '2'
import resource resource.setrlimit(resource.RLIMIT_AS, (4 * 1024**3, 4 * 1024**3)) # 4GB虚拟内存限制

新的报错:


visit_date=2025-11-16 16:39:40, 错误=[enforce fail at alloc_cpu.cpp:117] err == 0. DefaultCPUAllocator: can't allocate memory: you tried to allocate 9437184 bytes. Error code 12 (Cannot allocate memory) Traceback (most recent call last): File "/opt/lung_data/lung_main.py", line 843, in process_patients result = ocr(record) File "/opt/lung_data/lung_main.py", line 285, in ocr reader_chi = easyocr.Reader(['ch_sim'], model_storage_directory='./model', user_network_directory='./model', download_enabled=False, gpu=False) File "/home/ubuntu/anaconda3/envs/ocr/lib/python3.9/site-packages/easyocr/easyocr.py", line 214, in __init__ self.detector = self.initDetector(detector_path) File "/home/ubuntu/anaconda3/envs/ocr/lib/python3.9/site-packages/easyocr/easyocr.py", line 271, in initDetector return self.get_detector(detector_path, File "/home/ubuntu/anaconda3/envs/ocr/lib/python3.9/site-packages/easyocr/detection.py", line 75, in get_detector net = CRAFT() File "/home/ubuntu/anaconda3/envs/ocr/lib/python3.9/site-packages/easyocr/craft.py", line 35, in __init__ self.basenet = vgg16_bn(pretrained, freeze) File "/home/ubuntu/anaconda3/envs/ocr/lib/python3.9/site-packages/easyocr/model/modules.py", line 27, in __init__ vgg_pretrained_features = models.vgg16_bn( File "/home/ubuntu/anaconda3/envs/ocr/lib/python3.9/site-packages/torchvision/models/_utils.py", line 142, in wrapper return fn(*args, **kwargs) File "/home/ubuntu/anaconda3/envs/ocr/lib/python3.9/site-packages/torchvision/models/_utils.py", line 228, in inner_wrapper return builder(*args, **kwargs) File "/home/ubuntu/anaconda3/envs/ocr/lib/python3.9/site-packages/torchvision/models/vgg.py", line 459, in vgg16_bn return _vgg("D", True, weights, progress, **kwargs) File "/home/ubuntu/anaconda3/envs/ocr/lib/python3.9/site-packages/torchvision/models/vgg.py", line 103, in _vgg model = VGG(make_layers(cfgs[cfg], batch_norm=batch_norm), **kwargs) File "/home/ubuntu/anaconda3/envs/ocr/lib/python3.9/site-packages/torchvision/models/vgg.py", line 81, in make_layers conv2d = nn.Conv2d(in_channels, v, kernel_size=3, padding=1) File "/home/ubuntu/anaconda3/envs/ocr/lib/python3.9/site-packages/torch/nn/modules/conv.py", line 521, in __init__ super().__init__( File "/home/ubuntu/anaconda3/envs/ocr/lib/python3.9/site-packages/torch/nn/modules/conv.py", line 166, in __init__ torch.empty( RuntimeError: [enforce fail at alloc_cpu.cpp:117] err == 0. DefaultCPUAllocator: can't allocate memory: you tried to allocate 9437184 bytes. Error code 12 (Cannot allocate memory)

尝试修改代码,EasyOCR Reader 只创建一次,但是仍然出现上述两个报错。


4. 尝试将新服务器启用host cpu,重启后,运行脚本虽然还是报
Could not initialize NNPACK! Reason: Unsupported hardware.
但是py脚本并没有挂掉——解决!

将脚本开头的环境变量注释掉,仍然正常运行,未出现脚本挂掉的情况

import os import sys os.environ['NNPACK_DISABLE'] = '1' # os.environ['OMP_NUM_THREADS'] = '1' # 单线程最稳定 # os.environ['MKL_NUM_THREADS'] = '1' # os.environ['OPENBLAS_NUM_THREADS'] = '1' import resource # resource.setrlimit(resource.RLIMIT_AS, (8 * 1024**3, 8 * 1024**3)) # 8GB虚拟内存限制
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/1/23 7:40:58

豆包手机与应用封杀:技术变革与商业帝国的正面交锋

2025年12月&#xff0c;豆包手机一经发布&#xff0c;就引起了巨大的关注。这款结合了深度AI助手与智能操作系统的手机&#xff0c;在市场上被视为一次对传统智能手机行业的颠覆。然而&#xff0c;刚刚推出不久&#xff0c;豆包手机便遭遇了 微信、支付宝、淘宝 等主流应用的封…

作者头像 李华
网站建设 2026/1/2 15:26:56

DSP28335 ADC的转换和计算方法,电压对应的是3V还是3.3V?对应ADC是4095还是4096?

对于DSP28335的ADC,一个最关键的信息是:其满量程对应的电压是3.0V,而不是系统电源的3.3V。输入电压若超过3V可能会损坏芯片。 下面是它的转换原理、计算方法和一些需要注意的关键点。 📊 ADC转换计算方法 DSP28335内置一个12位ADC,可将0-3V的模拟电压线性映射为0-4095…

作者头像 李华
网站建设 2026/1/22 7:06:25

python中模型加速训练accelerate包的用法

文章目录介绍应用示例适配训练环境快速启动分布式训练推理时的显存优化优势介绍 accelerate 最核心的价值是简化大模型训练 / 推理的硬件适配&#xff0c;它抽象了不同硬件&#xff08;单卡、多卡、CPU、TPU、GPU 混合精度&#xff09;的底层差异&#xff0c;让你用一套代码就…

作者头像 李华
网站建设 2026/1/2 13:27:49

科技发展的ai

科技发展的双重赋能与治理困境&#xff1a;在创新与平衡中探寻可持续路径摘要科技发展作为人类文明进步的核心驱动力&#xff0c;在重塑经济结构、优化生活方式、破解全球难题等方面展现出颠覆性力量。从智能手机普及到人工智能赋能产业升级&#xff0c;从绿色技术革新到跨领域…

作者头像 李华
网站建设 2026/1/17 4:31:27

Java基础阶段练手项目清单

Java基础阶段练手项目清单这份清单覆盖语法应用、逻辑训练、简单数据处理等核心能力&#xff0c;适合刚学完基础语法的新手&#xff0c;无需框架&#xff0c;只用JDK即可完成。1. 控制台计算器- 核心需求&#xff1a;实现加、减、乘、除、取余运算&#xff0c;支持输入两个数字…

作者头像 李华
网站建设 2026/1/26 15:52:23

30、Linux系统操作与资源指南

Linux系统操作与资源指南 1. info工具的操作 info工具是Linux系统中常用的帮助工具,其相关文件存放在 /usr/share/info 目录下。在info工具中,有一些常用的组合键操作,如下表所示: | 组合键 | 操作 | | — | — | | 空格键、PageDown | 向下滚动到下一页 | | 退格键…

作者头像 李华