news 2026/4/16 20:54: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/16 9:21:58

Python实战-学生信息管理系统开发(Tkinter+Json)

本项目是一个基于Python Tkinter的图形化学生信息管理系统&#xff0c;实现学生信息的增删改查、数据保存和文件导出等功能。 这个学生信息管理系统的逻辑非常简单&#xff0c;它就像一个电子笔记本&#xff1a;所有学生信息都记在一个列表里&#xff0c;并自动保存成一个文件&…

作者头像 李华
网站建设 2026/4/16 11:04:36

导热系数测试仪厂家推荐排行榜:2025最新口碑单深度解析

在选择导热系数测试仪时&#xff0c;企业常常面临诸多困扰。比如&#xff0c;测试结果不准确&#xff0c;影响产品研发进度&#xff1b;设备稳定性差&#xff0c;频繁出现故障耽误生产&#xff1b;售后服务不及时&#xff0c;遇到问题无法快速解决。为了帮助企业快速找到靠谱的…

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

Java中Set集合的概念

java.util.Set 是 Java 集合框架的子接口&#xff0c;继承自 Collection 接口&#xff0c;核心特征是存储的元素无序且不可重复&#xff0c;不支持通过索引访问元素。 一、核心特性 1. 元素唯一性 Set 集合不允许存储重复元素&#xff0c;判断元素是否重复的依据是 equals…

作者头像 李华
网站建设 2026/4/16 11:00:29

学习Java的技巧

吃透Java的实用技巧&#xff0c;从入门到进阶不走弯路作为一门经典的面向对象编程语言&#xff0c;Java不仅是计算机专业学子的必修课&#xff0c;也是很多后端开发者的入门首选。想要学好Java&#xff0c;靠死记硬背远远不够&#xff0c;找对方法才能事半功倍。分享几个亲测有…

作者头像 李华
网站建设 2026/4/16 12:58:20

实时协作文档编辑:用Tiptap打造团队写作新体验

实时协作文档编辑&#xff1a;用Tiptap打造团队写作新体验 【免费下载链接】tiptap The headless editor framework for web artisans. 项目地址: https://gitcode.com/GitHub_Trending/ti/tiptap 在远程办公成为常态的今天&#xff0c;团队协作文档编辑不再是可有可无的…

作者头像 李华