关闭

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

标签: containersobjecttestingcapiencoding
1276人阅读 评论(0) 收藏 举报

注: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

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


0
0

猜你在找
【视频】C语言及程序设计(讲师:贺利坚)
【视频】Python爬虫工程师培养课程全套(讲师:韦玮)
【视频】Python全栈开发入门与实战(讲师:李杰)
【视频】2017软考网络规划设计师套餐(讲师:任铄)
【视频】2017软考软件设计师套餐(讲师:任铄)
【视频】2017软考信息系统项目管理师套餐(讲师:任铄)
【视频】软考(高级)项目经理实战营(讲师:张传波)
【视频】微信公众平台开发套餐(讲师:刘运强)
深度学习原理+实战+算法+主流框架套餐(讲师:唐宇迪)
2017系统集成项目管理工程师通关套餐(讲师:徐朋)
查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:636851次
    • 积分:7421
    • 等级:
    • 排名:第2808名
    • 原创:51篇
    • 转载:364篇
    • 译文:0篇
    • 评论:72条
    最新评论