首页 >知识讲堂 >网站建设知识>剖析美团对于Python的Django和Tornado框架的应用

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

2021-01-04 15:39:40 阅读(176 评论(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协议有了更成熟的解决方案。  &

以上就是关于剖析美团对于Python的Django和Tornado框架的应用的相关介绍,更多剖析美团对于Python的Django和Tornado框架的应用相关内容可以咨询我们或者浏览页面上的推荐内容。我们将让你对剖析美团对于Python的Django和Tornado框架的应用有更深的了解和认识。

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

推荐阅读

【案例】公司知识产权管理案例分析

公司知识产权管理需要科学构建管理架构和执行制度,知识产权的部门组织结构是知识产权管理的基本支撑,拥有了管理基础,才能为公司知识产权资产保护起到实质作用。目前公司知识产权部门有三种基本模式,分别是集中管理制、分散管理制和行列式管理制,下面就结...查看详情

2021最新吸睛网店网名大全

在网络发达的今天,不少人开起了网店。网店的店名相当于一家店的招牌,独一无二、好听、有深刻意义的店名和普通网店名相比,哪家网店更容易被客人记住,更容易吸引客人的眼球,我想不用我多说了吧。如何起一个好听的网店名字?在…查看详情

千牛超级店长怎么使用?

  优质答案(1)  打开千牛首页,打开我要订购,然后在搜索栏搜索超级店长即可找到。下面介绍具体操作方法:1、打开淘宝首页,登录个人账户,然后选择千牛卖家中心,点击打开免费开店。  2、打开千牛首页后,在左侧的功能表…查看详情

2021最新全本免费小说软件排行榜,抓紧收藏

我们最先接触到的是纸质小说,随着科技的飞速发展,慢慢演变成手机上看小说,俗称电子书。电子书的作用可大着捏!它不仅信息量广,还方便快捷。但最让人头疼的莫过于看到一半突然要钱,没关系,今天我为大家介绍几款免费看小说的…查看详情

5年之后,我活成了曾经最讨厌的那种老板

幸福的人生千篇一律,不幸的人生各有不同。同样,可爱的老板千篇一律,讨厌的老板各有千秋。前几天,同一朋友聊天,经过几年的创业,公司已有员工50多人,问到感受,有两点:01. 累,身心俱疲;02. 成为了以前自己所讨厌的那种...查看详情

网站建设的目标是什么?获取更多客户,赚取更多利益

随着网络的发展,人们的生活越来越便捷,足不出户就可以购买到大洋彼岸的产品,因此人们越来越依赖网络了,因此很多企业开始注重网站建设了,借此机会发展自身,那么网站建设的目标是什么呢?图片来源于网络 网站建设的目标是…查看详情

淘特卖的东西是正品吗?

  优质答案(1)  我的答案是还可以。  淘特上面的东西还是比较靠谱的,不过需要认准官方正品,因为淘特是淘宝特价版,良莠参差,这点还是需要注意一下。如果是日常用品可以选择淘特,类似于手机、化妆品之类的物品建议还是…查看详情

域名被墙是什么意思

  域名被墙是指一个网站的域名在特定地区或国家被政府或网络监管机构所屏蔽,导致该网站在该地区或国家无法正常访问。这种做法被称为封锁或屏蔽。  封锁或屏蔽通常是由于政治、宗教、社会稳定等原因引起的。政府和网络监管机…查看详情

天猫超市人工客服在哪?怎么才能找到?

天猫超市的负责人怎么联系?需要咨询它们的人工客服,然后说出你的需求,然后人工客服就会联系他们的负责人,这个负责人就会根据人工客服留下的电话和地址联系你的,然后你就可以把自己的遇到的不公正待遇给天猫负责人说一下,他就…查看详情

财务SaaS软件让财务数据分析更精准

精准的财务数据分析,能够让企业准确掌握财务状况,知道哪些钱用在哪些地方,哪些环节可以减少成本;知道哪些产品更有销售市场,哪些产品可以减少产出。因此,精准的财务数据分析对企业内外管理都是十分重要的。图片来源网络凭发…查看详情

壁纸软件排行榜介绍,帮你找到好看的壁纸

在使用手机或者电脑的时候,大家都想要用到好看的壁纸,这样就可以让自己的电脑或者手机更具吸引力。要找到好看的壁纸,先要找到丰富的壁纸软件,现在就给大家介绍壁纸软件排行榜,让大家知道哪些软件可以提供好看的壁纸。1、漫兜…查看详情

off是开还是关?

  优质答案(1)  一般来说,开关上的ON和OFF表示的是电源的开状态与关闭状态,并不是英文的缩写,是英文的全称,ON是开,OFF是关。off[:f,f]prep.离开;脱落adv.切断;走开。  adj.远离的;空闲的OFF是英语表示关...查看详情

安卓播放器软件哪几款排行靠前?推荐几款好用的安卓播放器软件

现在的安卓播放器软件可以说是五花八门,选择了不同的播放器软件带来的视频资源也是不同的,如果想要更快更迅速的看到很多的新资源,那么就一定要选择一款比较不错的安卓播放器软件,这样才能够带来更好的体验,而且也会比较流畅…查看详情

无需付费看大片软件有哪些 无需付费看大片软件排行榜

  很多小伙伴平时在闲暇时间都喜欢看大片来消磨时间,市面上大多数看大片的软件其实都是要收费的,下面小编就给大家来详细介绍一下无需付费看大片软件有哪些 无需付费看大片软件排行榜这一块的内容,希望能帮助到大家、  …查看详情

分享3个好用的动画制作软件,学会人人可以成为动画大师

现在媒体技术发展越来越迅速,对动画制作的需求也不断增大,当然也有许多工业动画制作的需要,许多企业或者公司都需要制作工业动画却没有软件可以使用,以下就是我给大家的推荐,希望对大家有所帮助。1、第一款动画制作常用软件AE…查看详情

首页

产品

万商学院

客户服务

会员中心

当前站点

h

选择站点

全国站成都

一 客户顾问-张三

已为0个客户提供专业互联网服务咨询
  • 手机号码
  • 验证码图形验证码换一张
  • 短信校验码

    电话咨询

    在线咨询