rbd创建特定的用户

!这是关于 Ceph 用户权限管理的非常重要且实用的内容。让我为你详细讲解:

核心概念理解

1. 为什么需要非管理员用户?

bash 复制代码
# 管理员用户(危险!)
ceph auth get-or-create client.admin mon 'allow *' osd 'allow *' mgr 'allow *'
# 权限:可以执行任何操作,包括删除整个集群!

# 专用用户(安全!)
ceph auth get-or-create client.rbd_user mon 'profile rbd' osd 'profile rbd pool=mypool'
# 权限:只能操作特定存储池的 RBD 功能

命令语法详解

基本结构

bash 复制代码
ceph auth get-or-create client.{用户名} \
    mon '权限描述' \
    osd '权限描述' \
    mgr '权限描述'

各部分权限说明

A. Monitor (mon) 权限
bash 复制代码
# 常用的 mon 权限配置
mon 'allow r'          # 只读权限
mon 'allow rw'         # 读写权限  
mon 'profile rbd'      # RBD 专用权限(推荐)
B. OSD 权限(最重要)
bash 复制代码
# 基本格式
osd 'profile {权限类型} pool={池名}'

# 权限类型选项:
profile rbd                   # RBD 完整权限
profile rbd-read-only         # RBD 只读权限
profile rbd-read-write        # RBD 读写权限
C. Manager (mgr) 权限
bash 复制代码
# RBD 相关的 manager 权限
mgr 'profile rbd'             # RBD 管理权限

实际应用示例

示例1:创建基础的 RBD 用户

bash 复制代码
# 创建只能操作 rbdpool 的 RBD 用户
ceph auth get-or-create client.rbd_user \
    mon 'profile rbd' \
    osd 'profile rbd pool=rbdpool' \
    mgr 'profile rbd'

示例2:创建多池权限用户(如文档中的例子)

bash 复制代码
# 用户 qemu 对 vms 池有读写权限,对 images 池有只读权限
ceph auth get-or-create client.qemu \
    mon 'profile rbd' \
    osd 'profile rbd pool=vms, profile rbd-read-only pool=images' \
    mgr 'profile rbd pool=images'

示例3:创建只读监控用户

bash 复制代码
# 只能查看 RBD 信息,不能修改
ceph auth get-or-create client.monitor \
    mon 'profile rbd' \
    osd 'profile rbd-read-only pool=rbdpool' \
    mgr 'profile rbd'

完整的创建和使用流程

步骤1:创建专用用户

bash 复制代码
#!/bin/bash
USER_NAME="myrbduser"
POOL_NAME="rbdpool"

echo "=== 创建 RBD 专用用户 ==="

# 创建用户并保存keyring
ceph auth get-or-create client.$USER_NAME \
    mon 'profile rbd' \
    osd 'profile rbd pool='$POOL_NAME \
    mgr 'profile rbd' > /etc/ceph/ceph.client.$USER_NAME.keyring

echo "用户创建完成"

步骤2:验证用户权限

bash 复制代码
# 使用新用户测试权限
ceph --user $USER_NAME -s                    # 应该能查看集群状态
ceph --user $USER_NAME osd pool ls           # 应该能查看存储池
rbd --user $USER_NAME ls --pool $POOL_NAME   # 应该能操作 RBD

# 测试越权操作(应该失败)
ceph --user $USER_NAME osd pool create test_pool 8 8  # 应该被拒绝

步骤3:客户端使用配置

bash 复制代码
# 在客户端机器上配置
# 将keyring文件复制到客户端
scp /etc/ceph/ceph.client.$USER_NAME.keyring client-machine:/etc/ceph/

# 在客户端使用指定用户
rbd map --pool $POOL_NAME myimage --user $USER_NAME

权限验证和测试

查看用户权限

bash 复制代码
# 查看所有用户
ceph auth ls

# 查看特定用户的权限详情
ceph auth get client.$USER_NAME

# 测试用户具体能执行哪些命令
ceph --user $USER_NAME osd lspools    # 应该成功
ceph --user $USER_NAME osd pool delete rbdpool rbdpool --yes-i-really-really-mean-it  # 应该失败

权限边界测试

bash 复制代码
#!/bin/bash
# 测试用户权限边界

USER="myrbduser"
POOL="rbdpool"

echo "=== 权限测试 ==="

# 1. 应该成功的操作
echo "测试允许的操作:"
ceph --user $USER -s >/dev/null 2>&1 && echo "✓ 查看集群状态"
rbd --user $USER ls --pool $POOL >/dev/null 2>&1 && echo "✓ 查看 RBD 镜像"

# 2. 应该失败的操作  
echo "测试禁止的操作:"
ceph --user $USER osd pool create test_pool 8 8 >/dev/null 2>&1 || echo "✓ 禁止创建存储池"
ceph --user $USER osd pool delete $POOL $POOL --yes-i-really-really-mean-it >/dev/null 2>&1 || echo "✓ 禁止删除存储池"

生产环境最佳实践

按用途创建专用用户

bash 复制代码
# 虚拟机用户(只能操作 vm_pool)
ceph auth get-or-create client.vm_user mon 'profile rbd' osd 'profile rbd pool=vm_pool' mgr 'profile rbd'

# 备份用户(只读权限)
ceph auth get-or-create client.backup mon 'profile rbd' osd 'profile rbd-read-only pool=vm_pool' mgr 'profile rbd'

# 监控用户(只读所有池)
ceph auth get-or-create client.monitor mon 'profile rbd' osd 'profile rbd-read-only' mgr 'profile rbd'

Keyring 文件管理

bash 复制代码
# 正确的文件权限设置
chmod 600 /etc/ceph/ceph.client.*.keyring
chown ceph:ceph /etc/ceph/ceph.client.*.keyring

# 密钥备份
cp /etc/ceph/ceph.client.myrbduser.keyring /backup/

故障排除

常见权限错误

bash 复制代码
# 错误:权限不足
rbd: error opening pool rbdpool: (13) Permission denied

# 解决:检查用户权限
ceph auth get client.myrbduser

# 错误:keyring文件找不到
rbd: couldn't connect to cluster: (13) Permission denied

# 解决:指定keyring文件
rbd --user myrbduser --keyring /etc/ceph/ceph.client.myrbduser.keyring ls

总结

这个机制的核心价值:

  • ✅ 安全性:避免使用管理员权限执行日常操作
  • ✅ 职责分离:不同用途使用不同用户
  • ✅ 审计跟踪:便于追踪谁执行了什么操作
  • ✅ 故障隔离:一个用户密钥泄露不会影响整个集群

对于你的 RBD 测试环境,建议创建一个专用用户而不是一直使用 admin 用户!

相关推荐
IT_陈寒3 分钟前
SpringBoot 项目启动慢?这5个优化技巧让你的应用快50%
前端·人工智能·后端
GISer_Jing12 分钟前
React核心语法:组件化与声明式编程
前端·react.js·前端框架
DJ斯特拉12 分钟前
文件上传(UUID防止重名文件&&阿里云实现云端上传&&MultipartFile接收前端文件)
前端
Alan Lu Pop17 分钟前
React 表单提交关键词意外触发刷新
前端·javascript·react.js
掘金安东尼20 分钟前
企业级Claw落地避坑指南:70%项目失败的真实原因
前端·面试·github
这儿有一堆花20 分钟前
从技术标准到营销概念:深度解析 HTML5 与 H5 的演变与区别
前端·html·html5
我命由我1234521 分钟前
React - 创建 React 项目、React 项目结构、React 简单案例、TodoList 案例
前端·javascript·react.js·前端框架·ecmascript·html5·js
SuperEugene22 分钟前
Vue3 Pinia 状态管理规范:何时用 Pinia 何时用本地状态|状态管理与路由规范篇
开发语言·前端·javascript·vue.js·前端框架
Moment23 分钟前
TypeScript 要换芯了,6.0 竟是旧编译器的最后一舞
前端·javascript·github
Cg1362691597428 分钟前
Element-入门
前端