iis服务器助手广告广告
返回顶部
首页 > 资讯 > 服务器 >OpenStackAPI的使用套路分享
  • 742
分享到

OpenStackAPI的使用套路分享

OpenStackAPI使用OpenStackAPI 2023-02-16 15:02:37 742人浏览 薄情痞子
摘要

目录写在前面获取token小栗子:获取所有实例详情写在前面 近期有openstack和vmware相关的开发需求,N年前从事虚拟化运维的时候玩过了,所以对它俩的api使用套路早忘得一

写在前面

近期有openstack和vmware相关的开发需求,N年前从事虚拟化运维的时候玩过了,所以对它俩的api使用套路早忘得一干二净。这次借这个机会把使用套路做个文档并分享出来,希望可以帮到有需要的盆友。本篇先分享openstack的API使用套路,后续再分享vmware api的使用套路。在本篇中,只给出了1个小例子,更多例子可自行去写代码,API的使用套路当然是万变不离其宗。

OpenStack官方API文档:https://docs.openstack.org/zed/api/

还有最重要的一点,请确保你已经搭建好openstack环境

获取token

Https://docs.openstack.org/api-quick-start/api-quick-start.html

通过上面的API页面可得知,认证服务的API是:http://controller:5000/v3/

使用python代码请求token

import requests
import JSON

USER = "admin"
PASSWord = "xxxxxx"
DOMaiN = "Default"
PROJECT = "admin"

TOKEN_URL = "http://10.0.0.10:5000/v3/auth/tokens?nocatalog"

def getToken():
    reqjson = {
        "auth":{
            "identity":{
                "methods":["password"],
                "password":{
                    "user":{
                        "domain":{"name":DOMAIN},
                        "name":USER,
                        "password":PASSWORD
                    }
                }
            },
            "scope":{
                "project":{
                    "domain":{
                        "name":DOMAIN
                    },
                    "name":PROJECT
                }
            }
        }
    }
    payload = json.dumps(reqJson)
    headers = {
    'Content-Type': 'application/json'
    }

    response = requests.request("POST", TOKEN_URL, headers=headers, data=payload)

    return response.headers.get("X-Subject-Token")


if __name__ == "__main__":
    token = getToken()
    print(token)

获取到的token如下:

gAAAAABj2cwy_AOflA6gDQiR8fGK0VzLGawXPScsKB-1hIp46jdkCY68Nuz8ZQ8-USTcyY_3cCoJRpIsq8OrcZl8ztMSkUU26VF_dnkBLm4lXAyM3DZF8lHWoqmEHOevfuC0IwqQdQ66FTUF7Nl9sFElFlB39QEuSR1mZSTBrJy6bwycd8a_C5c

小栗子:获取所有实例详情

假设有个需求,获取所有实例的详情信息。提到虚拟机实例,那肯定就是nova服务,所以要知道nova服务的api。在之前访问API的页面中,就是Compute服务。服务端点是http://controller:8774/v2.1

Compute API 官方文档:https://docs.openstack.org/api-ref/compute/

openstack的api是完全遵循REST风格的api,通过上面的api文档可得知,请求方法是GET,点开detail,可以看到更详细的API说明。

下面使用Python写代码

import requests
import json

USER = "admin"
PASSWORD = "xxxxxxxxx"
DOMAIN = "Default"
PROJECT = "admin"

TOKEN_URL = "http://10.0.0.10:5000/v3/auth/tokens?nocatalog"
SERVER_DETAIL_URL = "http://10.0.0.10:8774/v2.1/servers/detail"

def getToken():
    reqJson = {
        "auth":{
            "identity":{
                "methods":["password"],
                "password":{
                    "user":{
                        "domain":{"name":DOMAIN},
                        "name":USER,
                        "password":PASSWORD
                    }
                }
            },
            "scope":{
                "project":{
                    "domain":{
                        "name":DOMAIN
                    },
                    "name":PROJECT
                }
            }
        }
    }
    payload = json.dumps(reqJson)
    headers = {
    'Content-Type': 'application/json'
    }

    response = requests.request("POST", TOKEN_URL, headers=headers, data=payload)

    return response.headers.get("X-Subject-Token")

def serversDetail(token):
    headers = {
    'X-Auth-Token': token
    }
    response = requests.request("GET", SERVER_DETAIL_URL, headers=headers)
    serversList = response.json().get("servers")
    for s in serversList:
        status = s.get("status")
        name = s.get("name")
        ip = s.get("addresses").get("my-net")[0].get("addr")
        print(status, name, ip)

if __name__ == "__main__":
    token = getToken()
    serversDetail(token)

结果

(u'SHUTOFF', u'app-2', u'172.18.45.60')
(u'SHUTOFF', u'app-4', u'172.18.45.34')
(u'SHUTOFF', u'app-5', u'172.18.45.71')
(u'SHUTOFF', u'app-3', u'172.18.45.67')
(u'SHUTOFF', u'app-1', u'172.18.45.26')
(u'SHUTOFF', u'WEB', u'172.18.45.38')

到此这篇关于OpenStack API的使用套路分享的文章就介绍到这了,更多相关OpenStack API内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: OpenStackAPI的使用套路分享

本文链接: https://www.lsjlt.com/news/196428.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • OpenStackAPI的使用套路分享
    目录写在前面获取token小栗子:获取所有实例详情写在前面 近期有openstack和vmware相关的开发需求,N年前从事虚拟化运维的时候玩过了,所以对它俩的API使用套路早忘得一...
    99+
    2023-02-16
    OpenStack API使用 OpenStack API
  • Vue嵌套路由怎么使用
    这篇“Vue嵌套路由怎么使用”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Vue嵌套路由怎么使用”文章吧。用 Vue CLI...
    99+
    2023-07-04
  • Spring中使用事务嵌套时需要警惕的问题分享
    目录前言问题描述问题结果原因追溯解决之道事务的传播机制总结前言 最近项目上有一个使用事务相对复杂的业务场景报错了。在绝大多数情况下,都是风平浪静,没有问题。其实内在暗流涌动,在有些异...
    99+
    2023-05-17
    Spring事务嵌套使用 Spring事务嵌套
  • 微信小程序嵌套的H5使用小程序分享(分享微信好友或朋友圈)
    需求说明 嵌套在微信小程序中的H5想要使用小程序自带分享功能,分享H5的页面给微信好友或朋友圈 实现原理 H5中可使用wx.miniProgram.postMessage向小程序的webview发送消息,会触发组件的message事件,在小...
    99+
    2023-08-21
    小程序 微信小程序 微信
  • 单页面路由工程如何使用微信分享及二次分享
    这篇文章主要介绍单页面路由工程如何使用微信分享及二次分享,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!wxShare 说明文档单页面路由工程使用微信分享及二次分享解决方案很多人在单页...
    99+
    2024-04-02
  • Vue.js 中如何使用嵌套路由
    本篇文章给大家分享的是有关 Vue.js 中如何使用嵌套路由,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。用 Vue CLI 进行设置如果尚未...
    99+
    2024-04-02
  • Vue中如何使用嵌套路由
    今天就跟大家聊聊有关Vue中如何使用嵌套路由,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。解决方案使用动态路由新建home.vue作为子页面组件&l...
    99+
    2024-04-02
  • vue-router里怎么使用嵌套路由
    今天小编给大家分享一下vue-router里怎么使用嵌套路由的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。模板抽离我们已经学...
    99+
    2023-07-04
  • vue-router中如何使用嵌套路由
    vue-router中如何使用嵌套路由,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。模板抽离我们已经学习过了Vue模板的另外定义形式,使用...
    99+
    2024-04-02
  • MyEclipse常用的使用技巧分享
    这篇文章主要介绍“MyEclipse常用的使用技巧分享”,在日常操作中,相信很多人在MyEclipse常用的使用技巧分享问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”MyEclipse常用的使用技巧分享”的疑...
    99+
    2023-06-17
  • 使用JQuery实现的分页插件分享
    JQuery分页插件是一种非常常用的工具,可以帮助开发人员快速实现网页中的分页功能。以下是一个使用JQuery实现的分页插件的示例代...
    99+
    2023-08-14
    JQuery
  • java避免多层嵌套循环用到的一些小技巧分享
    目录避免多层嵌套循环用到的小技巧(1)借用第三个List,使用Contains()方法(2)数据量大,使用HashSet(3)JAVA8及以上使用lambda表达式跳出java中的多...
    99+
    2024-04-02
  • vue嵌套路由-query传递参数的示例分析
    这篇文章主要介绍了vue嵌套路由-query传递参数的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。在嵌套路由中我们经常会遇到父路由...
    99+
    2024-04-02
  • Vue3 - setup script的使用体验分享
    目录前言使用导出变量&方法使用组件使用props - defineProps使用emits - defineEmit使用context - useContext指令总结前言 ...
    99+
    2024-04-02
  • 详解vue route介绍、基本使用、嵌套路由
    目录前言一、介绍、安装1.定义2.安装二、基本使用(代码后赋)三、嵌套路由1.布局逻辑2.效果展示3.代码四、注意前言 想要学习完整内容请关注主页的专栏——&...
    99+
    2024-04-02
  • 分享MySQL中锁的使用技巧
    MySQL 锁的使用技巧分享随着数据库应用的日益广泛,对数据库的并发控制和数据完整性要求也越来越高。在MySQL数据库中,锁是一种重要的并发控制手段,可以有效地保护数据的完整性和一致性。本文将对MySQL锁的使用技巧进行详细分享,并提供具体...
    99+
    2023-12-21
    MySQL 技巧
  • Vue3嵌套路由中使用keep-alive缓存多层的实现
    目录前言Demo项目结构路由层级扁平化给所有的 router-view 都嵌套上 keep-alive前言 keep-alive是Vue中的缓存标签, 组件在标签中的内容会被缓存下来...
    99+
    2023-05-16
    Vue3 keep-alive缓存多层 Vue3 缓存多层
  • vue.js Router中嵌套路由的实用示例
    目录前言用 Vue CLI 进行设置基本代码输入 Vue 路由配置嵌套路由总结前言 随着 Vue.js 单页应用(SPA)变得相当复杂,你开始需要 Vue 路由以及嵌套路由。嵌套路由...
    99+
    2024-04-02
  • 使用Nginx怎么实现一个非套路镜像站
    使用Nginx怎么实现一个非套路镜像站?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。方案一做了如下配置:12345678location ^~ /book-c/{ p...
    99+
    2023-06-08
  • Go语言中websocket的使用demo分享
    服务端代码 main.go package main import ( "errors" "fmt" "net/http" "sync" "time"...
    99+
    2022-12-28
    Go语言 websocket使用 Go语言 websocket Go websocket
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作