当前位置: 首页 > news >正文

服务器运行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虚拟内存限制
http://www.zskr.cn/news/116492.html

相关文章:

  • 终极ASMR音频资源快速下载完整指南
  • 网通领域发光二极管(LED)应用全解析:从基础认知到选型要点
  • 10 个AI写作工具,自考论文轻松搞定!
  • Win系统更新常出错?一键永久彻底禁止Win更新,简单易用,小白也可轻松禁止系统更新操作,附2款工具
  • 如何快速获取完整中国行政区划数据:终极管理工具指南
  • 金仓数据库:不止于兼容,更以三重革新赋能企业数字化深水区
  • EmotiVoice语音自豪感合成增强成就反馈
  • pose-search:人体动作分析与姿态搜索终极指南
  • AI文字语音项目:搭建一个支持情感控制、可二次封装的TTS服务
  • 大模型备案“拦截关键词”咋做?一份干货避坑指南
  • 智能检索系统进阶指南:解锁代理规划与深度推理双引擎实战
  • SQL SERVER对每张表新增字段
  • EmotiVoice在脱口秀AI主持人开发中的潜力
  • Emby美化插件终极指南:打造专属影音中心
  • 如何用EmotiVoice打造个性化语音助手?开发者实战指南
  • veScale分布式训练终极指南:解锁大规模AI模型高效训练
  • EmotiVoice语音合成情感传染效应研究:听众情绪共鸣测试
  • Obsidian与Zotero的无缝集成:学术工作流的革命性突破
  • OpenProject版本决策指南:如何从开源社区版升级到企业级解决方案
  • 2025年上海疲劳试验机品牌商排行榜,新测评精选疲劳试验机生 - myqiye
  • 多模态视频理解技术架构与应用实践深度解析
  • 【分析式AI】-LightGBM算法命名解释
  • FanControl温度记忆系统:告别风扇抽搐的智能调校手册
  • 语雀文档导出神器yuque2book:让知识自由流动的终极解决方案
  • LLC谐振变换器变频移相(PFM + PSM)混合控制仿真探秘
  • 2025年AI获客公司技术栈观察:从RPA到GEO,TOP5架构解析与开源启示
  • Inter字体:数字时代的视觉语言革新者
  • 如何快速掌握网页链接优化:终极免费工具使用指南
  • HTTP状态码
  • SharedArrayBuffer is not defined