服务热线:400-0033-166
万商云集 - 企业数字化选用平台

企业首选的

数字选用平台

剖析美团对于Python的Django和Tornado框架的应用

2021-01-04 15:39:40 阅读(178 评论(0)

目前,独立的美团云业务部有十几名工程师。虽然部门独立,但在工作中仍与系统运维组密切配合。美团系统运维组原本有三分之二的开发工程师,所有运维工程师都有编写代码的能力,所以开发和运维工程师可以密切配合。美团云最初版本的相关制造商内容始于2012年7月,最初是作为私有云计算平台建立的。第一版开发了大约2个月,然后花了大约10个月的时间将美团的所有业务转移到云平台。现在除了Hadoopp、数据库仍在物理机器之外运行,美团网络的所有业务都在美团云上运行,内部研发和测试平台也在美团内部的办公云平台上运行。2013年5月,美团云开始向外界提供公共云服务,到目前为止只向外界提供云主机产品。对象存储、Redis、MySQL、负载平衡、监控、VPC等服务也在研发中,部分产品已在内部和部分测试客户中使用,未来将根据产品的成熟度和客户的需求逐步向公众开放。稳定性是公共云服务的核心价值。自公共云服务开放以来,美团云的主要工作是提高云主机的稳定性,改进云主机的模板、备份、监控和安全。预计美团云将于2014年9月发布其第三个版本的更新,并继续完善其产品细节。技术架构美团云最初选择OpenStack时、CloudStack、Eucalyptack已经进行了研究,结果是架构设计采用OpenStack框架,网络架构参考CloudStack,主要组件由自己开发,部分组件在OpenStack原生组件上进行了二次开发。云主机管理系统的核心是自己开发的,不使用Nova。采用Region-Zone-Cluster三层架构支持跨区域、多数据中心的大规模集群部署。基于KVM的主机虚拟化和基于OpenVSwitch Openflow网络虚拟化技术。Glance用于镜像管理。有一些修改,如多数据中心分布式支持和镜像替换。Keystone用于身份管理。还有一些修改,例如,高并发性能改进,与美团账户系统集成。Swift用于对象存储,但Swift在写延迟方面存在性能问题,OAM功能薄弱,因此也进行了一些修改和研发。Swift现在正在为美团内部存储量几十TB量级的业务提供服务。OpenStack之所以没有整体引入,是因为当时调查的时候,我觉得OpenStack的设计与美团的实际情况相比是脱节的。例如,网络架构需要大量的调整和共享存储的支持。那时候对于美团来说,现有业务的基础设施已经基本固化,为了适应OpenStack而做出这样的调整基本上是不可接受的。此外,OpenStack在很多细节上都达不到要求的水平。例如,OpenStack设计了跨机房多Zones,假设您的机房之间的网络是完整的,这不符合我们的网络现状。因此,基于美团现有的主机使用模式和网络架构,我们重新设计了网络、存储和主机管理模型,并独立开发了虚拟管理平台。同时,当我们从单机房到多机房时,我们在Zones之间进行了解耦。例如,Glance服务节点被放置在每个机房中,以减少对跨机房网络的依赖。正是由于这些研发工作,经过不到一年的磨练,我们实现了美团在私有云上完全运行整个基础设施的目标。当然,因为我们不使用Nova,这意味着我们不能直接使用OpenStack社区中许多依赖Nova的组件和功能。然而,与OpenStack大而全/兼容并包的架构相比,我们坚持在主机虚拟化使用KVM、网络虚拟化使用OpenVSwitch等各个方面都集中精力使用一项技术 OpenFlow,整个系统的开发和维护成本相对较低,可以深入挖掘这些技术方案的功能特性,最大限度地提高硬件性能。同时,由于我们掌握了基本系统的代码,我们可以更高效地添加一些新的业务功能(如虚拟IP、USBKEY支持等),并实现系统架构的升级(如多机房架构支持等)。此外,技术委员会还提出了如何将OpenStack组件的一些修改,如Swift的优化反馈给上游社区。当然,这取决于社区是否接受我们的patch,我们仍然优先满足业务需求。在其他方面,块存储落在本地SAS盘上,并在本地制作RAID。目前,我们为美团自己的业务做RAID5,为公共云用户做RAID10。这是考虑到美团自己的业务在应用层做了一个完整的高可用性设计,即使一个节点不会影响业务;但对于公共云用户来说,他们使用的云主机是一个单点,所以他们应该更好地保护他们的云主机。当然,使用RAID10的成本会更高。在解决上述稳定性和性能问题之前,我们也在考虑共享存储。SSD将在未来使用,从而大大提高块存储的性能。网络分布式设计,主机采用Openflow,通过Openflow修改二层协议,让每个用户都有一个独立的平面网络,与其他用户隔离。通过DNS虚拟化技术,不同的用户可以在自己的私人网络上使用相同的主机名称,并在每个宿主机上部署分布式DNS和DHCP,以实现基本网络服务的分散化。运维美团云的运维思路与整个美团的运维思路是一致的。以下操作思路不仅适用于美团云,也适用于整个美团网。运维框架可概括为五横三纵。从横向上看,自底向上分为五个层次:物理层,包括机房网络和硬件设施。我们正在从底层开展多机房和城市网络建设,以确保基础设施的稳定性。为了应对大型机房建设带来的运行和维护成本,我们实现了Baremetal自动安装和部署的Web管理。服务器上架后,其他工作自动完成,物理机器可以像虚拟机一样管理。包括操作系统和虚拟化在内的系统层。在虚拟化的基础上,我们采用模板(镜像)的方式进行管理,并对Linux核心进行了部分定制开发,如优化OVS的兼容性。包括Webserverr的服务层、缓存、数据库等基本服务。基于Puppet工具,我们进行了统一的配置管理,拥有自己的软件仓库,并定制了一些软件包。统一配置管理的优点,一方面可以避免不一致的修改,保证集群的稳定性,另一方面可以提高运维效率。逻辑层,包括业务逻辑,数据流。这一层的主要工作是发布和变更。在许多其他公司,业务发布和数据库变更管理都是由运营和维护完成的。我们认为,开发和运营维护的合作成本较高,因此我们一直在向开发人员自助的方向进行,通过代码发布平台和数据库变更平台实现开发和运营维护的轻耦合。在发布平台上,每个应用程序对应于一个独立的集群,一个开发作为应用程序owner有最高权限,许多开发成员可以自助发布代码作为应用程序。数据库变更平台也有类似的权限控制机制,在任务执行层面有特殊的稳定性。例如,大型变更任务将自动调度到夜间执行,并在后台备份删除数据表的任务。包括用户可见部分的应用层。除了类似于逻辑层的发布和变更外,我们还有一个统一的前端平台,实现访问流量的进出分离、行为监控和访问控制,这对整体安全非常有益。纵向工作有三个部分,对上述五个层次是通用的:监控。从物理层到服务层的监控和报警都是运维跟进和响应的。对于逻辑层和应用层,也是开发人员自助的理念。操作和维护为监控API提供了标准化。开发可以创建自己的监控项目,设置报警规则,并添加、删除和检查。监控报警后的处理,现在有些已经实现了自动化,有些还没有实现。特别是一些基础设施和业务之间的纵向链还没有打开,包括建立业务容量模型、特定业务形式的最高负荷、不同负荷水平的SLA应该是多少,等等,这些模型可以自动处理。安全。我们很早就部署了一个统一的安全访问平台。所有在线手动操作都需要登录relay跳板。每个人都有一个独立的登录帐户,所有在线操作都有一个审计日志。专门的信息安全组负责更多的安全工作。流程。Jira早期做了一些简单的流程,但还是需要改进的。目前正在开发相应的流程控制系统,以满足相对集中的需求,方向是自动化和自助化。从业务部门申请VM资源到业务扩张的整个过程,我们正在开放上下游。未来,我们可以通过非常简单的操作实现Web界面,并提供服务API,方便其他业务平台的集成。虚拟化覆盖整个业务线后,这些事情变得非常方便。总之,美团网的整体运维理念是保证业务的稳定运行,促进全面自动化和自助化。开发人员应尽可能通过自动化平台完成涉及开发、运维沟通合作的部分。除了基本环境和平台建设外,运维人员还帮助业务梳理高可用架构,提高代码的可操作性,定位和解决业务中的各种问题。从内部服务到现在两年来,美团云最大的改进是从单机房到多机房的建设,这与美团网的城市网络建设同步进行。单机房时,美团网业务早期遇到运营商网络中断几个小时的情况,期间业务不可用,非常痛苦。多机房冗余最理想的情况是,即使整个机房断电,业务也不会受到影响。当然,这意味着需要100%的冗余,成本相对较高。然而,对于美团来说。com愿意承担冗余成本,因为不可用业务造成的损失大于这些冗余成本。因此,我们现在有50%的物理资源冗余,30%的冗余通常保留在带宽上。由于美团网的快速发展,去年我们遇到了资源不足的情况,在踩了很多坑之后,开始做一些长远的规划。目前,美团网络业务的双机房冗余已经部分实施,美团云也有两个机房。如果公共云客户的业务支持水平扩张,也可以进行跨机房部署。这种机房级高可用性做得很好,大大提高了稳定性,大大降低了网络抖动对业务的影响。可用性SLA可以从目前的四个9中提高。一些大型客户对服务质量的需求相对较高,因此美团的城市网络和未来的广域网也将与我们的公共云客户共享。此外,上面提到我们的数据库运行在物理机器上,这一块现在使用SSD,读写性能高于早期的三个15000转SAS,瓶颈在千兆网卡上,所以我们现在也在做万兆网络的升级。数据库服务也将向公共云用户开放,基础设施与美团自身业务一致。由于未来计划使用本地存储,虚拟机迁移需要在夜间进行,以减少对用户服务的影响。在保证稳定性和性能的前提下,共享存储是提高服务可用性的好选择,因此我们正在测试万兆网络下的共享存储方案。此外,我们底层虚拟化机制使用的KVM本身没有热插拔功能,这也是我们计划要做的。现在很多客户问我们什么时候Redis,什么时候云数据库,有些客户会需要Redis和MongoDB,Web服务想要MySQL。我们的计划是DBA团队提供一些模板,相当于一些专门为Redis/MySQL优化的系统镜像,让客户可以直接使用。这可能会在下一个版本的release中推出。我们还将提供一些基础设施咨询服务,一方面是工程师提供的人工服务,另一方面是工具 以互联网的形式分享我们的最佳实践。美团现在已经达到了数百亿的规模,并积累了大量的内部经验。如果我们能把这些积累传递给我们的客户,我们可以帮助客户避免许多弯路。美团云架构   美团云的前端和后台框架是Django,主要处理网络业务的逻辑。Django拥有丰富的社区支持、健全的文档和强大的功能。然而,一些特征似乎是多余的。例如,Django中的许多“黑魔法”都是通过数据库外键实现的,但美团有自己的DBA团队负责审查所有项目的数据库设计,他们要求不允许使用外键,据说是因为最佳实践经验。   Python还实现了后端整个云平台的框架。底层包括虚拟化计算、网络和存储三个功能系统。上层分为资源管理、任务调度、日志、监控、用户管理、通知和报警API、用量计费等模块同时在垂直方向上,还包括关系数据库服务、缓存服务、对象存储服务、负载平衡服务、模板和快照服务、虚拟专用网络服务等。虽然后端业务不同,但架构师抽象出一套处理工作流的逻辑,并用Python实现了一个框架。例如,在新闻通信机制的选择上,美团云没有采用类似OpenStack的新闻队列Rabitmq方案,而是采用Webserver。主要原因是考虑到Webserver经历了更长时间的考验,行业对HTTP协议有了更成熟的解决方案。例如,在新闻通信机制的选择上,美团云没有采用类似OpenStack的新闻队列Rabitmq方案,而是采用Webserver。主要原因是考虑到Webserver经历了更长时间的考验,行业对HTTP协议有了更成熟的解决方案。  &

内容来源:网络,以上内容来源于网络,不代表本站观点,如有侵权,请联系删除。

推荐阅读

顾客管理系统是什么?有什么功能及优势

企业面临的是一个个需求巨大而供给不足的卖方市场,提高产品产量很自然成为管理的中心,企业管理基本是产值的管理,逐渐产品很变得丰富,导致市场上产品销售的激烈竞争,顾客的地位被提高到了前所未有的高度,所以市场上出现了顾客管理系统,今天我们就来了解…查看详情

云视通网络监控系统怎么连接网络

云视通网络监控系统是一种基于云计算和网络技术的视频监控解决方案。下面简要介绍如何将云视通网络监控系统连接到网络。 1.网络设备准备: 在连接云视通网络监控系统之前,需要准备以下网络设备: -云视通网络摄像机:这是实现视频监控的关键设…查看详情

天猫购物券怎么使用?

  优质答案(1)  1、我们领取天猫超市优惠券简单快捷的方式,就是到氧惠领券中心领取了。  2、氧惠领券中心为大家搜集和整理天猫超市的各种优惠券领取入口,大家根据自己的需求,选择领取即可。  3、氧惠领券中心天猫超市优惠券领取地址  4、…查看详情

crm系统软件具有哪些用途?这些功能不可忽视

在应用crm系统软件的时候,首先对于这款软件具体的功能,一定要了解清楚合理的应用,并且将这些功能都利用起来,才能够发挥最大的价值,那么crm系统软件具有哪些用途呢?这些功能不可忽视,下面就一起来通过文章的介绍看看吧。 1、…查看详情

有哪些聊天工具的用户群体比较大

现在是网络的时代,我们可以通过各种渠道去交友,扩大自己的朋友圈,让自己的朋友越来越多,那么,我们可以先了解一下聊天工具排名有哪些,根据用户量比较多的软件去下载使用。 1、VIber 它是一款免费的一起跨平台的聊天软件,主要用…查看详情

开通小程序要钱吗

  微信小程序申请需要费用吗?  分情况,如果小程序对应的公众服务号,已经认证,直接绑定就可以,不要收费。  如果只有一个小程序,并且要认证,也需要收费300  我的建议,就是先申请公众服务号,认证后再申请小程序绑定。因为小程序的推送机制比…查看详情

怎样使用代理服务器 代理服务器使用方法

  curl是一个命令行下的web客户端,可以在命令行下执行常见的web访问、自动web请求等操作,下面小编就给大家来详细介绍一下怎样使用代理服务器 代理服务器使用方法这一块的相关内容,希望能帮助到大家。怎样使用代理服务器  curl(cU…查看详情

css如何设置透明度

css怎么给背景图片覆盖一个透明度?css中rgba可以用来设置页面元素的颜色和透明度,rgba颜色值是RGB颜色值的扩展,带有一个alpha通道,通过它即可实现设置元素的不透明度。 在CSS3中,增加了一个opacity属性,使用此属性…查看详情

看书软件哪个好 哪个软件可以看书免费

  之前看到过很多关于为什么要读书的回答,其中一个回答令我印象深刻!  读书,你可以体验1000种人生。而不读书,你只能活一次!  我们没有办法无限延续生命的长度,但却可以增加生命的宽度和厚度,读书便是最好的方法。  随着互联网的不断发展,…查看详情

毕业生求职网站有哪些 毕业生求职网站排行榜

  现在的大学生找工作再也不像前几年那样,得通过现实中的人才招聘市场去找,更多的是通过网上的招聘网站去找工作,因此,大学生就必须知道有哪些招聘网站,下面就给大家介绍一下毕业生求职网站有哪些 毕业生求职网站排行榜这一块的相关内容,  毕业…查看详情

2021最火的5款财务系统软件排名

随着经济的快速发展,近些年各中大企业的财务管理也开始信息化、智能化,如何选择一个能够满足自己企业对信息化、智能化以及专业化的全面管理诉求的财务系统软件也已然成为企业领头者们最关心的问题,好用的财务系统软件有很多,我们该如何选型集成化的财务系…查看详情

美团出品的屏芯收银系统软件真实测评

时代不断发展的背景下,收银系统发展至今,架构形式、市场应用都发生了很大的变化,智能化SaaS收银系统更是深受市场的追捧和喜爱,正如美团出品的屏芯收银系统,那么它究竟好不好用,就软件各方面本文进行了真实详细测评。 在国内较知名的收银系统品牌如…查看详情

私有云储存有什么功能?

  私有云储存是指一种基于互联网的数据存储方式,允许用户将数据存储在自己的服务器上,实现远程存储和访问。随着数据存储需求的不断增长,私有云储存逐渐成为企业、政府机构和个人用户的首选,其主要功能如下:  一、数据备份和恢复功能  私有云储存可…查看详情

免费录音软件都有哪些?

想要制作一条好的视频,首先必须要有好的录音,尤其是解说游戏这一方面,如果录音不够吸引人,会让别人听着很乏味,因此,我们需要了解免费录音软件都有哪几款,然后运用这几款去录音。 1、简刻录音 有很多的免费录音的基本功能给你们的,…查看详情

dvi是什么接口

DVI是什么接口?数字视频接口。是一种视频接口标准,设计的目的是用来传输未经压缩的数字化视频。广泛应用于LCD、数字投影机等显示设备上。 此标准由显示业界数家领导厂商所组成的论坛:“数字显示工作小组”(DigitalDisplayWork…查看详情

最新文章