news 2026/4/22 15:28:47

服务器运行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/4/13 14:17:30

EmotiVoice技术解析:多情感语音合成背后的秘密

EmotiVoice技术解析&#xff1a;多情感语音合成背后的秘密 在虚拟助手开始对你“冷笑”、游戏角色因剧情转折而声音颤抖的今天&#xff0c;我们早已不再满足于那种机械朗读式的AI语音。用户想要的是有温度的声音——能愤怒、会撒娇、甚至带着一丝疲惫的叹息。正是在这种需求驱动…

作者头像 李华
网站建设 2026/4/23 0:09:58

八股学习日常(Spring篇)

1.说说对Srping的理解1&#xff09;Ioc容器&#xff1a;Spring通过控制反转实现了对象的创建以及依赖管理&#xff0c;开发者只需定义好Bean和依赖关系&#xff0c;Spring可帮助其实现创建以及组装这些对象。2&#xff09;aop&#xff1a;面向切面编程&#xff0c;开发者可以自…

作者头像 李华
网站建设 2026/4/16 17:55:32

AI安全攻防演练平台搭建与实战指南

项目概述 【免费下载链接】AI-Red-Teaming-Playground-Labs AI Red Teaming playground labs to run AI Red Teaming trainings including infrastructure. 项目地址: https://gitcode.com/gh_mirrors/ai/AI-Red-Teaming-Playground-Labs AI安全攻防演练平台是一个专门用…

作者头像 李华
网站建设 2026/4/10 22:33:12

如何快速获取完整中国行政区划数据:终极管理工具指南

想要轻松掌握全国行政区划信息吗&#xff1f;中国行政区划数据管理工具为你提供从省到村的完整五级联动地址数据&#xff0c;让地址管理变得前所未有的简单高效&#xff01; 【免费下载链接】Administrative-divisions-of-China 中华人民共和国行政区划&#xff1a;省级&#x…

作者头像 李华
网站建设 2026/4/18 16:51:10

Easy Effects音效优化完全指南:从入门到精通的专业预设配置

Easy Effects音效优化完全指南&#xff1a;从入门到精通的专业预设配置 【免费下载链接】easyeffects Limiter, compressor, convolver, equalizer and auto volume and many other plugins for PipeWire applications 项目地址: https://gitcode.com/gh_mirrors/ea/easyeffe…

作者头像 李华
网站建设 2026/4/17 3:33:17

Hslcommunication

上文截图中的方法&#xff0c;数组最大数量是960&#xff0c;版本如下。

作者头像 李华