剖析美团对于Python的Django和Tornado框架的应用
2021-01-04 15:39:40 阅读(194) 评论(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协议有了更成熟的解决方案。 &
推荐阅读
- 异步电机是什么
同步电机和异步电机各自的优缺点?同步电机转速与定子磁场转速同步,不论电机负载大小,只要不失步,电机转速就不会变化。只要调节电源频率就能达到精确调节电机转速,适用于精密调速场合。同步电机因为精度高、做工复杂、成本高、维修困难,应用不如异步电机…查看详情
- 知识产权专利是什么意思
知识产权专利是指为了保护创新成果而授予的一种独家权利。它是知识产权领域中最常见和重要的形式之一。一个专利可以授予发明者对其发明的独占权利,使其能够在一定的时间内以排他性方式使用、制造、销售或授权其发明。专利制度旨在鼓励创新和技术进步,因为它…查看详情
- 两种软件著作权取得方式,可根据以下情况做判断
软件著作权取得方式与一般作品著作权一致,都只有两种取得方式。一种为原始取得、一种为继受取得。 图片来源于网络 ■ 软件著作权取得方式:原始取得定义;指软件著作权权利的取得不是以他人已存权利为取得基础,而是初始性地取得权利的情形。通过原始取…查看详情
- 2022年安卓浏览器排行
下面是万商云集*给大家整理的2022年安卓浏览器排行,这些浏览器相对来说比较好用但是也比较少见。 BravePrivacy浏览器 Brave浏览器提供了一系列旨在保护你在网络上的安全和隐私的功能。例如,它包括针对内置广告、弹出窗口、脚本…查看详情
- 微信管理软件功能都有哪些呢?
微信是每个人都在用的一个软件,用微信就可以直接联系对方特别的方便,这样也可以省掉手机话费了,只要你有流量就可以给别人发微信,那么,有关于微信管理软件功能都有哪些呢? 1、丰富多彩的营销工具 假如您有不计其数乃至数以百计客户,…查看详情
- flash动画制作常用软件推荐
我们平时在制作任何东西的时候,都是需要借助软件的,只不过每一款软件所对应的应用功能不相同,应用范围也不一样,所以不管你在制作什么东西的时候,一定要找对应的软件去制作,这样才可以那么制作flash的软件有哪些? 1、flash…查看详情
- 转让专利权需要交增值税吗?
在平时很多的小伙伴都不知道转让专利权交增值税吗的基本情况,而且对转让专利权交增值税吗都不是很熟悉,下面万商云集*就为大家整理了转让专利权交增值税吗这方面的相关内容,希望下面的内容能帮助到各位。 一、转让专利权需要交增值税吗? …查看详情
- 农产品要商品化、品牌化、电商化,互联网推广是什么角色?
农产品滞销,农民“丰产不丰收”是常见社会现象,也是国家农业部高度重视并极力解决的问题。互联网推广是什么?是渠道,也是销售。2020年上半年的网络数据统计显示,“互联网+农产品”能够有效帮助农产品销售,在一定程度上解决农产品滞销问题,为农户解…查看详情
- csdn是什么
csdn是什么?是中国软件开发者网络。在“中国的软件开发者网络”或“中国软件开发者网络”(CSDN),通过操作白莲Midami数码科技有限公司,是国内最大的网络之一,软件开发者在中国。CSDN提供Web论坛,博客托管,IT新闻和其他服务。C…查看详情
- 制作图片的软件都有哪些?好用的图片软件制作推荐
不少的人喜欢拍照片,拍完照片之后对于照片的制作也是非常关键的,只有通过对图片进行编辑才能够打造出更好的效果,也会让图片变得更加美观精致。如果想要让图片呈现出不一样的效果,那么就应该要选择比较好的软件。那么制作图片的软件都有哪些?…查看详情
- 小程序如何推广运营 小程序怎么做推广
最近几年小程序营销是非常的火热的,很多的企业公司都在做小程序营销推广,下面万商云集*就给大家详细介绍下小程序的营销推广方法。小程序推广,常用十二种方法,你用过几种方法 第一种,用名称强排名 也许很多人还不知道,小程序的排名其实跟名称…查看详情
- 免费学习网站有哪些 5个免费学习网站推荐
现在有很多小伙伴会因为工作太忙而没有时间去学习,提升自己,想要去网上学习又不知道哪些网站靠谱。别担心,今天*将分享几个非常强大还免费的自学网站给大家,下面万商云集*给大家来详细推荐一下免费学习网站有哪些 5个免费学习网站推荐这方面的内容…查看详情
- 如何申请开网店,具体步骤和条件是什么
“网店”,作为一个火爆的代名词,在当下社会的规模正一点点扩展。好多人想要尝试去经营一家网店,但是又有几大多数人不了解如何申请开网店,今天这篇文章就告诉你如何让申请开网站,具体步骤和条件是什么。 一、注册淘宝账户 第一步:账户未登录情况下,点…查看详情
- 如何将域名解析到ip,都有哪些过程?
优质答案(1) 步骤如下: 1、DNS的解析过程,主要有以下几个步骤: 1.如果现在要访问某网站站点,客户机会提出解析请求,并且将请求发送给本地的域名服务器。 优质答案(2) 域名解析是把域名指向网站空间IP,让人们通过注册的…查看详情
- 企业ERP系统需要做哪些维护工作?
企业ERP系统在建设完成上线后,能够给企业带来很多便利,但对ERP系统的运营和维护却容易被忽略。事实上,企业ERP系统只是一款工具,需要运营起来才能发挥效用,也需要使用维护才能长期为企业所用。那么,企业ERP系统上线后的主要维护工作有哪些呢…查看详情
猜你喜欢
最新文章

扫码二维码
立即领取《千元实战营销秘籍》
还可免费试用营销管理系统
*如有疑问,请随时拨打免费咨询热线:400-0033-166
邮箱:zjb@iwanshang.com
服务时间:8:30-18:00
软件企业
认定号:川RQ-2018-0216
高新技术企业
认定号:GR201951001121

关注微信公众号
和10万中小企业共同成长

扫码下载APP
享全方位服务一触即达
Copyright © 2004-2022 万商云集(成都)科技股份有限公司 版权所有
蜀ICP备12001963号-2
川公网安备 51010402000322号

快速找产品

找一找哪款产品适合您?
咨询热线:400-0033-166
-


-
电话沟通
获取方案
下载APP
官方微信
扫码下载APP
全方位服务一触即达

关注万商云集
和10万中小企共成长

TOP

企业首选的AI增效平台

400-0033-166
8:30-18:00















































注册有好礼



