升级 ceph (16.2 -> 18.2) ceph mon 启动失败

ceph 升级后, ceph mon 启动报错:

复制代码
Dec 31 12:55:11 server ceph-mon[15982]: 2025-12-31T12:55:11.930+0800 7f60570a3e40 -1 _open error initializing leveldb db back storage in /var/lib/ceph/mon/ceph-server/store.db
Dec 31 12:55:11 server ceph-mon[15982]: /builddir/build/BUILD/ceph-18.2.6/src/mon/MonitorDBStore.h: In function 'void MonitorDBStore::_open(const std::string&)' thread 7f60570a3e40 time 2025-12-31T12:55:11.930993+0800
Dec 31 12:55:11 server ceph-mon[15982]: /builddir/build/BUILD/ceph-18.2.6/src/mon/MonitorDBStore.h: 635: ceph_abort_msg("MonitorDBStore: error initializing keyvaluedb back storage")

大致原因之前使用 level db,ceph 18.2 使用变为了 rocksdb。

恢复方法,通过 osd 信息重建 mon。

  1. 使用 osd 上存储的信息重建 mon

    ms=<directory>
    mkdir $ms

    for host in host_list; do rsync -avz "ms" root@host:"ms"; rm -rf "ms" ssh root@host <<EOF
    for osd in /var/lib/ceph/osd/ceph-*; do
    ceph-objectstore-tool --data-path $osd --op update-mon-db --mon-store-path ms done EOF rsync -avz root@host:ms ms; done

  2. 重建 mon 存储

    ceph-monstore-tool <directory> rebuild -- --keyring <keyring>

如果没有 keyring

复制代码
ceph-monstore-tool <directory> rebuild
  1. 替换

    mv /var/lib/ceph/mon/<mon-ID>/store.db
    /var/lib/ceph/mon/<mon-ID>/store.db.corrupted

  2. 导出 mon

    ceph-mon -i <mon-ID> --extrace-monmap /tmp/lastmap

  3. 删除 mon ,注意 默认生成的 mon 无法启动,需要删除

    monmaptool --rm a /tmp/lastmap

  4. 重新添加 mon

    monmaptool --add <mon-ID> <mon ip>:6789 /tmp/lastmap

  5. 导入 mon

    ceph-mon -i <mon-ID> --inject-monmap /tmp/lastmap

  6. 启动 mon

    systemctl start ceph-mon@<mon-ID>

相关推荐
杨云龙UP1 小时前
ODA运维实战:Oracle 19c YJXT PDB表空间在线扩容全过程_20260503
linux·运维·服务器·数据库·oracle
yyuuuzz2 小时前
aws 基础认知与实践注意点
运维·服务器·网络·云计算·github·aws
Rust语言中文社区2 小时前
【Rust日报】2026-05-02 Temper - 用 Rust 编写的 Minecraft 服务器项目发布 0.1.0 版
运维·服务器·开发语言·后端·rust
吠品2 小时前
高性能JS数组操作:何时选用push、unshift、splice或扩展运算符?
linux·服务器·数据库
fish_xk2 小时前
Linux中的指令和权限
linux·运维·服务器
暴力求解2 小时前
Linux---内核态
linux·运维·服务器
mounter6253 小时前
深入理解 Linux 网络新特性:netkit 中的 RX/TX Queue Leasing 与 TCP Devmem
linux·服务器·网络·tcp/ip·kernel
空中海3 小时前
02. 静态逆向、Manifest 分析与 Smali 重打包
服务器·网络·windows
江南十四行3 小时前
AI Agent应用类型及Function Calling开发实战(三)
服务器·前端·javascript
炘爚3 小时前
TCP三次握手和四次挥手
服务器·网络·tcp/ip