[openstack swift]3 其他相关(2)

转载 2011年08月10日 00:04:12

注:swift1.1版使用swift-auth-add-user生成用户,swift1.3之后用户信息全部记录在proxy-server.conf 的[filter:tempauth]过滤器里,差别并不明显。文章完成时的安装环境为swift1.1,swift版本稳定之后会补充说明因版本差异而造成的变动!

3.2swift应该如何使用

OpenStack Object Storage Developer Guide 列举了通用API,这里只是对常用的操作做简单举例

约定:

  1. account: test  
  2. user:tester  
  3. password: testing  

用户的生成参照1.1节swift安装教程。

(注:st是swifttool 的缩写,swift1.3之后st更名为swift,因此实践时请注意版本差异!)

3.2.1 使用st

任何安装了st的机器都可以使用,并不限于storage node 或者 proxy-auth node

查询用户状态

  1. swift@node31:~$ st -v -A https://192.168.1.31:11000/v1.0 -U test:tester -K testing stat  
  2. StorageURL: https://192.168.1.31:8080/v1/AUTH_d6084598cca04ee6a0951dbdd89612c6  
  3. Auth Token: AUTH_tkefdc936d7e94493982d78f3dd6c16ead  
  4.    Account: AUTH_d6084598cca04ee6a0951dbdd89612c6  
  5. Containers: 2  
  6.    Objects: 8  
  7.      Bytes: 15177385  

列表用户的container和object

  1. swift@node31:~$ st -A https://192.168.1.31:11000/v1.0 -U test:tester -K testing list  
  2. images  
  3. mp3  
  4. swift@node31:~$ st -v -A https://192.168.1.31:11000/v1.0 -U test:tester -K testing list images  
  5. 1Mb.file  
  6. test.jpg  
  7. test1.jpg  

上传object

  1. swift@node31:~$ st -v -A https://192.168.1.31:11000/v1.0 -U test:tester -K testing upload images 1Mb.file  

下载object

  1. swift@node31:~$ st -v -A https://192.168.1.31:11000/v1.0 -U test:tester -K testing download images 1Mb.file  
  2. 1Mb.file  

3.2.2使用curl

curl用来自定义网络报文,因此可以和提供Restful API的swift进行交互。从curl的格式来看,大概能窥测到使用语言封装object请求的方法。:)


查询用户状态

  1. zzfancy@129:~$ curl -k -D - -H 'X-Storage-User: test:tester' -H 'X-Storage-Pass: testing' https://192.168.1.31:11000/v1.0  
  2. HTTP/1.1 204 No Content  
  3. X-Storage-Url: https://192.168.1.31:8080/v1/AUTH_d6084598cca04ee6a0951dbdd89612c6  
  4. X-Storage-Token: AUTH_tkefdc936d7e94493982d78f3dd6c16ead  
  5. X-Auth-Token: AUTH_tkefdc936d7e94493982d78f3dd6c16ead  
  6. Content-Length: 0  
  7. Date: Tue, 02 Aug 2011 08:43:10 GMT  

查看空间使用情况

  1. zzfancy@129:~$ curl -k -X HEAD -D -  -H 'X-Auth-Token: AUTH_tkefdc936d7e94493982d78f3dd6c16ead' https://192.168.1.31:8080/v1/AUTH_d6084598cca04ee6a0951dbdd89612c6  
  2. HTTP/1.1 204 No Content  
  3. X-Account-Object-Count: 8  
  4. X-Account-Bytes-Used: 15177385  
  5. X-Account-Container-Count: 2  
  6. Content-Length: 0  
  7. Date: Tue, 02 Aug 2011 08:47:02 GMT  

列表用户的container和object,可加参数(本例中参数为format-xml,详情请查询API)

  1. zzfancy@129:~$ curl -k -X GET -H 'X-Auth-Token: AUTH_tkefdc936d7e94493982d78f3dd6c16ead' https://192.168.1.31:8080/v1.0/AUTH_d6084598cca04ee6a0951dbdd89612c6/images  
  2. 1Mb.file  
  3. test.jpg  
  4. test1.jpg  
  5.   
  6. zzfancy@129:~$ curl -k -X GET -H 'X-Auth-Token: AUTH_tkefdc936d7e94493982d78f3dd6c16ead' https://192.168.1.31:8080/v1.0/AUTH_d6084598cca04ee6a0951dbdd89612c6/images?format=xml  
  7. <?xml version="1.0" encoding="UTF-8"?>  
  8. <container name="images">  
  9. <object>  
  10. <name>1Mb.file</name>  
  11. <hash>b6d81b360a5672d80c27430f39153e2c</hash>  
  12. <bytes>1048576</bytes>  
  13. <content_type>application/octet-stream</content_type>  
  14. <last_modified>2011-06-20T07:57:34.523220</last_modified>  
  15. </object>  
  16. <object>  
  17. <name>test.jpg</name>  
  18. <hash>a9d7d0f2d01bf737027256b8e7e9bf6a</hash>  
  19. <bytes>87345</bytes>  
  20. <content_type>image/jpeg</content_type>  
  21. <last_modified>2011-06-17T03:32:21.838280</last_modified>  
  22. </object>  
  23. <object><name>test1.jpg</name>  
  24. <hash>a9d7d0f2d01bf737027256b8e7e9bf6a</hash>  
  25. <bytes>87345</bytes>  
  26. <content_type>image/jpeg</content_type>  
  27. <last_modified>2011-06-19T16:07:39.431260</last_modified>  
  28. </object>  
  29. </container>  

创建container并上传object

  1. zzfancy@129:~$ curl -k -X PUT -T ./2Mb.jpeg -H 'Content-Type: image/jpeg' -H 'X-Auth-Token: AUTH_tkefdc936d7e94493982d78f3dd6c16ead' https://192.168.1.31:8080/v1.0/AUTH_d6084598cca04ee6a0951dbdd89612c6/images/2Mb.jpeg  
  2. <html>  
  3.  <head>  
  4.   <title>201 Created</title>  
  5.  </head>  
  6.  <body>  
  7.   <h1>201 Created</h1>  
  8.   <br /><br />  
  9.  </body>  
  10. </html>  

下载object

  1. zzfancy@129:~$ curl -s -k -X GET -H 'X-Auth-Token: AUTH_tkefdc936d7e94493982d78f3dd6c16ead' https://192.168.1.31:8080/v1/AUTH_d6084598cca04ee6a0951dbdd89612c6/images/2Mb.jpeg -O .  


3.2.3cyberduck

cyberduck 支持的服务类型非常广泛,详见官网[1]。虽然swift1.3之后没有再引入对cyberduck的介绍,但并不影响其使用。

笔者用的cyberduck版本为4.0.2(8601)。

填入服务器地址,端口,用户名和key

“路径”选项选填,默认为空


相关文章推荐

[openstack swift]3 其他相关(2)

******************转载请注明出处!********** 最后更新:2011年8月2日17:55:11 注:swift1.1版使用swift-auth-add-...
  • zzcase
  • zzcase
  • 2011年08月02日 17:53
  • 5884

[openstack swift]3 其他相关

******************转载请注明出处!********** 最后更新:2011年8月1日20:22:35 3.1CAP原则和swift的联系     这个idiot的小...
  • zzcase
  • zzcase
  • 2011年08月01日 20:23
  • 3990

Openstack swift支持s3 api

Openstack swift支持s3 api [root@swift1 swift]# cd /usr/local/src/;ls client keystone pip-1.3.1 p...

openstack 源码分析之swift proxy 服务启动 2

接上篇  通过wift-proxy-server 脚本,swift调用swift.common.wsgi中的run_wsgi(conf_file, 'proxy-server', default_po...
  • lcnsir
  • lcnsir
  • 2013年07月10日 23:29
  • 634

OpenStack_Swift源码分析——ObjectReplicator源码分析(2)

1、Replicator执行代码详细分析 上篇问中介绍了启动Replicator的具体过程,下面具体讲解Replicator的执行代码的具体实现: def replicate(self, o...

OpenStack_Swift源码分析——Object-auditor源码分析(2)

1 Object-aduitor审计具体分析 上一篇文章中,讲解了Object-aduitor的启动,其中审计的具体执行是AuditorWorker实现的,在run_audit中实例化了Audito...

[openstack swift]2基本概念

最后更新:2011年7月21日16:19:49 swift 的基本概念
  • zzcase
  • zzcase
  • 2011年07月21日 16:25
  • 7645

OpenStack文件注入相关分析(2)

上一篇博客中我们介绍了文件注入的相关内容,相关代码的结构,以及文件注入过程中支持的镜像文件挂载方式。现在,我们具体来看代码中文件注入的具体实现,由于在之前的虚拟机建立代码分析过程中涉及到了此部分的内容...

OpenStack Swift源码分析(3)----swift服务启动源码分析之三

本片博文开始以/usr/bin/swift-proxy-server为例,详细分析源码,来进一步解析swift中的服务启动过程; 首先来看swift-proxy-server代码: from swi...

openstack keystone v2 to v3

Disable NetworkManager systemctl stop NetworkManager systemctl disable NetworkManager systemctl ena...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:[openstack swift]3 其他相关(2)
举报原因:
原因补充:

(最多只允许输入30个字)