CN109213496A - 一种部署OpenStack的实现方法及系统 - Google Patents

一种部署OpenStack的实现方法及系统 Download PDF

Info

Publication number
CN109213496A
CN109213496A CN201810993605.3A CN201810993605A CN109213496A CN 109213496 A CN109213496 A CN 109213496A CN 201810993605 A CN201810993605 A CN 201810993605A CN 109213496 A CN109213496 A CN 109213496A
Authority
CN
China
Prior art keywords
ansible
web page
output information
openstack
server
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Pending
Application number
CN201810993605.3A
Other languages
English (en)
Inventor
荣耀祖
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Zhengzhou Yunhai Information Technology Co Ltd
Original Assignee
Zhengzhou Yunhai Information Technology Co Ltd
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Zhengzhou Yunhai Information Technology Co Ltd filed Critical Zhengzhou Yunhai Information Technology Co Ltd
Priority to CN201810993605.3A priority Critical patent/CN109213496A/zh
Publication of CN109213496A publication Critical patent/CN109213496A/zh
Pending legal-status Critical Current

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/60Software deployment

Landscapes

  • Engineering & Computer Science (AREA)
  • Software Systems (AREA)
  • General Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)

Abstract

本发明实施例公开了一种部署OpenStack的实现方法及系统,其中,所述方法包括:通过web页面发送ansible部署命令至服务器以部署OpenStack组件;获取所述服务器执行所述ansible部署命令得到的输出信息;缓存所述输出信息到Redis数据库,并通过所述web页面展示所述输出信息。通过本发明实施例,为OpenStack的部署提供了便利,针对测试以及运维人员去搭建一套OpenStack集群,只需要在web页面前端输入命令就可以在web页面看到部署信息,提高产品的易用性和便利性。

Description

一种部署OpenStack的实现方法及系统
技术领域
本发明涉及计算机技术领域,尤指一种部署OpenStack的实现方法及系统。
背景技术
OpenStack是一个由NASA(National Aeronautics and Space Administration,美国国家航空航天局)和Rackspace合作研发并发起的,以Apache许可证授权的自由软件和开放源代码项目,OpenStack是一个开源的云计算管理平台项目,由几个主要的组件组合起来完成具体工作。OpenStack支持几乎所有类型的云环境,项目目标是提供实施简单、可大规模扩展、丰富、标准统一的云计算管理平台。OpenStack通过各种互补的服务提供了基础设施即服务(IaaS)的解决方案,每个服务提供API(Application Programming Interface,应用程序编程接口)以进行集成。
OpenStack包含两个主要模块:Nova和Swift,前者是NASA开发的虚拟服务器部署和业务计算模块;后者是Rackspace开发的分布式云存储模块,两者可以一起用,也可以分开单独使用。
传统的OpenStack部署和运维方式偏命令行化,部署OpenStack和后期运维查看日志等都只能使用命令行的方式操作,这样就对一些不太熟悉OpenStack的用户不很友好。
发明内容
为了解决上述技术问题,本发明提供了一种部署OpenStack的实现方法及系统,能够通过web(World Wide Web,全球广域网)页面部署OpenStack。
为了达到本发明目的,本发明实施例提供了一种部署OpenStack的实现方法,基于Django web框架,包括:
通过web页面发送ansible部署命令至服务器以部署OpenStack组件;
获取所述服务器执行所述ansible部署命令得到的输出信息;
缓存所述输出信息到Redis数据库,并通过所述web页面展示所述输出信息。
可选地,所述通过web页面发送ansible部署命令至服务器以部署OpenStack组件,包括:
通过web页面获取所述ansible部署命令,将所述ansible部署命令以参数的方式通过ansible的playbook_executor接口和run接口传递至所述服务器。
可选地,所述获取所述服务器执行所述ansible部署命令得到的输出信息,包括:
调用ansible.utils.display.Display接口,获取所述输出信息。
可选地,所述通过所述web页面展示所述输出信息,包括:
通过Django的管道将所述输出信息同步至所述web页面。
可选地,所述方法还包括:
基于paramiko封装,通过所述web页面对部署所述OpenStack组件的服务器和所述OpenStack组件的服务进行监控。
本发明实施例还提供一种部署OpenStack的实现系统,基于Django web框架,包括:
发送模块,用于通过web页面发送ansible部署命令至服务器以部署OpenStack组件;
获取模块,用于获取所述服务器执行所述ansible部署命令得到的输出信息;
缓存输出模块,用于缓存所述输出信息到Redis数据库,并通过所述web页面展示所述输出信息。
可选地,所述发送模块,用于通过web页面获取所述ansible部署命令,将所述ansible部署命令以参数的方式通过ansible的playbook_executor接口和run接口传递至所述服务器。
可选地,所述获取模块,用于调用ansible.utils.display.Display接口,获取所述输出信息。
可选地,所述输出模块,用于通过Django的管道将所述输出信息同步至所述web页面。
可选地,所述系统还包括:
监控模块,用于基于paramiko封装,通过所述web页面对部署所述OpenStack组件的服务器和所述OpenStack组件的服务进行监控。
与现有技术相比,本发明实施例基于Django web框架,包括:通过web页面发送ansible部署命令至服务器以部署OpenStack组件;获取所述服务器执行所述ansible部署命令得到的输出信息;缓存所述输出信息到Redis数据库,并通过所述web页面展示所述输出信息。通过本发明实施例,为OpenStack的部署提供了便利,针对测试以及运维人员去搭建一套OpenStack集群,只需要在web页面前端输入命令就可以在web页面看到部署信息,提高产品的易用性和便利性。
本发明的其它特征和优点将在随后的说明书中阐述,并且,部分地从说明书中变得显而易见,或者通过实施本发明而了解。本发明的目的和其他优点可通过在说明书、权利要求书以及附图中所特别指出的结构来实现和获得。
附图说明
附图用来提供对本发明技术方案的进一步理解,并且构成说明书的一部分,与本申请的实施例一起用于解释本发明的技术方案,并不构成对本发明技术方案的限制。
图1为本发明实施例的部署OpenStack的实现方法的流程图;
图2为本发明实施例的部署OpenStack的实现系统的组成示意图。
具体实施方式
为使本发明的目的、技术方案和优点更加清楚明白,下文中将结合附图对本发明的实施例进行详细说明。需要说明的是,在不冲突的情况下,本申请中的实施例及实施例中的特征可以相互任意组合。
在附图的流程图示出的步骤可以在诸如一组计算机可执行指令的计算机系统中执行。并且,虽然在流程图中示出了逻辑顺序,但是在某些情况下,可以以不同于此处的顺序执行所示出或描述的步骤。
Django是一个开放源代码的Web应用框架,由Python语言编写而成。采用了MVC的框架模式,即模型M,视图V和控制器C。它最初是被开发来用于管理劳伦斯出版集团旗下的一些以新闻内容为主的网站的,即是CMS(Content Management System,内容管理系统)软件。并于2005年7月在BSD(Berkeley Software Distribution,伯克利软件套件)许可证下发布。
本发明实施例中,基于Django开发OpenStack部署和运维,利用Django整合了ORM(Oriented Relational Mapping,对象映射关系)的良好特性,使用Django的管道技术,结合Redis缓存数据库和本地MySQL数据库,安全方面使用基于SSHv2协议的Paramiko开发工具,这是基于Python语言开发的用于SSH登录的第三方工具包,方便对OpenStack中所有的机器进行免密配置和免密登录。OpenStack部署方面,使用基于kolla-ansible和docker技术的部署方式,kolla-ansible,是基于一种使用Python开发ansible运维编排工具,能够实现任务分发,角色指定等,能够很方便的将OpenStack不同功能的组件部署到相应的机器上。Docker是一个开源的应用容器引擎,基于Go语言,并遵从Apache2.0协议开源。Docker可以让开发者打包他们的应用以及依赖包到一个轻量级、可移植的容器中,然后发布到任何流行的Linux机器上,也可以实现虚拟化。Kolla就是将OpenStack所有组件以docker镜像的方式打包,kolla-ansible对镜像进行拉取并安装。
Django的特点是APP解耦,可以灵活的创建APP并实现热插拔。在本发明实施例中,结合kolla-ansible的部署方式,实现基于Django的OpenStack页面部署。
如图1所示,本发明实施例的部署OpenStack的实现方法,基于Django web框架,包括:
步骤101,通过web页面发送ansible部署命令至服务器以部署OpenStack组件。
本步骤中,实现在页面前端发送ansible部署命令。
在一实施例中,通过web页面获取所述ansible部署命令,将所述ansible部署命令以参数的方式通过ansible的playbook_executor接口和run接口传递至所述服务器。
这里对ansible源码进行了改装引用,使用了ansible的playbook_executor接口和run接口,从前端获取指令,将指令以参数的形式传递给上述两个接口就可以实现前端执行playbook(Ansible的任务配置文件)。
步骤102,获取所述服务器执行所述ansible部署命令得到的输出信息。
本步骤中,实现将输出信息重定向到前端页面。
在一实施例中,调用ansible.utils.display.Display接口,获取所述输出信息。
这里也是对ansible的源码进行了重新封装使用,调用ansible.utils.display.Display()接口,获取ansible执行的输出信息。
步骤103,缓存所述输出信息到Redis数据库,并通过所述web页面展示所述输出信息。
本步骤中,实现缓存页面输出信息及展示输出。
在一实施例中,通过Django的管道(channels)将所述输出信息同步至所述web页面。
这里使用Django的channels技术,channels是基于websocket通信技术,这样就可以将输出信息同步动态输出到前端页面。
另外,本发明实施例还可以查看docker镜像运行信息,是否是正常运行状态。
在一实施例中,所述方法还包括:
基于paramiko封装,通过所述web页面对部署所述OpenStack组件的服务器和所述OpenStack组件的服务进行监控。
部署完成后,可以使用基于paramiko封装的方式,对集群中服务器以及服务器中OpenStack的服务进行监控,可以采用定期发送心跳包的方式进行监控。
通过本发明实施例,为OpenStack的部署提供了便利,针对测试以及运维人员去搭建一套OpenStack集群,只需要在web页面前端输入命令就可以在web页面看到部署信息,提高产品的易用性和便利性。
如图2所示,本发明实施例的部署OpenStack的实现系统,基于Django web框架,包括:
发送模块21,用于通过web页面发送ansible部署命令至服务器以部署OpenStack组件;
获取模块22,用于获取所述服务器执行所述ansible部署命令得到的输出信息;
缓存输出模块23,用于缓存所述输出信息到Redis数据库,并通过所述web页面展示所述输出信息。
通过本发明实施例,为OpenStack的部署提供了便利,针对测试以及运维人员去搭建一套OpenStack集群,只需要在web页面前端输入命令就可以在web页面看到部署信息,提高产品的易用性和便利性。
在一实施例中,所述发送模块21,用于通过web页面获取所述ansible部署命令,将所述ansible部署命令以参数的方式通过ansible的playbook_executor接口和run接口传递至所述服务器。
在一实施例中,所述获取模块22,用于调用ansible.utils.display.Display接口,获取所述输出信息。
在一实施例中,所述缓存输出模块23,用于通过Django的管道将所述输出信息同步至所述web页面。
在一实施例中,所述系统还包括:
监控模块,用于基于paramiko封装,通过所述web页面对部署所述OpenStack组件的服务器和所述OpenStack组件的服务进行监控。
本发明实施例中,可以将Django应用在OpenStack的部署和运维上,可以很方便的从web界面查看OpenStack系统的部署情况和运行情况。
本发明实施例还提出一种部署OpenStack的实现设备,包括存储器、处理器及存储在存储器上并可在处理器上运行的计算机程序,所述处理器执行所述程序时实现上述部署OpenStack的实现方法。
本发明实施例还提出一种计算机可读存储介质,存储有计算机可执行指令,所述计算机可执行指令被处理器执行时实现上述部署OpenStack的实现方法。
综上所述,本发明实施例针对ansible的重新封装和对django channels技术与Redis结合方式的创新,实现了输出信息动态刷新和页面缓存以及动态监控OpenStack部署状态和运行状态信息。
本领域普通技术人员可以理解,上文中所公开方法中的全部或某些步骤、系统、装置中的功能模块/单元可以被实施为软件、固件、硬件及其适当的组合。在硬件实施方式中,在以上描述中提及的功能模块/单元之间的划分不一定对应于物理组件的划分;例如,一个物理组件可以具有多个功能,或者一个功能或步骤可以由若干物理组件合作执行。某些组件或所有组件可以被实施为由处理器,如数字信号处理器或微处理器执行的软件,或者被实施为硬件,或者被实施为集成电路,如专用集成电路。这样的软件可以分布在计算机可读介质上,计算机可读介质可以包括计算机存储介质(或非暂时性介质)和通信介质(或暂时性介质)。如本领域普通技术人员公知的,术语计算机存储介质包括在用于存储信息(诸如计算机可读指令、数据结构、程序模块或其他数据)的任何方法或技术中实施的易失性和非易失性、可移除和不可移除介质。计算机存储介质包括但不限于RAM、ROM、EEPROM、闪存或其他存储器技术、CD-ROM、数字多功能盘(DVD)或其他光盘存储、磁盒、磁带、磁盘存储或其他磁存储装置、或者可以用于存储期望的信息并且可以被计算机访问的任何其他的介质。此外,本领域普通技术人员公知的是,通信介质通常包含计算机可读指令、数据结构、程序模块或者诸如载波或其他传输机制之类的调制数据信号中的其他数据,并且可包括任何信息递送介质。

Claims (10)

1.一种部署OpenStack的实现方法,其特征在于,基于Django web框架,包括:
通过web页面发送ansible部署命令至服务器以部署OpenStack组件;
获取所述服务器执行所述ansible部署命令得到的输出信息;
缓存所述输出信息到Redis数据库,并通过所述web页面展示所述输出信息。
2.根据权利要求1所述的方法,其特征在于,所述通过web页面发送ansible部署命令至服务器以部署OpenStack组件,包括:
通过web页面获取所述ansible部署命令,将所述ansible部署命令以参数的方式通过ansible的playbook_executor接口和run接口传递至所述服务器。
3.根据权利要求1所述的方法,其特征在于,所述获取所述服务器执行所述ansible部署命令得到的输出信息,包括:
调用ansible.utils.display.Display接口,获取所述输出信息。
4.根据权利要求1所述的方法,其特征在于,所述通过所述web页面展示所述输出信息,包括:
通过Django的管道将所述输出信息同步至所述web页面。
5.根据权利要求1~4中任意一项所述的方法,其特征在于,所述方法还包括:
基于paramiko封装,通过所述web页面对部署所述OpenStack组件的服务器和所述OpenStack组件的服务进行监控。
6.一种部署OpenStack的实现系统,其特征在于,基于Django web框架,包括:
发送模块,用于通过web页面发送ansible部署命令至服务器以部署OpenStack组件;
获取模块,用于获取所述服务器执行所述ansible部署命令得到的输出信息;
缓存输出模块,用于缓存所述输出信息到Redis数据库,并通过所述web页面展示所述输出信息。
7.根据权利要求6所述的系统,其特征在于,
所述发送模块,用于通过web页面获取所述ansible部署命令,将所述ansible部署命令以参数的方式通过ansible的playbook_executor接口和run接口传递至所述服务器。
8.根据权利要求6所述的系统,其特征在于,
所述获取模块,用于调用ansible.utils.display.Display接口,获取所述输出信息。
9.根据权利要求6所述的系统,其特征在于,
所述输出模块,用于通过Django的管道将所述输出信息同步至所述web页面。
10.根据权利要求6~9中任意一项所述的系统,其特征在于,还包括:
监控模块,用于基于paramiko封装,通过所述web页面对部署所述OpenStack组件的服务器和所述OpenStack组件的服务进行监控。
CN201810993605.3A 2018-08-29 2018-08-29 一种部署OpenStack的实现方法及系统 Pending CN109213496A (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201810993605.3A CN109213496A (zh) 2018-08-29 2018-08-29 一种部署OpenStack的实现方法及系统

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201810993605.3A CN109213496A (zh) 2018-08-29 2018-08-29 一种部署OpenStack的实现方法及系统

Publications (1)

Publication Number Publication Date
CN109213496A true CN109213496A (zh) 2019-01-15

Family

ID=64985574

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201810993605.3A Pending CN109213496A (zh) 2018-08-29 2018-08-29 一种部署OpenStack的实现方法及系统

Country Status (1)

Country Link
CN (1) CN109213496A (zh)

Cited By (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN110430084A (zh) * 2019-08-20 2019-11-08 济南浪潮数据技术有限公司 节点状态监控方法及装置
CN110661868A (zh) * 2019-09-25 2020-01-07 浙江九州云信息科技有限公司 一种可拓展的可视化应用部署的解决方法
CN111669284A (zh) * 2020-04-28 2020-09-15 长沙证通云计算有限公司 OpenStack自动化部署方法、电子设备、存储介质及系统
CN111885201A (zh) * 2020-07-31 2020-11-03 中国工商银行股份有限公司 数据传输方法、装置、设备及介质
CN112711428A (zh) * 2021-01-18 2021-04-27 浪潮云信息技术股份公司 一种基于ansible的动态部署方法及系统
CN114968214A (zh) * 2022-07-12 2022-08-30 云账户技术(天津)有限公司 代码自动生成方法、装置、存储介质及终端设备

Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN104536899A (zh) * 2015-01-20 2015-04-22 成都益联科创科技有限公司 一种基于智能集群的软件部署及其维护方法
CN105242913A (zh) * 2015-07-06 2016-01-13 临沂优狐网络科技有限公司 Yyuc-php框架

Patent Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN104536899A (zh) * 2015-01-20 2015-04-22 成都益联科创科技有限公司 一种基于智能集群的软件部署及其维护方法
CN105242913A (zh) * 2015-07-06 2016-01-13 临沂优狐网络科技有限公司 Yyuc-php框架

Non-Patent Citations (2)

* Cited by examiner, † Cited by third party
Title
王彬: "基于OpenStack的云平台管理系统的设计与实现", 《中国优秀硕士学位论文全文数据库信息科技辑》 *
邱晨等: "基于容器化OpenStack云平台及Ceph存储的私有云实施案例", 《邮电设计技术》 *

Cited By (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN110430084A (zh) * 2019-08-20 2019-11-08 济南浪潮数据技术有限公司 节点状态监控方法及装置
CN110661868A (zh) * 2019-09-25 2020-01-07 浙江九州云信息科技有限公司 一种可拓展的可视化应用部署的解决方法
CN111669284A (zh) * 2020-04-28 2020-09-15 长沙证通云计算有限公司 OpenStack自动化部署方法、电子设备、存储介质及系统
CN111885201A (zh) * 2020-07-31 2020-11-03 中国工商银行股份有限公司 数据传输方法、装置、设备及介质
CN111885201B (zh) * 2020-07-31 2022-11-08 中国工商银行股份有限公司 数据传输方法、装置、设备及介质
CN112711428A (zh) * 2021-01-18 2021-04-27 浪潮云信息技术股份公司 一种基于ansible的动态部署方法及系统
CN112711428B (zh) * 2021-01-18 2024-04-12 浪潮云信息技术股份公司 一种基于ansible的动态部署方法及系统
CN114968214A (zh) * 2022-07-12 2022-08-30 云账户技术(天津)有限公司 代码自动生成方法、装置、存储介质及终端设备

Similar Documents

Publication Publication Date Title
CN109213496A (zh) 一种部署OpenStack的实现方法及系统
WO2021051914A1 (zh) 基于gpu资源的数据处理方法、电子设备及系统
US10545749B2 (en) System for cloud computing using web components
EP3951595A1 (en) Method and apparatus for graphics rendering
CN112069265B (zh) 配置数据的同步方法、业务数据系统、计算机系统和介质
US7992132B2 (en) Server side application integration framework
CN102968331B (zh) 一种虚拟机管理系统及其文件访问方法
CN103338135B (zh) 一种集群存储容量的实时监控方法
US20110246988A1 (en) Hypervisor for starting a virtual machine
CN104376127B (zh) 一种数据操作方法及装置
US20170262221A1 (en) Methods and apparatuses for data migration of a storage device
CN106850332A (zh) 基于云的应用动态监控方法及系统
US20140279899A1 (en) Data bus architecture for inter-database data distribution
US11093694B2 (en) Multi-stage data page rendering
JP6692000B2 (ja) リスク識別方法、リスク識別装置、クラウドリスク識別装置及びシステム
CN111966748B (zh) 分布式空基仿真运行控制管理方法
US10360188B2 (en) Dynamic property data integration framework
US20180102950A1 (en) Integration of cloud services for consumption in cloud applications
CN105391652A (zh) 基于usb重定向实现usb设备网络共享的系统及方法
US20170083387A1 (en) High-performance computing framework for cloud computing environments
CN114691050B (zh) 基于kubernetes的云原生存储方法、装置、设备及介质
CN109697114A (zh) 用于应用迁移的方法和机器
CN104092747B (zh) 虚拟化环境下usb动态连接方法及装置
US20130125093A1 (en) Generating object-oriented programming language code from a multi-domain dynamic simulation model
US10733689B2 (en) Data processing

Legal Events

Date Code Title Description
PB01 Publication
PB01 Publication
SE01 Entry into force of request for substantive examination
SE01 Entry into force of request for substantive examination
RJ01 Rejection of invention patent application after publication

Application publication date: 20190115

RJ01 Rejection of invention patent application after publication