效率篇-“私人订制”Openstack管理后台

当在排除万难上线openstack后,发现官方管理后台(dashboard)那么的简洁、那么的歪果仁化,有没有一种做一次“私人订制”的冲动。在线上跑了一段时间后这种冲动转化了动力,用了半个月时间推出融合部门内各个同事需求的openstack 管理后台。

不能容忍的点

1.各个机房都会存在1+套openstack,管理员需要登录多套dashboard。

2.虚机等信息与运维平台脱节,eg:这台vm属于哪个应用,属于哪个运维负责,属于哪个资产登记号等等。

改造的目标

1.运维同事只在一个入口就可以管理所有的openstack。

2.与现有运维平台信息互通。

3.尽量靠近公有云的用户体验模式。

改造的功能

实例(虚机):创建、删除、升级配置、启动、停止、在线迁移、登陆等。

卷(硬盘):创建、扩容、镜像、删除等。

模板(虚机cpu、内存、系统盘):创建、删除等。

镜像:实时同步数据。(因为上传镜像需要花上时间,就用命令行进行)

还有其它配套功能。

使用技术

前端:angularjs 双向绑定,主要呈现结果页面快速显示(也可以用ajax来全部构建)。

后端:java(jsp、spring、mybatis)。

与openstack对接的工作层:python。

后端与工作层中引入队列:减低页面操作量大,从而引起的瓶颈风险。

架构

Web:现有运维平台。(除了特殊数据外,其它数据都在运维平台数据中留一份,提高查询效率)

Queue:存储操作请求。

Worker:与openstack Restful API打交道,并把结果返回Web。

(非特殊情况,只准单向操作,Web中操作Openstack,从而保证数据一致性)

效果对比

|||||||||||

创建实例

原模式

现在效果

|||||||||||

实例列表

原模式

现效果

太多张图片就不在这里一一列举了,页面用户交互基本参考了各大公有云(阿里、tx、ucloud)厂商实现。

刚上线的时候,童鞋们的表情是这样,大家都还满意新的管理界面。

Openstack对接介绍

对Openstack的使用基本基于四种方式:

1.OpenStack client

2.cURL

3.Rest API(本次改造是基于该模式)

4.OpenStack SDK

这里介绍两个API,其它可以详读API文档(http://docs.openstack.org/api/quick-start/content/index.html)(用curl进行示范)

PS:OpenStack client中每个命令都可以加入-debug 从而看到每个命令详细调用过程。

post和get请求各举例一个。可以有个认识:post是增删改相关;get是查询相关。

1.获取访问权限和API前缀

http://管理端:5000/v2.0/tokens

方式:POST

参数:

tenantName, passwordCredentials,username ,password

eg:

curl -d ‘{"auth":{"tenantName":"","passwordCredentials":{"username":"", "password":""}}}‘ -H "Content-type: application/json" http://:5000/v2.0/tokens | python -m json.tool

注意:header 中 content-type 必须json

返回结果:包含了token、nova、glance、neutron等访问授权和api前缀。

2.获取实例信息

(http://IP:PORT/v2/授权id/)servers/实例id

()内是通过授权获得的信息。

方式:GET

参数:实例id

eg:

curl -s -H "X-Auth-Token: xxx" http://172.16.10.2:8774/v2/2f50e3cc08d944fdb9dd0e328659c6f0/servers/2f77c971-4848-4923-84e3-c224498300d1  | python -mjson.tool

{

"server": {

"OS-DCF:diskConfig": "AUTO",

"OS-EXT-AZ:availability_zone": "nova",

"OS-EXT-SRV-ATTR:host": "noc",

"OS-EXT-SRV-ATTR:hypervisor_hostname": "nodctc",

"OS-EXT-SRV-ATTR:instance_name": "instance-00000001",

"OS-EXT-STS:power_state": 1,

"OS-EXT-STS:task_state": null,

"OS-EXT-STS:vm_state": "active",

"OS-SRV-USG:launched_at": "201000",

"OS-SRV-USG:terminated_at": null,

"accessIPv4": "",

"accessIPv6": "",

"addresses": {

"Private": [

{

"OS-EXT-IPS-MAC:mac_addr": "fa:16:ae:9eb",

"OS-EXT-IPS:type": "fixed",

"addr": "192.1682",

"version": 4

}

]

},

"config_drive": "",

"created": "2016-14Z",

"flavor": {

"id": "2",

"links": [

{

"href": "http://172.16.10.2:8774/2f50e3cc08d944fdb9dd0e328659c6f0/flavors/2",

"rel": "bookmark"

}

]

},

"hostId": "b30ea8de3f06f2e7f9771aee23badc99f24a3b05cba13fe7f893682d",

"id": "2f77c971-4848-4923-84e3-c224498300d1",

"image": {

"id": "b7d10944-9afc-4b22-8d01-364305716e3c",

"links": [

{

"href": "http://172.16.10.2:8774/2f50e3cc08d944fdb9dd0e328659c6f0/images/b7d10944-9afc-4b22-8d01-364305716e3c",

"rel": "bookmark"

}

]

},

"key_name": null,

"links": [

{

"href": "http://172.16.10.2:8774/v2/2f50e3cc08d944fdb9dd0e328659c6f0/servers/2f77c971-4848-4923-84e3-c224498300d1",

"rel": "self"

},

{

"href": "http://172.16.10.2:8774/2f50e3cc08d944fdb9dd0e328659c6f0/servers/2f77c971-4848-4923-84e3-c224498300d1",

"rel": "bookmark"

}

],

"metadata": {},

"name": "test",

"os-extended-volumes:volumes_attached": [],

"progress": 0,

"security_groups": [

{

"name": "default"

}

],

"status": "ACTIVE",

"tenant_id": "2f50e3cc08d944fdb9dd0e328659c6f0",

"updated": "201:14Z",

"user_id": "90cae4d95424"

}

}

浏览过官方API文档,大家应该觉得做openstack dashboard的二次开发不难,有冲动的兄弟姐妹们动手做个“私人订制”吧。

更多信息请关注微信订阅号:轻量运维

时间: 2024-10-08 21:20:20

效率篇-“私人订制”Openstack管理后台的相关文章

基于H.ui.Admin UI模板的网站管理后台

最近接手一个跨境电商平台开发,客户侧重电商网站UI设计,对管理后台要求不高,由我们决定选哪一款后台模板.找来找去,感觉还是H.ui靠谱一些,主要是这个模板清爽,不需要过多选择.其他的流行后台模板也看了,但功能繁杂,选择起来很费劲,要花很多时间拆解. 所以,考虑到是外包项目,速度和效率第一,越快上手越好. 现在把几个效果图贴出来,与大家分享,欢迎指正:

微信公众平台开发(9)管理后台开发

开发微信公众平台,不可少的自然会有管理后台,对开发模式下的各种功能进行管理.对应公众号的功能,总结需要管理的功能如下: 1.用户管理------保存用户openid.微信个人信息(服务号接口获取). 与自身应用系统关联: 2.用户消息记录----用户发送各类消息记录.菜单点击记录,  有了这些记录,结合客服消息接口.模板消息接口,可以做出对话效果,让用户体验更好: 3.自定义菜单----自定义菜单的编辑管理, 创建生成到微信: 4.关键字管理----基础关键字,直接回复图文消息或文本消息,  关

50个高端大气上档次的管理后台界面模板

大部分站点都有一个管理面板或者管理界面用于查看和管理站点信息.可是通常大家并非非常重视这个后台管理界面的设计,一般能用即可了.可是事实上美丽的管理界面也能大大的提升工作人员的工作效率啊.通过使用美丽的管理面板你能够省掉非常多的时间,同事,设计良好的界面也适合在移动终端上使用,从而降低对PC的依赖和提供管理的灵活性. 这里收集了50个高端大气上档次,简洁时尚国际化的后台管理界面模板,希望你能喜欢并获取灵感. 1. Katniss Premium Admin Template 2. Esthetic

ActiveMQ管理后台以及消费者密码设置

1.管理后台密码 (1)ActiveMQ使用的是jetty服务器打开apache-activemq-5.8.0\conf\jetty.xml 找到 <pre name="code" class="html"> <bean id="securityConstraint" class="org.eclipse.jetty.util.security.Constraint"> <property nam

TOM企业邮箱发布新版管理后台,员工管理更高效!

据TOM企业邮箱官方透露,期待已久的企业邮箱管理后台6.0 版本正式与大家见面. 管理后台新版围绕以企业管理员三步实现成员管理.一步找到功能入口为宗旨,进行了极简式快速办公的改版方法.用户交互方面,均经过反复内测,真正严把用户体验.功能方面全新升级邮箱搬家.邮件群组.移动办公.企业个性化管理等,将以华丽的新貌盛装呈现!同时将不断更新更多功能与大家见面 成员管理快速创建,一键群发邮件通知企业新同事入职及管理员管理,新增多个快捷入口,全流程操作引导,有效提升专业管理员的工作效率,解决新手管理员的使用

微信小程序管理后台介绍

微信小程序的管理后台,每次进入都需要扫码,还是特别不爽,现在微信小程序还没正式发布,很多人都还没看到管理后台,这里抢先发布出来 ------------------------------------------------------------ http://www.cnblogs.com/likwo/p/6057258.html 好推小程序统计:https://weixin.hotapp.cn关键指标分析推广效果,一行代码接入微信登录 ---------------------------

学生成绩管理后台第二项任务:初步建模,搭建一个简单的网站

负责人:程琳茹 合伙人:李玉婷 签约员工:闫玉荣 前言:学生成绩管理后台,看起来是一个简单的项目,但是对于我们今后的发展很重要,建设一个管理后台有很多方法,这里我们主要使用Rstudio,在之后的文章中,会详细给出我们小组完成项目的过程与遇到的问题,欢迎大家借鉴,此外,同学们要积极参与讨论. 项目步骤:1.熟悉与安装Rstudio,并且配置好R内部环境. 2.建立好文件所存放的位置与确保文档可以正常使用. 3.搭建一个简单的网站,分别分为server.R端口与ui.R端口. 4.搭建好网站后,插

Python-S13作业-day4-之登陆,管理后台

Python-S13作业-day4-之登陆,管理后台 需求: 本节作业,用户管理程序:          普通用户: 登录,注册,修改密码,查看本用户信息 管理员用户: 查看所有普通用户,按照指定关键字搜索用户信息: 登录,注册,修改密码,查看本用户信息:                       删除.添加普通用户                       修改普通用户密码 提高普通用户权限 注意: 1.用户信息:要存文件里         2.权限验证,要用装饰器 思路: Readme:

【转】Solr安全设置——对外禁用管理后台

本文转自:http://www.devnote.cn/article/94.html 测试于:Solr 4.5.1, Jdk 1.6.0_45, Tomcat 6.0.37 | CentOS 5.7 Solr管理后台功能可谓强大,但是真正线上,如果管理后台地址可以公开访问的话,不但core的结构会暴漏出来,索引库甚至可以被修改或删除. 推荐的做法是,在apache或其他服务器上做设置,平时禁用对外的访问地址,项目访问solr的内网地址(如:http://localhost:8080/solr/c