可以使用的语言有java,c等云技术的开发,并没有发展什么新语言,而是在其他语言的基础上。比如Java语言。与其他技术,最显著的区别,不是在开发上,而是在于架构上,最显著的特点是分布式。
1、Hadoop
Hadoop是一个框架,它是由Java语言来实现的。Hadoop是处理大数据技术Hadoop可以处理云计算产生大数据,需要区分hadoop并不是云计算。它和云计算密不可分。详细见下面内容。
(1)Hadoop是如何产生的
Hadoop产生是互联网的产物,也是必然。大家都知道,我们上网时需要服务器的。假如世界上只有一台电脑,根本不需要服务器。如果有10台服务器,100台,1000台,上万台,那么我们该如何让大家相互通信,共享知识,所以我们产生了互联网。
互联网产生,全世界都可以通信,知识如此居多,我们像获取更多的知识,想获取新技术,获取新知识,通过什么,国内通过百度,国外也有许多,比如Google。可是百度和谷歌的用户有多少,多了不说,最起码有上亿的用户。并且这些用户每天上百度,上谷歌,又会产生多少数据,查询多少数据。那么他们怎么承受如此多用户。这不是一台电脑、一台服务器能完成的事情。
2、openstack
openstack是搭建云平台技术,可以搭建公有云,私有云,和混合云。
OpenStack是开源的云管理平台,用来统一管理多个虚拟化集群的框架。
openstack目前分为两种
(1)openstack的运维
(2)openstack的二次开发
目前来讲,国内真正对openstack二次开发的很少,这方面的人才也是比较稀缺,网上资料也比较少,淘宝上资料也稀缺,只有很少一部分。建议向高工资的朋友,可以从这方面下点功夫。
3CloudFoundry
CloudFoundry是一个开源的平台即服务产品,它提供给开发者自由度去选择云平台,开发框架和应用服务。CloudFoundry最初由VMware发起,得到了业界广泛的支持,它使得开发者能够更快更容易的开发,测试,部署和扩展应用。CloudFoundry是一个开源项目,用户可以使用多种私有云发行版,也可以使用公共云服务。
还有nosql即notonlysql。
nosql数据库是一种比较低级的数据库,关系型数据库是由nosql数据库发展而来。
什么是关系型数据库,这里不从概念上区别,常用的SqlServer,mysql,oracle都是关系型数据库。关系型数据库顾名思义,数据库关系明确严谨。
而nosql则是一种数据关系不严谨的数据库。一个key和value。
你可以看看下面参数,详细可查看CloudStack及其和OpenStack的比较整体比较 比较项 CloudStackOpenStack服务层次IaaSIaaS授权协议Apache 20Apache 20许可证不需要不需要动态资源调配主机Maintainance模式下自动迁移VM无现成功能,需通过Nova-scheduler组件自己实现VM模板支持支持VM Console支持支持开发语言JavaPython用户界面Web Console,功能较完善DashBoard,较简单负载均衡软件负载均衡(Virtual Router)、硬件负载均衡软件负载均衡(Nova-network或 OpenStack Load Balance API)、硬件负载均衡虚拟化技术XenServer,Oracle VM,vCenter,KVM,Bare MetalXenServer,Oracle VM,KVM,QEMU,ESX/ESXi,LXC(Liunx Container)等最小化部署一管理节点,一主机节点支持All in one(Nova,Keystone,Glance组件必选)支持数据库MySQLPostgreSQL,MySQL,SQLite组件Console Proxy VM,Second Storage VM,Virtual Router VM,Host Agent,Management ServerNova,Glance,Keystone,Horizon,Swift网络形式Isolation(VLAN),ShareVLAN,FLAT,FLATDhcp版本问题版本发布稳定,不存在兼容性问题存在各版本兼容性问题VLAN不能VLAN间互访支持VLAN间互访
OpenStack和CloudStack的对比
1)历史背景和概况
OpenStack由NASA和Rackspace公司在2010年联合发布,两者分别贡献计算代码(Nova)和存储代码(Swift),以Apache许可协议进行授权。OpenStack的目标是提供一个既可以用来建设公有云也能建设私有云的通用的开源云计算平台,而且做到云平台的搭建尽量的简单方便,同时能够快速的横向扩展。OpenStack独立于任何企业,遵循开源、开放设计、开放开发流程和开放社区的理念,完全由社区主导和维护。OpenStack的发布周期是半年,到目前为止已经发布8个正式版本,最新的版本是Havana,在每个版本发布之后社区都会举行一次峰会,来自世界各地的公司和开发者一起讨论下一个版本的设计,同时进行OpenStack相关的技术分享,值得一提的是,最近的一次峰会在中国的香港举行。
CloudStack最初由Cloudcom公司开发,分为商业和开源两个版本,开源版本通过GPLv3(GNU General Public License, version 3)许可协议进行授权,Citrix公司在2011年收购Cloudcom后,将全部代码开源,并在2012年将CloudStack贡献给Apache软件基金会,成为Apache的孵化项目,同时将授权协议改为更加宽松开放和商业友好的Apache许可协议,CloudStack在2013年3月份升级为Apache的正式项目。CloudStack的目标是提供高度可用的、高度可扩展的能够进行大规模虚拟机部署和管理的开放云平台。CloudStack的发布周期并不固定,目前最新的版本是42,社区每年会举行一次全球协作会议(CloudStack Collaboration Conference)进行技术分享和交流。
2)平台架构
OpenStack采用分布式架构,整个平台按照功能不同分为多个模块项目,如图2所示,项目之间通过消息队列中间件和RESTful形式的API进行交互通信(其中认证项目为其它项目提供认证和服务注册),因此每个项目都可以单独部署在不同的主机上,架构非常的灵活,OpenStack对外提供丰富和功能强大的API,使得资源可以被用户方便的使用和调度,同时提供和Amazon AWS(Amazon Web Services)兼容的API。
图2、OpenStack分布式架构图
CloudStack采用集中式的单体架构(Monolithic architecture),如图3所示,整个平台只有一个项目构成,不同模块之间通过的本地调用进行交互,在一台主机上就可以完成平台的部署,非常方便,CloudStack同样地对外提供自身API和与Amazon AWS相兼容的API。
图3、CloudStack集中式架构图
可以看到两者的架构几乎是相对的,OpenStack的分布式架构灵活性好,不同的项目可以单独部署,因此可以很容易的根据实际需要进行功能组合,并且由于不同的项目间耦合性低,项目间功能划分明确,因此针对单独功能进行定制开发也非常方便,缺点是部署麻烦,每个项目都要部署配置一遍;CloudStack因为只有一个项目,所以部署起来会相对容易很多,然而平台的扩展性就要相对弱一些。
3)平台整体比较
OpenStack和CloudStack的功能对比如表1所示,我们从授权协议、支持的底层技术和用户群等不同方面对两者进行了比较。
OpenStack
CloudStack
授权协议
Apache 20,可以免费商用
Apache 20,可以免费商用
虚拟化技术
XenServer/XCP,KVM,QEMU,
LXC,VMware ESXi/vCenter,Hyper-V Baremetal,Docker,Xen/Libvirt
XenServer,KVM,QEMU,
VMware vCenter ,LXC
网络服务
VLAN,Flat,FlatDHCP
Quantum虚拟化网络
VLAN,Flat,OpenFlow
存储支持
iSCSI,Ceph,NFS,LVM,Swift,Sheepdog
NFS,LVM,Ceph,Swift
调度策略
模型全面,易扩展
模型简单,可扩展
用户界面
功能完善,界面简单
功能完善,界面友好
数据库
PostgreSQL,MySQL,SQLite
MySQL
虚拟机模板
支持
支持
组件
Nova,Glance,Keystone,
Horizon,Swift,Cinder,
Quantum,Heat,Ceilometer
Console Proxy VM,
Second Storage VM,
Virtual Router VM,
Host Agent,Management Server
开发主导
开源社区
Citrix公司
开发语言
Python
Java
官方文档
非常详细
详细
版本问题
存在版本兼容性问题
不存在版本兼容性问题
用户群
160家左右,包括NASA、
RedHat、Rackspace、HP、
网易、UnitedStack等
不到60家,包括诺基亚、
日本电话电报公司、Zynga、
阿尔卡特、迪斯尼等
表1、OpenStack与CloudStack 比较
4)平台选择
经过前面的比较分析我们能够获得这样的结论,OpenStack和CloudStack都是功能强大的开源云平台,满足企业私有云建设的需求,并且因为开放开源,都可以根据需要进行定制。不同的是CloudStack因为是从商业软件开源出来的,所以对企业来说会更容易上手,在云平台构建时会比较方便,然而同样因为其带有商业软件属性,平台架构比较集中,模块间耦合度比较高,因此扩展性不是太好,同时二次开发的成本较高;OpenStack自诞生之初就是开源软件,并采用分布式的架构,所有的开发都是由社区承担,不同的项目之间几乎没有耦合,所以可以方便的进行开发定制,然而因为其有多个项目组成,每个项目都要单独安装,并且要保证项目间的协作,所以部署会比较麻烦,另外由于OpenStack处于高速发展阶段,不同版本之间项目可能会有较大的变动,因此版本间的升级会比较困难。
另外值得一提的是,OpenStack和CloudStack虽然都对VMware的ESXi虚拟化技术提供支持,但支持方式是不一样的,如图4所示。CloudStack要经过vCenter才可以实现对ESXi宿主机上虚拟机的管理;而OpenStack支持直接和ESXi通信,实现对虚拟机的基本管理,只有高级功能才需要vCenter的支持。针对目前中小企业普遍采用VMware的免费虚拟化技术而没有vCenter的现状,这也是在平台选择时需要考虑的。
图4、VMware ESXi管理方式对比图
恒天云采用OpenStack开源平台进行私有云建设,因为OpenStack架构非常开放,方便定制开发,并且拥有众多技术厂商的支持,非常有可能成为云计算IaaS平台领域的Linux,所以通过对OpenStack定制开发,积累云计算的技术能力,从长远来看对企业也是非常有益的。
以上就是关于云计算 *** 作系统一般是用什么语言开发的全部的内容,包括:云计算 *** 作系统一般是用什么语言开发的、虚拟化管理平台OpenStack和CloudStack的优缺点、openstack cloudstack 选哪个等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)