Rust LanceDB 内存不足问题

报错内容:

log 复制代码
thread '<unnamed>' (245) panicked at library/std/src/sys/pal/unix/stack_overflow.rs:231:13:
failed to set up alternative stack guard page: Cannot allocate memory (os error 12)
note: run with `RUST_BACKTRACE=1` environment variable to display a backtrace

thread '<unnamed>' (246) panicked at library/std/src/sys/pal/unix/stack_overflow.rs:231:13:
failed to set up alternative stack guard page: Cannot allocate memory (os error 12)
2026-03-19 15:07:33 [lance_io::local] DEBUG - get_range: range=713265..717361

thread '<unnamed>' (247) panicked at library/std/src/sys/pal/unix/stack_overflow.rs:227:13:
failed to allocate an alternative stack: Cannot allocate memory (os error 12)
2026-03-19 15:07:33 [lance_io::local] DEBUG - open; path=Path { raw: "app/data/lancedb_data/documents.lance/data/3836854-10fc-49da-af99-3315c0982ed4.lance" } block-size=4096 know.
fatal runtime error: failed to initiate panic, error fatal runtime error: failed to initiate panic, error fatal runtime error: failed to initiate panic, error 555, aborting
, aborting
, aborting
memory allocation of 41 bytes failed

猜测一:RAM 不足

从报错可以看到是内存分配失败,启动时监控内存 free -mh,内存变化不大,确认不是 RAM 不足。

猜测二:Docker 容器限制

猜测是 Docker 容器限制了内存使用,修改 docker-compose.yaml

yaml 复制代码
services:
  app:
    image: your-image
    mem_limit: 128g

发现还是不行。

猜测三:虚拟内存不足

根据AI推理,修改 stack 大小

yaml 复制代码
services:
  app:
    ulimits:
      stack: 1024

仍然不行。

尝试增加 swap,依然不行。

猜测四:mmap(实际问题)

因为 lancedb 会把数据读到 mmap 提高访问速度

查询系统允许的最大 mmap 数量

shell 复制代码
> cat /proc/sys/vm/max_map_count
262162 /proc/2440330/maps

查询 mmap 数量

shell 复制代码
pid=$(pgrep -f '/app/htknow|htknow' | head -n1)
wc -l /proc/$pid/maps

临时修改

shell 复制代码
sysctl -w vm.max_map_count=1048576

再启动就 ok 了,确认是该问题。

持久化配置

shell 复制代码
echo 'vm.max_map_count=2097152' | sudo tee /etc/sysctl.d/99-htknow.conf
sudo sysctl --system
相关推荐
花褪残红青杏小9 小时前
Rust图像处理第6节- 均值模糊 & 中值模糊:3×3 邻域的两种经典玩法
rust·webassembly·图形学
子兮曰13 小时前
前端工具链的「Rust 化」:一场没有赢家的军备竞赛?
前端·后端·rust
星栈15 小时前
写 Dioxus Demo 不难,难的是把它写成项目
前端·rust·前端框架
mCell17 小时前
【锐评】桌面端技术营销:别拿跑分当工程判断
前端·rust·electron
武子康21 小时前
调查研究-201 Rust 里的 dev build 和 release build:为什么同一份代码性能差这么多?
后端·架构·rust
doiito1 天前
【Agent Harness】Gliding Horse 的 L2 作战地图:让多 Agent 协作从“摸黑”变成“透明”
ai·rust·架构设计·系统设计·ai agent
星栈2 天前
我用 Rust + Dioxus 做了个全栈跨平台笔记应用:再把新建、编辑和交付补上
前端·rust·前端框架
独孤留白2 天前
从C到Rust:基本类型 C 的隐式不确定 vs Rust 的显式确定
rust
清晨很温柔啊2 天前
# 用 Rust 手搓 AI 自演化主板:当 18 个异构器官长出 C++ 骨骼
rust
星栈3 天前
我用 Rust + Dioxus 做了个全栈跨平台笔记应用:第一版先把列表和详情跑通
前端·rust·前端框架