生成一新用户:python
在两个集群当中都建立相同的管理用户json
radosgw-admin user create --uid=admin --display-name=admin --access_key=admin --secret=123456 |
这里为了测试方便使用了简单密码swift
此时admin还仅仅是普通的权限,须要经过cap添加user的capabilities,例如:异步
radosgw-admin caps add --uid=admin --caps="users=read, write" |
$ radosgw-admin user create --display-name="johnny rotten" --uid=johnny
{ "user_id": "johnny",
"rados_uid": 0,
"display_name": "johnny rotten",
"email": "",
"suspended": 0,
"subusers": [],
"keys": [
{ "user": "johnny",
"access_key": "TCICW53D9BQ2VGC46I44",
"secret_key": "tfm9aHMI8X76L3UdgE+ZQaJag1vJQmE6HDb5Lbrz"}],
"swift_keys": []}
删除一用户:工具
$ radosgw-admin user rm --uid=johnny
删除一个用户和与他相关的桶及内容:测试
$ radosgw-admin user rm --uid=johnny --purge-data
删除一个桶:ui
$ radosgw-admin bucket unlink --bucket=foo
显示一个桶从 2012 年 4 月 1 日起的日志:this
$ radosgw-admin log show --bucket=foo --date=2012-04-01
显示某用户 2012 年 3 月 1 日(不含)到 4 月 1 日期间的使用状况:url
$ radosgw-admin usage show --uid=johnny \
--start-date=2012-03-01 --end-date=2012-04-01
只显示全部用户的使用状况汇总:spa
$ radosgw-admin usage show --show-log-entries=false
裁剪掉某用户 2012 年 4 月 1 日以前的使用信息:
$ radosgw-admin usage trim --uid=johnny --end-date=2012-04-01
radosgw-admin 工具备不少命令,可完成各类管理任务:
用指定的 ceph.conf 配置文件而非默认的 /etc/ceph/ceph.conf 来肯定启动时所需的监视器地址。
链接到指定监视器,而非经过 ceph.conf 查询。
radosgw 用户的 ID 。
子用户名字。
用户的电子邮件地址。
配置用户的显示名称(昵称)
S3 访问密钥。
生成随机访问密钥(给 S3 )。
指定密钥的密文。
生成随机密钥。
密钥类型,可用的有: swift 、 S3 。
临时 URL 密钥。
给用户设置系统标识。
指定桶名
指定对象名
某些命令所需的日期
某些命令所需的起始日期
某些命令所需的终结日期
执行 mdlog list 时为可选项。对 mdlog trim 、 replica mdlog get/delete 、 replica datalog get/delete 来讲是必须的。
librados 认证所需的 auid 。
删除用户前先删除用户数据。
若加了此选项,删除子用户时将一块儿删除其全部密钥。
删除桶前先删除其内全部对象。
用 metadata get 检索元数据时用的密钥。
radosgw 所在的 region 。
radosgw 所在的区域。
除了检查桶索引,还修复它。
检查桶:根据对象的实际状态重建桶索引。
为某些操做指定输出格式: xml 、 json 。
user stats 的选项,收集用户的桶索引状态、并同步到用户状态。
执行 log show 时,显示或不显示日志条目。
执行 log show 时,显示或不显示日志汇总。
让 log show 只显示数字字段非零的日志。
设置时指定要读取的文件。
给 opstate set 命令指定状态。
复制日志类型( metadata 、 data 、 bucket ),操做复制日志时须要。
逗号分隔的一系列类目,显示使用状况时须要。
能力列表,如 “usage=read, write; user=read” 。
某些特定操做须要。
为配额命令指定桶。
指定最大对象数(负数为禁用)。
指定最大尺寸(单位为字节,负数为禁用)。
配额有效范围(桶、用户)。
执行下面的命令新建一个用户 (S3 接口):
实例以下:
radosgw-admin user create --uid=johndoe --display-name="John Doe" --email=john@example.com
为了给用户新建一个子用户 (Swift 接口) ,你必须为该子用户指定用户的 ID(--uid={username}),子用户的 ID 以及访问级别:
radosgw-admin subuser create --uid={uid} --subuser={uid} --access=[ read | write | readwrite | full ]
实例以下:
radosgw-admin subuser create --uid=johndoe --subuser=johndoe:swift --access=full
Note:full 并不表示 readwrite, 由于它还包括访问权限策略.
要获取一个用户的信息,你必须使用 user info 子命令而且制定一个用户 ID(--uid={username}) .
radosgw-admin user info --uid=johndoe
要修改一个用户的信息,你必须指定用户的 ID (--uid={username}),还有 你想要修改的属性值。典型的修改项主要是 access 和secret 密钥,邮件地址,显 示名称和访问级别。举例以下:
radosgw-admin user modify --uid=johndoe --display-name="John E. Doe"
要修改子用户的信息, 使用 subuser modify 子命令而且执行子用户的 ID. 举例以下:
radosgw-admin subuser modify --uid=johndoe:swift --access=full
当你建立了一个用户,用户默认状况下是处于启用状态的。然而,你能够暂停用户权 限并在之后随时从新启用它们。暂停一个用户,使用 user suspend 子命令 而后哦指定用户的 ID:
radosgw-admin user suspend --uid=johndoe
要从新启用已经被停用的用户,使用 user enable 子命令并指明用户的 ID.
radosgw-admin user enable --uid=johndoe
Note:停用一个用户后,它的子用户也会一块儿被停用.
删除用户时,这个用户以及他的子用户都会被删除。固然,若是你愿意,能够只删除子用户。要删除用户(及其子用户),可以使用 user rm 子命令并指明用户 ID :
radosgw-admin user rm --uid=johndoe
只想删除子用户时,可以使用 subuser rm 子命令并指明子用户 ID 。
radosgw-admin subuser rm --subuser=johndoe:swift
其它可选操做:
在你删除子用户的同时,也失去了 Swift 接口的访问方式,可是这个用户在系统 中还存在。要删除子用户,可以使用 subuser rm 子命令并指明子用户 ID :
radosgw-admin subuser rm --subuser=johndoe:swift
其它可选操做:
要为用户新建一个密钥,你须要使用 key create 子命令。对于用户来讲,须要指明用户的 ID 以及新建的密钥类型为 s3 。要为子用户新建一个密钥,则须要指明子用户的 ID以及密钥类型为 swift 。实例以下:
radosgw-admin key create --subuser=johndoe:swift --key-type=swift --gen-secret
用户和子用户要能使用 S3 和Swift 接口,必须有 access 密钥。在你新 建用户或者子用户的时候,若是没有指明 access 和 secret 密钥,这两 个密钥会自动生成。你可能须要新建 access 和/或 secret 密钥,不论是 手动指定仍是自动生成的方式。你也可能须要删除一个 access 和 secret 。可用的选项有:
要新建密钥,须要指明用户 ID.
radosgw-admin key create --uid=johndoe --key-type=s3 --gen-access-key --gen-secret
你也可使用指定 access 和 secret 密钥的方式.
要删除一个 access 密钥, 也须要指定用户 ID.
radosgw-admin key rm --uid=johndoe
Ceph 存储集群提供了一个管理API,它容许用户经过 REST API 执行管理功能。默认状况下,用户没有访问 这个 API 的权限。要启用用户的管理功能,须要为用 户提供管理权限。
执行下面的命令为一个用户添加管理权限:
radosgw-admin caps add --uid={uid} --caps={caps}
你能够给一个用户添加对用户、bucket、元数据和用量(存储使用信息)等数据的 读、写或者全部权限。举例以下:
--caps="[users|buckets|metadata|usage|zone]=[*|read|write|read, write]"
实例以下:
radosgw-admin caps add --uid=johndoe --caps="users=*"
要删除某用户的管理权限,可用下面的命令:
radosgw-admin caps rm --uid=johndoe --caps={caps}
在你启用用户的配额前 ,你须要先设置配额参数。 例如:
radosgw-admin quota set --quota-scope=user --uid=<uid> [--max-objects=<num objects>] [--max-size=<max size>]
实例以下:
radosgw-admin quota set --quota-scope=user --uid=johndoe --max-objects=1024 --max-size=1024
最大对象数和最大存储用量的值是负数则表示不启用指定的 配额参数。
在你设置了用户配额以后,你能够启用这个配额。实例以下:
radosgw-admin quota enable --quota-scope=user --uid=<uid>
你也能够禁用已经启用了配额的用户的配额。 举例以下:
radosgw-admin quota-disable --quota-scope=user --uid=<uid>
Bucket 配额做用于用户的某一个 bucket,经过 uid 指定用户。这些配额设置是独立于用户以外的。:
radosgw-admin quota set --uid=<uid> --quota-scope=bucket [--max-objects=<num objects>] [--max-size=<max size>]
最大对象数和最大存储用量的值是负数则表示不启用指定的 配额参数。
在你设置了 bucket 配额以后,你能够启用这个配额。实例以下:
radosgw-admin quota enable --quota-scope=bucket --uid=<uid>
你也能够禁用已经启用了配额的 bucket 的配额。 举例以下:
radosgw-admin quota-disable --quota-scope=bucket --uid=<uid>
你能够经过用户信息 API 来获取每个用户的配额 设置。经过 CLI 接口读取用户的配额设置信息,请执行下面的命令:
radosgw-admin user info --uid=<uid>
配额的统计数据的同步是异步的。你也能够经过手动获 取最新的配额统计数据为全部用户和全部 bucket 更新配额统计数据:
radosgw-admin user stats --uid=<uid> --sync-stats
执行下面的命令获取当前用户已经消耗了配额的多少:
radosgw-admin user stats --uid=<uid>
Note:你应该在执行 radosgw-admin user stats 的时候带上 --sync-stats 参数来获取最新的数据.
你能够在 region map中读取和设置配额。执行下面的命 令来获取 region map:
radosgw-admin regionmap get > regionmap.json
要为整个 region 设置配额,只须要简单的修改 region map 中的配额设置。而后使用 region set 来更新 region map便可:
radosgw-admin region set < regionmap.json
Note:在更新 region map 后,你必须重启网关.
Ceph 对象网关会为每个用户记录用量数据。你也能够经过指定日期范围来跟踪用户的用量数据。
可用选项以下:
Note:你能够指定时间为分钟和秒,可是数据存储是以一个小时的间隔存储的.
显示用量统计数据,使用 usage show 子命令。显示某一个特定 用户的用量数据,你必须指定该用户的 ID。你也能够指定开始日期、结 束日期以及是否显示日志条目。:
radosgw-admin usage show --uid=johndoe --start-date=2012-03-01 --end-date=2012-04-01
经过去掉用户的 ID,你也能够获取全部用户的汇总的用量信息
radosgw-admin usage show --show-log-entries=false
对于大量使用的集群而言,用量日志可能会占用大量存储空间。你能够为全部用户或者一个特定的用户删除部分用量日志。你也能够为删除操做指定日期范围。:
radosgw-admin usage trim --start-date=2010-01-01 --end-date=2010-12-31
radosgw-admin usage trim --uid=johndoe
radosgw-admin usage trim --uid=johndoe --end-date=2013-12-31