分享

OpenStack api使用记录

xioaxu790 发表于 2014-9-14 17:58:43 [显示全部楼层] 回帖奖励 阅读模式 关闭右栏 0 7352
问题导读

1、api中怎样使用GET方法的接口?
2、如何使用token id调用你使用的api?
3、获取认证token值的命令是什么?





openstack官方有提供api供开发者使用,可以使用api做一些外围的小工具,用来简化对openstack的管理。本篇主要讲解api中使用GET方法的接口,其余的POST、DELETE方法以后介绍。

    api-quickstart:http://docs.openstack.org/api/quick-start/content/index.html

    api-doc:http://api.openstack.org/api-ref.html

    环境:ubuntu12.10(10.1.1.186)

    如果你看了官方的quickstart,他会让你先生成一个X-Auth-Token值,然后使用这个认证的值调用相关的api接口。如下过程:
  1. curl -k -X 'POST' -v http://10.1.1.186:5000/v2.0/tokens -d '{"auth":{"passwordCredentials":{"username": "guol", "password":"123456"}}}' -H 'Content-type: application/json' | python -mjson.tool
复制代码



输出结果如下:
  1. {
  2.     "access": {
  3.         "serviceCatalog": {},
  4.         "token": {
  5.             "expires": "2013-01-27T04:55:35Z",
  6.             "id": "a4b6a871ff2f41a797c0b7d45c69f81e"
  7.         },
  8.         "user": {
  9.             "id": "4c1a6122fc874a8bb541a34be3b316ad",
  10.             "name": "guol",
  11.             "roles": [],
  12.             "roles_links": [],
  13.             "username": "guol"
  14.         }
  15.     }
  16. }
复制代码



然后使用token id调用你使用的api
  1. curl -X 'GET' -H  "X-Auth-Token:a4b6a871ff2f41a797c0b7d45c69f81e" -v http://10.1.1.186:5000/v2.0/tenants | python -mjson.tool
复制代码


输出的结果如下:
  1. {
  2. "tenants": [
  3. {
  4. "description": "\u4e91\u5e73\u53f0\u7ba1\u7406\u5458,\u5168\u5c40\u7ba1\u7406\u6240\u6709\u9879\u76ee",
  5. "enabled": true,
  6. "id": "3a3613f83183435d9c47aa362261f720",
  7. "name": "admin"
  8. }
  9. ],
  10. "tenants_links": []
  11. }
复制代码



    当你按照api-doc接着调用compute、image、volume等下面的api接口时,会发现统统没有返回值,经过一段时间的摸索,发现对下剩下的api接口是需要使用认证过的token才能使用的,下面的方法才是王道。

获取认证token值
  1. curl -X POST -d  '{"auth": {"tenantName": "VM", "passwordCredentials":{"username": "admin", "password": "123456"}}}' -H "Content-type: application/json" http://10.1.1.186:35357/v2.0/tokens | python -mjson.tool
复制代码


返回值如下:
  1. {
  2.     "access": {
  3.         "metadata": {
  4.             "is_admin": 0,
  5.             "roles": [
  6.                 "141927156f7a47d98858e51febaea8cf"
  7.             ]
  8.         },
  9.         "serviceCatalog": [
  10.             {
  11.                 "adpoints": [
  12.                     {
  13.                         "adminURL": "http://10.1.1.186:8774/v2/170bf7acb88646bc9147085d426c4671",
  14.                         "id": "e02aaf58a24641049fddfe7385ce9399",
  15.                         "internalURL": "http://10.1.1.186:8774/v2/170bf7acb88646bc9147085d426c4671",
  16.                         "publicURL": "http://10.1.1.186:8774/v2/170bf7acb88646bc9147085d426c4671",
  17.                         "region": "RegionOne"
  18.                     }
  19.                 ],
  20.                 "endpoints_links": [],
  21.                 "name": "nova",
  22.                 "type": "compute"
  23.             },
  24.             {
  25.                 "endpoints": [
  26.                     {
  27.                         "adminURL": "http://10.1.1.186:9292/v1",
  28.                         "id": "7c48fa4d876d44e0a3cb324a45a14931",
  29.                         "internalURL": "http://10.1.1.186:9292/v1",
  30.                         "publicURL": "http://10.1.1.186:9292/v1",
  31.                         "region": "RegionOne"
  32.                     }
  33.                 ],
  34.                 "endpoints_links": [],
  35.                 "name": "glance",
  36.                 "type": "image"
  37.             },
  38.             {
  39.                 "endpoints": [
  40.                     {
  41.                         "adminURL": "http://10.1.1.186:8776/v1/170bf7acb88646bc9147085d426c4671",
  42.                         "id": "c08114987bc0443d879436db6290dd08",
  43.                         "internalURL": "http://10.1.1.186:8776/v1/170bf7acb88646bc9147085d426c4671",
  44.                         "publicURL": "http://10.1.1.186:8776/v1/170bf7acb88646bc9147085d426c4671",
  45.                         "region": "RegionOne"
  46.                     }
  47.               ],
  48.                 "endpoints_links": [],
  49.                 "name": "volume",
  50.                 "type": "volume"
  51.             },
  52.             {
  53.                 "endpoints": [
  54.                     {
  55.                         "adminURL": "http://10.1.1.186:8773/services/Admin",
  56.                         "id": "cd6c3c2ac44340d6a78cb903ec9bcab3",
  57.                         "internalURL": "http://10.1.1.186:8773/services/Cloud",
  58.                         "publicURL": "http://10.1.1.186:8773/services/Cloud",
  59.                         "region": "RegionOne"
  60.                     }
  61.                 ],
  62.                 "endpoints_links": [],
  63.                 "name": "ec2",
  64.                 "type": "ec2"
  65.             },
  66.             {
  67.                 "endpoints": [
  68.                     {
  69.                         "adminURL": "http://10.1.1.186:8080/v1",
  70.                         "id": "a75755093500441ea954f4874ccecf15",
  71.                         "internalURL": "http://10.1.1.186:8080/v1/AUTH_170bf7acb88646bc9147085d426c4671",
  72.                         "publicURL": "http://10.1.1.186:8080/v1/AUTH_170bf7acb88646bc9147085d426c4671",
  73.                         "region": "RegionOne"
  74.                     }
  75.                 ],
  76.                 "endpoints_links": [],
  77.                 "name": "swift",
  78.                 "type": "object-store"
  79.             },
  80.             {
  81.                 "endpoints": [
  82.                     {
  83.                         "adminURL": "http://10.1.1.186:35357/v2.0",
  84.                         "id": "196e553f9bcc4c8fa425bc0fa28a144b",
  85.                         "internalURL": "http://10.1.1.186:5000/v2.0",
  86.                         "publicURL": "http://10.1.1.186:5000/v2.0",
  87.                         "region": "RegionOne"
  88.                     }
  89.                 ],
  90.                 "endpoints_links": [],
  91.                 "name": "keystone",
  92.                 "type": "identity"
  93. }
  94.         ],
  95.         "token": {
  96.             "expires": "2013-01-27T05:06:50Z",
  97.             "id": "71fb5b7816804febbd89ed315fe67c94",
  98.             "tenant": {
  99.                 "description": "\u6240\u6709\u516c\u53f8\u81ea\u4e3b\u6e38\u620f\u7684\u524d\u7aef\u53d1\u5e03\u673a,\u5982\u8d5b\u5c14\u53f7,\u529f\u592b\u7b49",
  100.                 "enabled": true,
  101.                 "id": "170bf7acb88646bc9147085d426c4671",
  102.                 "name": "VM"
  103.             }
  104.         },
  105.         "user": {
  106.             "id": "24a2251c32504957ad2647c2448ffac3",
  107.             "name": "admin",
  108.             "roles": [
  109.                 {
  110.                     "name": "\u524d\u7aef\u6e38\u620f"
  111.                 }
  112.             ],
  113.             "roles_links": [],
  114.             "username": "admin"
  115.         }
  116.     }
  117. }
复制代码



使用返回的token id和tenant id调用api返回该tenant下的servers
  1. curl -X GET -H "X-Auth-Token:71fb5b7816804febbd89ed315fe67c94" -H "Content-type: application/json" http://10.1.1.186:8774/v2/170bf7acb88646bc9147085d426c4671/servers | python -mjson.tool
复制代码



返回结果如下
  1. {
  2.     "servers": [
  3.         {
  4.             "id": "ac561829-dffa-443e-a321-260d48f4cba3",
  5.                 {
  6.                     "href": "http://10.1.1.186:8774/v2/170bf7acb88646bc9147085d426c4671/servers/ac561829-dffa-443e-a321-260d48f4cba3",
  7.                     "rel": "self"
  8.                 },
  9.                 {
  10.                     "href": "http://10.1.1.186:8774/170bf7acb88646bc9147085d426c4671/servers/ac561829-dffa-443e-a321-260d48f4cba3",
  11.                     "rel": "bookmark"
  12.                 }
  13.             ],
  14.             "name": "VM1"
  15.         },
  16.         {
  17.             "id": "e3b84378-7598-48c8-8a1d-bd555c4c1f90",
  18.             "links": [
  19.                 {
  20.                     "href": "http://10.1.1.186:8774/v2/170bf7acb88646bc9147085d426c4671/servers/e3b84378-7598-48c8-8a1d-bd555c4c1f90",
  21.                     "rel": "self"
  22.                 },
  23.                 {
  24.                     "href": "http://10.1.1.186:8774/170bf7acb88646bc9147085d426c4671/servers/e3b84378-7598-48c8-8a1d-bd555c4c1f90",
  25.                     "rel": "bookmark"
  26.                 }
  27.             ],
  28.             "name": "VM2"
  29.         },
  30.         {
  31.             "id": "beafef2e-26c4-4320-9b45-70006e71785c",
  32.             "links": [
  33.                 {
  34.                     "href": "http://10.1.1.186:8774/v2/170bf7acb88646bc9147085d426c4671/servers/beafef2e-26c4-4320-9b45-70006e71785c",
  35.                     "rel": "self"
  36.                 },
  37.                 {
  38.                     "href": "http://10.1.1.186:8774/170bf7acb88646bc9147085d426c4671/servers/beafef2e-26c4-4320-9b45-70006e71785c",
  39.                     "rel": "bookmark"
  40.                 }
  41.             ],
  42.             "name": "VM3"
  43.         },
  44.         {
  45.             "id": "f8450270-9d96-4dba-b1c2-8ebcef1ff012",
  46.             "links": [
  47.                 {
  48.                     "href": "http://10.1.1.186:8774/v2/170bf7acb88646bc9147085d426c4671/servers/f8450270-9d96-4dba-b1c2-8ebcef1ff012",
  49.                     "rel": "self"
  50.                 },
  51.                 {
  52.                     "href": "http://10.1.1.186:8774/170bf7acb88646bc9147085d426c4671/servers/f8450270-9d96-4dba-b1c2-8ebcef1ff012",
  53.                     "rel": "bookmark"
  54.                 }
  55.             ],
  56.             "name": "VM4"
  57.         }
  58.     ]
  59. }
复制代码



通过返回值可以看到vm tenant中共包含VM1 VM2 VM3 VM4四台实例。

下面附上一个python调用api获取特定tenant下运行实例的脚本
  1. #!/usr/bin/python
  2. import base64,urllib,httplib,json,os
  3. from urlparse import urlparse
  4. url1="10.1.1.186:35357"
  5. params1 = '{"auth": {"tenantName": "tenant-name", "passwordCredentials":{"username": "admin", "password": "123456"}}}'
  6. headers1 = {"Content-Type": 'application/json'}
  7. conn1 = httplib.HTTPConnection(url1)
  8. conn1.request("POST","/v2.0/tokens",params1,headers1)
  9. response1 = conn1.getresponse()
  10. data1 = response1.read()
  11. dd1 = json.loads(data1)
  12. conn1.close()
  13. apitoken = dd1['access']['token']['id']
  14. apitenant= dd1['access']['token']['tenant']['id']
  15. apiurl = dd1['access']['serviceCatalog'][0]['endpoints'][0]['publicURL']
  16. apiurlt = urlparse(dd1['access']['serviceCatalog'][0]['endpoints'][0]['publicURL'])
  17. url2 = apiurlt[1]
  18. params2 = urllib.urlencode({})
  19. headers2 = { "X-Auth-Token":apitoken, "Content-type":"application/json" }
  20. conn2 = httplib.HTTPConnection(url2)
  21. conn2.request("GET", "%s/servers" % apiurlt[2], params2, headers2)
  22. response2 = conn2.getresponse()
  23. data2 = response2.read()
  24. dd2 = json.loads(data2)
  25. conn2.close()
  26. for i in range(len(dd2['servers'])):
  27.     print dd2['servers'][i]['name']
复制代码





没找到任何评论,期待你打破沉寂

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关闭

推荐上一条 /2 下一条