OpenStack已死?恐怕你想多了 | 技术头条

戳蓝字“CSDN云计算”关注我们哦!


640?wx_fmt=jpeg

技术头条:干货、简洁、多维全面。更多云计算精华知识尽在眼前,get要点、solve难题,统统不在话下!


译者:Lorraine Lo


在接受不同采访时我经常会被问到这么一个问题:OpenStack到底发生了什么?就像人们认为OpenStack已经死了一样。而每次面对这个问题,我都会在回答之前做出害羞无辜的表情。这里我要给大家一个提示:OpenStack并没有死,只是经历了风雨。

 

这个项目目前运作仍十分健康,依旧遵循发展曲线推进:OpenStack发展至今已足够成熟,这一点已经不足以引起人们的兴趣来引发讨论了,所以大家随之在想OpenStack是不是发生了什么,这种情况是可以理解的。

 

问我这个问题的人通常好奇又善意,我认为我的回答跟我的专业背景有很大的关系,所以即使是在采访时,我会偏向于采用闲聊的方式。我决定今天重新讨论这个话题。下次要是再有人问同样问题,我就会让他来读一读这篇文章。

 

要知道,为了实现生态系统长期持久的成功,我们需要一个超规模的OpenStack公有云,还需要在我们已有的Iaas/Paas层上构建一套健康的SaaS应用程序,除此之外,我们还需要在多个hyperscale来避免引力问题(在早期,这就是RackSpace)。

 

640?wx_fmt=jpeg


很多人都在公开场合谈论到的一点是,常见的头条新闻将OpenStack与AWS进行比较,每个风险投资机构和分析师都想知道OpenStack是否已经为企业提供服务做好了准备。我甚至还曾在一个小组讨论里探讨过这个问题!(网上有链接记录,但我不会在这里分享,因为我不想回忆当年自己的形象)但随着时间的推移,我们成功的关键部分从未实现。为什么会这样呢?

 

早在2014年时,我在惠普云工作,那时候资金正源源不断地流入OpenStack,我们也正为此得意洋洋,那是OpenStack发展达到顶峰的一年,巴黎峰会上嘉年华的场景对于现在的我来说依然记忆犹新。这一现象实则出于电信公司和硬件供应商试图影响OpenStack方向的原因,但对于局外人却是雾里看花。更具体地来说,这些公司希望为他们能够迅速上市的集成私有云解决方案创造技术基础。

 

而在私底下,我们可以看到,这些市场势力与hyperscale实际实现是背道而驰的。大帐篷项目(The Big Tent)是一个试图解决当中一些问题的大胆之举。我们(即技术委员会)使劲自己最大的力气,但最终还是无法解决这些问题,因为钱包控制权并不掌握在我们手中。

 

正如大家所看到的,当时几乎所有为OpenStack做出重大贡献的公司都依赖于企业客户,这其实是业内知名公司每年花费巨资在彼此合作的公司之上的另一种较为好听的说法。与hyper-scalers不同,企业客户通常对构建自己的服务器或编写自己的交换机固件并不感兴趣,他们会选择从这些产品服务提供商那里购买(以及给他们的支持合同),并且希望继续从这些交易中赚钱。

 

与此同时,发行商和运营商正努力实现OpenStack可安装,以便能够展开和维护部署来满足市场需求。而且企业对新的私有云领域的需求非常高。OpenStack开发团队面临(来自于发行商、电信公司、硬件供应商)巨大的内部压力,他们要在具有地理弹性的少部分地区大约的1000-10000个核心中创建企业客户所需并运行良好的软件。

 

640?wx_fmt=png


但是,为10000个和为10000000个核心构建分布式系统存在根本性的差异。除了要改变代码之外,增加三个数量级还需要对任何业务的运行方式进行根本性的改变。利润率会越来越小。第三方支持合同、B2B交易、增值软件这些被视为销售团队“车轮的润滑油”已经不复存在了。企业硬件和软件巨头不愿意重组那么多业务,而像OVH这样的公司其自然增长速度太慢了,尽管我认为他们仍然走在正确的轨道上。

 

创建一个可行的、开源的、超大规模的云软件解决方案与对OpenStack开发投资最多的公司的最大利益。

 

有一天,我以我一贯的方式试图在餐巾纸画出以下的图。原来的版本已经遗失很久了,所以我把它从下面的记忆中重新画出来。

 

影响来自错误的方向。电信公司、硬件供应商和发行商的产品管理(如ATT、思科、戴尔和红帽等)投入大量资金来施加影响力、雇佣程序员编写代码、为奢华派对提供资金并推高工资水平(毫不掩饰地说,我确实很喜欢这些派对活动,同时我的薪酬待遇也很好)。与此同时,运营商越来越落后于发布进程,几乎没有发声(毕竟他们正忙着云的运行),云的最终用户(应用程序开发人员)也几乎没有发声。

 

到最后,营收需要从云端上受支持业务的增长(即APP程序开发人员的成功)中获得,但我们却没能实现这个目标,因为运营商无法充分扩大规模,或无法保持和维护一个健康市场在云端上蓬勃发展所需的跨云兼容性。图表左侧的每个人都忙于寻找自己的差异性优势,从而无法促成彼此间的交易。

 

在这个情况下,作为可以看到问题所在的上游技术团队领导正向我们每个公司内部进行游说,希望能够改变优先事项。我们说服了一些管理者和执行者在代码和基础设施方面进行战术投资,但我们无法获得足够的支持来应对所需的更大变化。

 

只要金融影响者专注于中型客户(MSP和企业市场)的商业模式,对于让OpenStack在超大规模市场上具有竞争力所需的大量战略方面,他们并无投资意愿。因此,绝大多数开发人员在面对自己所属的项目目标由项目经理和他们雇主内部的管理人员决定时,都忙于将一切为利用“增值集成”所设计的特性(也就是企业销售周期中的润滑油)驱动到代码库中,没有人能够解决对于正忙于扩大云规模的部署人员来说很明显的核心问题。

 

成功的hyperscalers已经消除了中间件的边际成本。谷歌、AWS,甚至Facebook都在制造自己的服务器、交换机、存储设备等。他们提供开源项目,然后付钱给开发人员进行维护和私有云版本的改进,这样他们就可以保持领先,而一些项目现在正尝试阻止这一趋势。这些公司通过削减基础设施的成本来扩大规模,但这些效率驱动举措并没能让它们回到企业级市场中。他们在很大程度上成为了如今的巨头,通过构建流程、打造团队和搭建硬件来打破对第三方软件和硬件的依赖和支持。

 

所以你可以看到,创建一个可行的、开放源码的、超大规模的云软件解决方案是违背了对OpenStack开发投资最多的公司的最大利益的。

 

当你在看其他云产品的时候,思考下当下可能会对你最喜爱的代言人产生影响的的相似利益冲突(Kubernetes,我正在看着你呢)

 

对于我们中那些早早加入OpenStack并梦想成为大人物的人,我想说:好吧,我们没有机会在OpenStack中构建这些梦想了。OpenStack已经变成一种没有梦想光环但或许更实用的可扩展工具,用于中等规模的基础设施自动化,助力世界各地数千家企业,这包括许多非营利性和公益性机构。

 

而且,我想阐明的是,我很高兴能够通过采用我的方式帮助构建成了一个被广泛使用的工具。

 

我现在发表这篇文章,是希望它能对所有在Kubernetes.投资的人起到警示作用。你将永远无法像GKE那样以同样的规模并有效地运行它——除非你也一样在组织全面变革方面进行投资。

 

640?wx_fmt=jpeg


即便如此,如果你使用Kubernetes,你可能也不会成功,因为让其他人真正与GKE竞争是与谷歌的最大利益相悖的。

 

也许这也没关系。事实上,OpenStack+Kubernetes是对于你正在构建的合适的模式,而且这两个项目也不会在短期内实现无处不在的模式。

 

如果另一家公司想在hyperscale的空间中立于不败之地,它需要从整体上审视自身的业务机构,并重复Google/Facebook/Amazon的开放源代码私有化模式,把资金投资在自己的服务器制造中,或者与其他垂直聚焦的开放源代码企业联合才得以在市场上与对手竞争。

 

640?wx_fmt=png


福利

扫描添加小编微信,备注“姓名+公司职位”,加入【云计算学习交流群】,和志同道合的朋友们共同打卡学习!


640?wx_fmt=jpeg


推荐阅读:

  • 轻松了解面试官心理!ElasticSearch写入数据的工作原理是什么? | 技术头条

  • 专访图灵奖得主John Hopcroft:中国必须提升本科教育水平,才能在AI领域赶上美国

  • 程序员与程序媛的神仙爱情 | 程序员有话说

  • 他曾主导世界上第一台安卓智能机, 如今能否靠区块链手机找回昔日的光荣?|人物志

  • 移动开发或将被颠覆?

  • 如何将TensorFlow Serving的性能提高超过70%?


640?wx_fmt=png喜欢就点击“在看”吧

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/524268.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Windows 环境 Jenkins集成构建SonarQube

关于Windows搭建SonarQube_Mysql的相关操作先点击下面的链接,进行跳转。 操作手册: Windows搭建SonarQube_Mysql 启动Jenkins有2种方式: 第1种:java -jar jenkins.war :原理是用自身的netty启动第2种:把jenkins.war…

tcp的简单使用实例一

话不多说,直接上自己写的一个tcp小程序,分为客户端和服务端两个程序,实现了单一方向的数据传输。下面来看具体的代码: 先看客户端的程序。创建基于Qt Widgets Application 的应用程序,选择基类QDialog,修改类名为myCli…

英特尔强势上新一大波数据产品,小伙伴们“奔走相告”…… | 极客头条

戳蓝字“CSDN云计算”关注我们哦!技术头条:干货、简洁、多维全面。更多云计算精华知识尽在眼前,get要点、solve难题,统统不在话下!作者:刘晶晶近日,英特尔推出了一款创新产品组合,点…

Qt中Tcp通信的简单使用二

tcp编程中写的一个简单的单项传输数据的小例子&#xff0c;和上一节一样&#xff0c;分为客户端和服务端程序&#xff0c;下面看一下界面的效果。 创建的方法和之前一样&#xff0c;上面上代码&#xff1a; 客户端 Client.h #ifndef CLIENT_H #define CLIENT_H#include <…

atom插件安装方法

Search Atom packages 安装插件前提&#xff1a; 1、安装git 和node.js2、node官网&#xff1a;https://nodejs.org/en/3、下载稳定版 4、安装node.js 详细安装步骤&#xff1a; http://www.runoob.com/nodejs/nodejs-install-setup.html 5、插件搜索官网&#xff1a; https…

Docker精华问答:Docker与虚拟机的区别?| 技术头条

Docker 是个划时代的开源项目&#xff0c;它彻底释放了计算虚拟化的威力&#xff0c;极大提高了应用的维护效率&#xff0c;降低了云计算应用开发的成本&#xff01;使用 Docker&#xff0c;可以让应用的部署、测试和分发都变得前所未有的高效和轻松&#xff01;1Q&#xff1a;…

Qt下Tcp通信的简单使用三

和之前两个例子一样&#xff0c;程序比较简单&#xff0c;刚入门的可以看看&#xff0c;先上效果图。 下面是客户端&#xff1a; myClient.h #ifndef CLIENT_H #define CLIENT_H#include <QDialog>QT_BEGIN_NAMESPACE namespace Ui { class Client; } QT_END_NAMESPAC…

44年前的今天,改变世界的TA诞生了! | 极客头条

戳蓝字“CSDN云计算”关注我们哦&#xff01;极客头条&#xff1a;速递、最新、绝对有料。这里有企业新动、这里有业界要闻&#xff0c;打起十二分精神&#xff0c;紧跟fashion你可以的&#xff01;1975年4月4日&#xff0c;是历史上普通的一天。这一天&#xff0c;有两个人成立…

第二篇:Spring Boot 热部署

文章目录1. 依赖2. 开启实时自动编译3. 开启运行自动编译开关1. 依赖 <!-- 热部署DevTools --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-devtools</artifactId></dependency>2. 开启实时自…

Spring Boot 企业实战_前夕

Spring Boot 专栏设置意在实战微服务&#xff0c;依赖统一由父工程进行依赖控制&#xff0c;其他子项目均依赖此工程。 小技巧&#xff1a; Spring Boot 集成周边技术3部曲 1.pom文件引入maven依赖 2.配置文件中配置相关信息 3.启动类上加注解 创建Spring Boot 父工程&#xff…

西门子和阿里云要搞啥事情?| 极客头条

戳蓝字“CSDN云计算”关注我们哦&#xff01;极客头条&#xff1a;速递、最新、绝对有料。这里有企业新动、这里有业界要闻&#xff0c;打起十二分精神&#xff0c;紧跟fashion你可以的&#xff01;重 磅• 西门子MindShpere成功部署在阿里功云上并开始运营• 信守承诺、按期推…

Qt中UDP通信的简单示例

udp通信分为发送端和接收端&#xff0c;通信步骤可以分为以下&#xff1a; 接收端&#xff1a; 创建QUdpSocket对象。在.h文件中添加类的前置声明&#xff0c;定义该类的指针&#xff0c;在.cpp的构造函数中定义指向该类的指针。bind()。绑定IP和端口。connect()。绑定readyR…

FB接连出事儿?上亿用户记录在亚马逊云服务器上就公之于众了……下滑到第七?领英说苹果怎么就不受雇员欢迎了呢? | 极客头条...

戳蓝字“CSDN云计算”关注我们哦&#xff01;极客头条&#xff1a;速递、最新、绝对有料。这里有企业新动、这里有业界要闻&#xff0c;打起十二分精神&#xff0c;紧跟fashion你可以的&#xff01;每周三次&#xff0c;打卡即read更快、更全了解泛云圈精彩newsgo go go 销售火…

第三篇:Spring Boot整合Servlet

一、Springboot整合Servlet 第一种方案&#xff1a; 1、创建一个自定义的servlet&#xff0c;继承HttpServlet添加WebServlet注解 以前ssm中的web.xml配置文件中的servlet> <servlet><servlet-name>FirstServlet</servlet-name><servlet-class>c…

第四篇:Spring Boot 整合listener

一、Spring Boot整合listener 第一种方案&#xff1a;通过注解扫描完成Listener的注册 1.1 编写一个listener WebListener public class FirstListener implements ServletContextListener {Overridepublic void contextInitialized(ServletContextEvent sce) {System.out.pri…

2019年关于VM和Kubernetes的思考 | 技术头条

戳蓝字“CSDN云计算”关注我们哦&#xff01;转自&#xff1a;开源云中文社区近年来&#xff0c;容器已成为云原生应用程序架构的同义词。它们重新定义了打包、分发、部署和管理应用程序的方式。但是&#xff0c;容器本身就是已有Linux技术的重新兴起&#xff0c;只不过这些技术…

Qt实现界面的窗口的局部动态添加并布局

此程序实现的是点击界面的添加界面按钮&#xff0c;新增加一个窗口&#xff0c;并实现窗口的布局&#xff0c;随着窗口个数的在布局中的增加&#xff0c;窗口大小自动缩小。创建基于QT widget Application的应用程序&#xff0c;选择基类QDialog,去掉Generate form前的勾&#…

第五篇:Spring Boot整合filter

一、Springboot整合Servlet 第一种方案&#xff1a;通过注解扫描完成filter组建的注册 1、编写自定义filter(FirstFilter) //urlPattern是一个数组可以添加多个 //WebFilter(filterName "FirstFilter",urlPatterns {"*.do","*.jsp"}) WebFilt…

微服务精华问答:什么是微服务架构中的DRY?| 技术头条

微服务(Microservice Architecture)是近几年流行的一种架构思想,关于它的概念很难一言以蔽之。 究竟什么是微服务呢?今天就让我们一探究竟。1Q&#xff1a;什么是微服务架构中的DRY&#xff1f;A&#xff1a;DRY代表不要重复自己。它基本上促进了重用代码的概念。这导致开发和…

第六篇:Spring Boot 访问静态资源

Spring Boot的默认静态资源的路径为&#xff1a; spring.resources.static-locationsclasspath:/META-INF/resources/,classpath:/resources/,classpath:/static/,classpath:/public/ 优先级从从高到低 一、Spring Boot 访问静态资源有二种方案 第一种方案&#xff08;默认&…