掏空大山、沉入海底?互联网大厂的服务器为什么要这么处理?

掏空大山、沉入海底?互联网大厂的服务器为什么要这么处理?,第1张

全球的互联网公司里最重要的莫过于它们的服务器,一旦服务器发生故障后果不堪设想,在我们的认知里这些公司的服务器一定是放在非常重要的地方。但其实全球很多公司的服务器存放的地方,可能令网友们大吃一惊, 例如微软的服务器是放在大海里,阿里巴巴将自家服务器放在了著名景区千岛湖的湖底,苹果的服务器则是放在了我国贵州,腾讯、华为同样将服务器放在贵州大山里。

2014年微软开始着手将服务器放置于水下的计划 ,同年开始在海里做投放实验,他们将300台电脑的服务器,放置进一个重约十七吨的密封舱内,该密封舱是全钢制的。而且密封舱内同时还装载着100多个传感器,岸上的工作人员随时可以通过这些传感器感知到水压和温度,便于及时发现并处理特殊情况,一切就绪后微软的团队将这个密封舱投入加州海岸的近海区。

第一次试验结束后,为证明海底数据中心是可行的, 2019年微软又进行了第二次海底数据试验, 这次的实验规模更大,装载的电脑服务器更多,一共有864台电脑服务器,相比较第一次的钢制密封罐,这次试用的密封设备更像一艘小型潜艇,它的长度超过十米,而这次的实验周期为期五年。

同样将服务器放在水里的还有阿里巴巴,阿里将自家服务器藏在了千岛湖里面,去过 旅游 的游客应该有听导游介绍过吧。服务器在运行过程中会散发大量热气,此时必须做好散热,不然可能会有烧坏的风险。而为了保护环境,减少碳排放,阿里便将服务器放在了湖底。千岛湖地区平均温度在18摄氏度左右,湖水更是能让数据中心节省8成以上的制冷能源。如此以来一年便可减少1万吨的碳排放

华为也有类似储存服务器的举动,与微软将服务器放进海下不同的是, 华为是将服务器存放在山洞里 。2017年时候华为在贵州贵安新区的七星湖数据中心,开始着手建立自己的服务器中心, 据悉,该数据中心第一期项目就已经有40万平方米,可以存放服务器约为60万个,华为在这里共存放了170多个的服务器。 这样大规模的项目几乎将一座山掏空,未来可能还会继续扩大规模。

为什么这些互联网公司,会将这么重要的服务器放在这些看似“不靠谱”的地方呢?特别服务器还非常怕水,微软不怕服务器进水吗?其实原因很简单,服务器怕水同样怕热,普通电脑机房的温度就会让人受不了,何况是这些互联网公司的数据中心。所以散热一直是让这些 科技 公司头疼的问题,特别是夏天,为这么庞大的服务器组织冷散热也是一笔很大的支出。

据相关数据表明,如华为微软这种大型互联网公司,每天为数据中心散热所需要的电力成本,就占所有成本的20%以上,其中又有40%以上是用于制冷消耗。 全球的互联网为公司的数据中心,每年用在为服务器散热的电量,是全球每年用电的2%。 这个数据已经非常庞大了,相当于一些国家一年的用电量了。所以如何更加节能减排为服务器散热,是许多互联网公司都在积极寻求的,微软使用的“水冷”就是一个很好的解决方案。

据微软表示将水下数据中心放进海底105天后,他们发现这个密封舱的温度会随着海水的流动而消散,目前效果还算不错,但密封舱附近的海水会有少许上升,约为正常海水温度的千分之一。不过要是大规模使用这种方式可能还有些困难,毕竟微软的数据中心可不止几百台电脑,而且放进海底维护起来可能也有诸多不便。

像华为选择把服务器存放在山洞中的方案,维护起来就更方便一点,唯一问题就是前期挖隧道需要一些投入。而且贵州气温受山地影响,常年温度都维持在20多度不冷不热,而且夏天的夜晚山里温度非常低,山洞内的温度就要更低一些。 另外,贵州的用电非常便宜,一度电仅0.35元左右,而且在贵州的水力发电非常成熟,可以减少火力发电的污染。

不仅是华为,例如苹果,腾讯也在这个地区有自己的数据中心,就连国家大数据中心也是在这个地方。这里存放着全球一半以上的国家管理数据,同时贵州也是全球最大的数据中心。另外,如亚马逊,360等公司,他们将数据中心存放于宁夏地区,目的也很简单,就是利用当地的自然气候达到为服务器降温的目的。

随着互联网技术的不断发展,我们在进行服务器开发方面也掌握了很多的开发部署技术。今天,云南IT培训http://www.kmbdqn.cn/就给大家简单来介绍一下,都有哪些服务器开发部署方法是值得我们使用的。

停机部署

停机部署其实是简单粗暴的方式,就是简单地把现有版本的服务停机,然后部署新的版本。在一些时候,我们必需使用这样的方式来部署或升级多个服务。比如,新版本中的服务使用到了和老版本完全不兼容的数据表的设计。这个时候,我们对生产有两个变更,一个是数据库,另一个是服务,而且新老版本互不兼容,所以只能使用停机部署的方式。

这种方式的优势是,在部署过程中不会出现新老版本同时在线的情况,所有状态完全一致。停机部署主要是为了新版本的一致性问题。

这种方式不好的问题就是会停机,对用户的影响会很大。所以,一般来说,这种部署方式需要事前挂公告,选择一个用户访问少的时间段来做。

蓝绿部署

蓝绿部署与停机部署大的不同是,其在生产线上部署相同数量的新的服务,然后当新的服务测试确认OK后,把流量切到新的服务这边来。蓝绿部署比停机部署好的地方是,它无需停机。

我们可以看到这种部署方式,就是我们说的预发环境。在我以前的金融公司里,也经常用这种方式,生产线上有两套相同的集群,一套是Prod是真实服务的,另一套是Stage是预发环境,发布发Stage,然后把流量切到Stage这边,于是Stage就成了Prod,而之前的Prod则成了Stage。有点像换页似的。

这种方式的优点是没有停机,实时发布和升级,也避免有新旧版本同时在线的问题。但这种部署的问题就是有点浪费,因为需要使用双倍的资源(不过,这只是在物理机时代,在云计算时代没事,因为虚拟机部署完就可以释放了)。

另外,如果我们的服务中有状态,比如一些缓存什么的,停机部署和蓝绿部署都会有问题。

滚动部署

滚动部署策略是指通过逐个替换应用的所有实例,来缓慢发布应用的一个新版本。通常过程如下:在负载调度后有个版本A的应用实例池,一个版本B的实例部署成功,可以响应请求时,该实例被加入到池中。然后,版本A的一个实例从池中删除并下线。

这种部署方式直接对现有的服务进行升级,虽然便于操作,而且在缓慢地更新的过程中,对于有状态的服务也是比较友好的,状态可以在更新中慢慢重建起来。但是,这种部署的问题也是比较多的。

在发布过程中,会出现新老两个版本同时在线的情况,同一用户的请求可能在新老版中切换而导致问题。


欢迎分享,转载请注明来源:夏雨云

原文地址:https://www.xiayuyun.com/zonghe/648800.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-07-22
下一篇2023-07-22

发表评论

登录后才能评论

评论列表(0条)

    保存