Swift学习与实践

azeqjz OpenStack: Swift学习与实践

Swift架构

  1. OpenStack的Swift服务架构具有一个前端服务:proxyserver (swift-proxy),和三个后端服务:account server (swift-account);container server (swift-container)和object server (swift-object)。Swift API 由 proxy server 进行维护。
  • Proxy Server: 处理API请求与定位请求的对象,编解码。
  • Ring:映射实体的名称到磁盘的存储位置。Accounts/Containers/Object Server都有自己的Ring。ring 保存了 object 与物理位置的映射关系,proxy server 与Ring通信,提出请求并找到 object。默认情况下,Ring的每个 partition 复制3份,存储的Ring需要分发到集群中所有的服务器中。
  • Account Server:保存所有container的列表。
  • Container Server:保存包含所有对象的列表。
  • Object Server:存储/获取/删除对象。
  1. Swift是一种分布式存储解决方案,它既不是文件系统也不是实时数据存储。
    -每份数据需要在不同 zones 复制,所以 zones 确保数据被隔离,一个 zone 损坏不会对集群产生影响。
    -推荐 zone 的数量为5,分布在5个节点上,Swift 默认对数据复制3份,如果某个zone瘫痪,数据仍然可以均匀分布。

Swift命令示意

  • 仍然支持swift post, swift list, 和 swift stat 等命令。新版本OpenStack逐步转向用OpenStack统一CLI。

  • 创建ring

swift-ring-builder <builder_file> add
    [r<region>]z<zone>-<ip>:<port>[R<r_ip>:<r_port>]/<device_name>_<meta>
     <weight>
    [[r<region>]z<zone>-<ip>:<port>[R<r_ip>:<r_port>]/<device_name>_<meta>
     <weight>] ...

    Where <r_ip> and <r_port> are replication ip and port.

or

swift-ring-builder <builder_file> add
    --region <region> --zone <zone> --ip <ip or hostname> --port <port>
    [--replication-ip <r_ip or r_hostname>] [--replication-port <r_port>]
    --device <device_name> --weight <weight>
    [--meta <meta>]

创建container与上传对象

操作用户权限要求

要求有admin权限或者swiftoperator权限。


要求admin或swiftoperator权限

dashboard操作

在Object Store中创建container:


创建container

在container中创建folder与上传对象:


上传对象

点击container的link:


点击container的link

CLI操作

查看用户权限是否可以操作swift
导入环境变量,可以用环境变量中的admin/favmvajW7WEh7MwEnUKnB4MkB登录OpenStack overcloud链接http://172.25.250.50,进入admin project。

[student@workstation ~(admin-admin)]$ source admin-rc 
[student@workstation ~(admin-admin)]$ 
[student@workstation ~(admin-admin)]$ cat admin-rc 
unset OS_SERVICE_TOKEN
export OS_USERNAME=admin
export OS_PASSWORD=favmvajW7WEh7MwEnUKnB4MkB
export OS_AUTH_URL=http://172.25.250.50:5000/v2.0
export PS1='[\u@\h \W(admin-admin)]\$ '
export OS_TENANT_NAME=admin
export OS_REGION_NAME=regionOne
[student@workstation ~(admin-admin)]$ 

可以通过env | grep OS_查询目前用户。

查看用户列表

[student@workstation ~(admin-admin)]$ openstack user list
+----------------------------------+------------+
| ID                               | Name       |
+----------------------------------+------------+
| f599788fec954a3298edd2ecd1003352 | admin      |
| de3b2c86585f4fcca2a8de1df60348aa | neutron    |
| e5a6b8abe19d43a89185b269264e7c5e | heat       |
| 5e5fd2f8fd32498fbb174ac382c62d80 | gnocchi    |
| eba44218530d421193a40ad70d773337 | aodh       |
| 579e3d3bc9bc4650a48bef93549d6dd2 | nova       |
| 7567550545cd4ae0b851a39d8eeab416 | glance     |
| 23166a38937e4ac195d1b701337a1e79 | ceilometer |
| d87768bbd094453389f88b2a0eb03223 | cinder     |
| d3740f4c3c454450a75e11daee5124aa | heat-cfn   |
| a8ce6463d0494b7e9de288997caa4ff3 | swift      |
| 66bc12cae73645238712bded0b729854 | developer1 |
| 4cc2c444ecb849ec9a9955200c95f8c5 | operator1  |
+----------------------------------+------------+

查看用户详细信息

[student@workstation ~(admin-admin)]$ openstack user show developer1
+------------+----------------------------------+
| Field      | Value                            |
+------------+----------------------------------+
| email      | developer1@lab.example.com       |
| enabled    | True                             |
| id         | 66bc12cae73645238712bded0b729854 |
| name       | developer1                       |
| project_id | c04a7309489b4b1393174db634117234 |
| username   | developer1                       |
+------------+----------------------------------+

查看用户所在项目

[student@workstation ~(admin-admin)]$ openstack project show c04a7309489b4b1393174db634117234
+-------------+----------------------------------+
| Field       | Value                            |
+-------------+----------------------------------+
| description | finance                          |
| enabled     | True                             |
| id          | c04a7309489b4b1393174db634117234 |
| name        | finance                          |
| properties  |                                  |
+-------------+----------------------------------+

查看用户权限是否可以操作swift

[student@workstation ~(admin-admin)]$  openstack  role assignment list -f json --user developer1 --project finance --names
[
  {
    "Project": "finance", 
    "Role": "_member_", 
    "User": "developer1"
  }, 
  {
    "Project": "finance", 
    "Role": "swiftoperator", 
    "User": "developer1"
  }
][student@workstation ~(admin-admin)]$  openstack  role assignment list -f json --user developer1 --project finance 
[
  {
    "Project": "c04a7309489b4b1393174db634117234", 
    "Role": "9fe2ff9ee4384b1894a90878d3e92bab", 
    "User": "66bc12cae73645238712bded0b729854"
  }, 
  {
    "Project": "c04a7309489b4b1393174db634117234", 
    "Role": "1669757ff40b48d0ba327905d6fe2643", 
    "User": "66bc12cae73645238712bded0b729854"
  }
][student@workstation ~(admin-admin)]$ 

切换目标用户进行操作

<未完>

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,319评论 5 459
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,801评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,567评论 0 319
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,156评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,019评论 4 355
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,090评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,500评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,192评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,474评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,566评论 2 309
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,338评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,212评论 3 312
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,572评论 3 298
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,890评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,169评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,478评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,661评论 2 335

推荐阅读更多精彩内容

  • 一、安装和配置对象存储服务Swift 在控制节点完成 1. 创建Swift的身份认证证书 加载admin客户端脚本...
    野狗子嗷嗷嗷阅读 4,439评论 0 2
  • 第一章 OpenStack基础 OpenStack管理的资源及提供的服务OpenStack做为一个操作系统,...
    sgt_tiger阅读 12,810评论 4 72
  • 主控节点安装配置 Keystone 认证服务 主控节点 IP:192.168.1.101 vim /etc/m...
    烟熏的皮囊阅读 1,902评论 0 51
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,494评论 18 139
  • 本文遵循「知识共享许可协议 CC-BY-NC-SA 4.0 International」,未经作者书面许可,不允许...
    laiwei阅读 11,720评论 1 24