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

企业首选的

数字选用平台

案例分享:当当网的内部框架开源策略

2021-01-05 09:40:38 阅读(232 评论(0)

建立内部应用框架。当当技术部现在按产品线划分。产品线的产品、开发和测试都在一个部门,但项目管理、运维和架构等技术体系中的公共部分是独立的部门。架构部分主要分为三个部分,一个是架构和规范,一个是性能测试,另一个是基础应用系统的研发。我们在技术架构上花了更多的精力。去年,我们在Dubbo上进行了二次开发,做了Dubbox并开源。行业反馈不错,包括很多来面试的人都知道。Java是我们技术体系和核心业务体系的明确方向,去年年底,我们开始建立基于Java的应用开发框架,DDFrame,用它来连接一些核心组件,包括SOA、已发布2.0版本,如作业调度、缓存、消息队列、数据库、配置中心等。虽然资源有限,进展缓慢,但我们一直在这样做,这个框架将在未来逐步完善,成为技术体系的核心。开源Dubbox,扩展Dubbo服务框架,支持REST风格远程调用。当当网最近开源了Dubbox项目,可以为Dubbo服务框架提供REST风格远程调用等多种扩展功能。Kryo/FST序列化等。当当当网络架构部和技术委员会架构师沈李向InfoQ中文站介绍Dubox项目时,开发背景和主要特点描述如下:Dubo是国内许多互联网公司广泛使用的开源分布式服务框架,即使从国际角度来看,也应该是一个非常全面的SOA基本框架。作为一个重要的技术研究课题,我们根据自己的需要在当当网实现了一些Dubbox的新功能,并将其命名为Dubbox(即Dubboextensions)。支持REST风格远程调用的主要新功能包括:(HTTP JSON/XML):基于非常成熟的JBossresteasy框架,REST风格在dubo中实现(HTTP JSON/XML)远程调用显著简化了企业内部的跨语言交互,同时,OpenAPI显著简化企业对外、开发无线API甚至AJAX服务端。事实上,这种REST调用也使Dubo能够为当今特别流行的“微服务”架构提供基本的支持。事实上,REST调用也使Dubbo能够为当今特别流行的“微服务”体系结构提供基本支持。此外,REST调用在基准测试下也取得了较高的性能,HTTP JSON和Dubo2.默认RPC协议(即TCP) Hessian2二进制序列化之间只有1.5倍左右的差距,详见下面的基准测试报告。支持基于Kryo和FST的Java高效序列化实现:基于今天著名的Kryo和FST高性能序列化库,为Dubo默认RPC协议增加了新的序列化实现,优化调整了其序列化系统,显著提高了DuboRPC的性能。详见下图。支持基于嵌入式Tomcat的HTTPremoting系统:基于嵌入式Tomcat实现dubo的HTTPremoting系统(即dubobo)-remoting-http),嵌入式Jetty用于逐步取代Dubo中的旧版本,可显著提高REST等远程调用性能,并将ServletAPI的支持从2.5升级到3.1。(注:除REST外,dubo中的WebServiceses、Hessian、HTTPInvoker等协议都是基于这个HTTPremoting系统)。(注:除REST外,dubo中的WebServiceses、Hessian、HTTPInvoker等协议都是基于这个HTTPremoting系统的)。升级Spring:dubo中的Spring.升级到目前最常用的3x.x版本减少了项目中版本冲突带来的麻烦。升级Zookeper客户端:将dubo中的zookeper客户端升级到最新版本,以修改旧版本中包含的bug。当当网内部稳定使用了以上许多功能,现在开源出来,供大家参考和指正。我也希望感兴趣的朋友也能为Dubo做出更多的改进。注:dubbox和dubo2.x是兼容的,dubbo的任何现有功能和配置都没有改变(除了升级Spring等版本)。此外,dubbox还严格遵守Apache2.0许可证的要求。分布式操作调度框架elastic-job的开源elastic-job原本是当当java应用框架ddframe的一部分-job。ddframe包括编码规范、开发框架、技术规范、监控和分布式组件。ddframe规划分为四个进化阶段,目前处于第二阶段。3、第四阶段涉及的技术组件并不意味着当当没有使用,但ddframe还没有统一规划。ddframe由各种模块组成,都是dd-开头,比如dd-container、dd-soa、dd-rdb、dd-job等。当当希望将ddframe的每个模块与公司环境解耦并开源,以反馈社区。Dubbox是Dd-soa的核心模块,是之前开源的Dubbo扩展版。本次介绍的elasticjob是ddjob的开源部分,其中没有开源监控(但开源监控方法)和ddframe的核心接入。elastic-job的主要设计理念是无集中的分布式定时调度框架,其思路来源于Quartz基于数据库的高可用性方案。然而,数据库毕竟没有分布式协调功能,因此在高可用性方案的基础上增加了弹性扩展和数据分割的理念,以便更大程度地利用分布式服务器的资源。目前,团队由三部分组成。第一部分是开发团队,由架构部架构师曹浩、高洪涛和我组成,主要负责设计和编码;第二部分是各研发团队的应用架构师、开发工程师和架构部主任史海峰。他们负责推广和实施,整理需求,贡献当当现有的最佳实践代码;第三部分由架构部性能测试团队组成,负责架构部性能和稳定性测试。elastic-job主要分为注册中心、数据分片、分布式协调、定期任务处理、多操作模式等模块。Zookeeeper直接用于记录操作配置、服务器信息和操作状态。Zookeeper虽然成熟,但原理复杂,使用困难,在大量数据支持下也会出现性能和网络问题。目前,elastic-job已经抽象出注册中心的接口,下一步将考虑支持用户自己实现的多注册中心,如etcd或注册中心。无临时节点和监控机制的注册中心需要实现定期心跳监测等功能。数据分片是elastic-job中实现分布式的重要概念,对应真实数据和逻辑分片,用于解耦操作框架与数据之间的关系。操作框架只负责将分片合理分配给相关操作服务器,操作服务器需要根据分配的分片匹配数据进行处理。目前,服务器分片存储在注册中心,每个服务器根据自己的IP地址拉分片。处理作业服务器动态扩容缩容的分布式协调模块。一旦集群中的服务器发生变化,分布式协调将自动监控,并将变化结果通知每个仍然存在的操作服务器。协调将涉及主节点选举、重分片等操作。采用Zookeeper的临时节点和监听器,实现主动检查和通知功能。根据cron表达式定时触发任务,定时任务处理具有防止任务同时触发、错过任务重启等功能。Quartz本身的定时调度功能主要用于每个任务都使用独立的线程池,以便于控制。多操作模式将定期任务分为多个流程,有无任何修改的简单任务;fetchdata/processdata用于处理数据的数据流任务;未来将增加新闻流任务、文件任务、工作流任务等。用户可以以插件的形式扩展和贡献代码。作业即定时任务。一般来说,系统可以使用信息传输而不是部分使用场景。两者确实有相似之处。可替换的场景,如队列表。将待处理的数据放入队列表中,然后使用频率极短的定时任务拉取队列表中的数据并进行处理。在这种情况下,使用新闻中间件的推送模式可以更好地处理实时数据。而且基于数据库的消息存储吞吐量远小于基于文件的顺序。但在某些情况下,不能交换:时间驱动或事件驱动:内部系统通常可以由事件驱动,但涉及到外部系统,只能使用时间驱动。例如:抓取外部系统的价格。每小时抓取,由于是外部系统,事件触发事件不能像内部系统一样发送。批量处理OR逐条处理:批量处理堆积的数据比消息中间件更有效率,在不需要实时处理的情况下更有优势。此外,一些业务逻辑只能批量处理,如电子商务公司和快递公司结算,每月结算一次,并根据交货数量提供佣金。例如,如果当月送货超过1000,快递公司将额外支付1%的快递费。非实时OR实时性:虽然新闻中间件可以实时处理数据,但在某些情况下不需要。比如VIP用户降级,如果超过一年没有购买行为,就会自动降级。这种需求没有强烈的时间要求,VIP用户也不需要按时间精确降级。解耦系统内部OR系统。操作一般包装在系统内部,消息中间件可用于系统间解耦。elastic-job的主要功能分布式:重写基于数据库的Quartz分布式功能,并使用zookeeper实现注册中心。并行调度:通过任务分片实现。将一个任务分成n个独立的任务项,分布式服务器并行执行各自分配的分片项。弹性扩展缩容:将任务分成n个任务项后,每个服务器分别执行各自分配的任务项。一旦新的服务器加入集群,或者现有的服务器离线,elastic-job将在下一个任务开始前触发任务重分片,以保持任务执行不变。集中管理:采用基于Zookeeper的注册中心,集中管理和协调分布式作业的状态,分配和监控。根据Zookeper的数据,外部系统可以直接管理和监控elasticc-job。定制流程任务:操作可分为简单和数据流处理两种模式,数据流分为高吞吐处理模式和顺序处理模式,高吞吐处理模式可以打开足够的线程快速处理数据,顺序处理模式将每个分割分配到一个独立的线程,以确保同一分割的顺序,类似于kafka的分割顺序。其他功能故障转移:下次操作前弹性扩容缩容,但在执行过程中,线下服务器分配的操作不会重新分配。在这次操作中,可以使用空闲服务器抓取孤儿作业分片进行故障转移功能。同样,故障转移功能也会牺牲部分性能。Spring命名空间支持:elastic-job可以直接运行,而不依赖spring,但也为spring集成提供了自定义的命名空间。运维平台:为管理操作提供web控制台。非功能需求稳定性:当服务器没有波动时,不会重新分割;即使服务器波动,下次分割的结果也会根据服务器IP和操作名称哈希值计算稳定的分割顺序,尽量不要做大的变化。高性能:自动切割和多线程并行处理同一服务器的批量数据处理。灵活性:所有功能和性能之间的权衡都可以通过配置打开/关闭。如:elastic-job将向注册中心更新操作状态的必要信息。如果操作执行频率高,会导致大量Zookeeper编写操作,而分布式Zookeeeper同步数据可能会导致网络风暴。因此,为了考虑性能问题,可以牺牲一些功能来换取性能的提高。幂等性:elastic-job可以牺牲部分性能,以确保同一部分不会同时在两个服务器上运行。容错性:当操作服务器与Zookeeper断开连接时,立即停止操作,防止分片重新分配,脑裂服务器继续执行,导致重复执行。Elastic-job刚刚在当当内部推广。目前已使用支付系统、订单系统、发票系统和促销系统,快递系统和仓储系统即将使用。开源后也了解到很多公司都有使用计划。

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

推荐阅读

香奈儿商标惹上了中国兵器?胡扯!

最近两条关于商标的新闻,均涉及到了国际知名品牌香奈儿有报道称:中国武术协会贵州分会认为法国奢侈品品牌香奈儿(Chanel)的商标涉嫌抄袭中国传统武器八卦子午鸳鸯钺,指责该公司亵渎中国文化,并向法院对香奈儿提起诉讼。据报道,香奈儿的商标与八卦…查看详情

2022推荐10款好用到爆的软件,你收藏了几款?

相信大家平时手机里面都备用了自己喜欢方便好用的app软件,这些软件成为了大家的必备软件,下面小编就给大家来详细介绍一下2022推荐10款好用到爆的软件这一块的内容,希望能帮助到大家!  2022推荐10款好用到爆的软件  1、《UC浏览器》…查看详情

小说有声阅读软件有哪些 好用的小说有声阅读软件

每个人晚上入睡的方式都不一样,有的人喜欢听小说,所以,晚上的时候,就会听着小说睡觉,但是,并不是每个软件都可以听小说的,需要下载对应的软件,小说有声阅读软件有哪些? 1、掌阅听书 全面塑造史上最强力的APP:大量原版、永久免…查看详情

客服系统排行榜,客服系统哪种好用?

现在各个行业也都非常注重于给消费者带来的优质服务,所以也都会使用可客服系统来增加办事的效率,而这样的系统在市场中,也是越来越多了,大家可能在选择的时候也会非常的迷茫,不知道哪一款系统更值得选择,那么客服系统排行榜有哪些呢?哪种好…查看详情

专利技术申请程序 专利技术如何申请

   在平时很多的小伙伴都不知道专利技术申请程序的基本情况,而且对专利技术申请程序都不是很熟悉,下面万商云集小编就为大家整理了专利技术申请程序这方面的相关内容,希望下面的内容能帮助到各位。    一、专利技术申请程序  《中华人民共和国专利…查看详情

2021年开始做电子商务怎么样?是否已经晚了?

电子商务如今作为一种新型网上贸易方式,使企业与消费者摆脱了传统的商业束缚,网络支付也逐渐引起大家的关注。国内的电商已经从第一代发展到了第三代电商,行业虽然规范度还不是特别清晰,但也已相对完善。那么现在开始做电子商务怎么样?是否算晚? 图片来…查看详情

钉钉视频会议爆满怎么解决,这几种方法可以解决

  相信大家平时在疫情期间都使用过钉钉来进行学习和进行视频会议, 但是很多的时候会遇到一个问题就是视频会议爆满的情况,下面小编就给大家来详细介绍一下如何解决这个问题。  钉钉视频会议爆满怎么解决  1、在钉钉软件我的界面里,点击设置按钮。…查看详情

专利权的保护期是多久?专利权的保护期时长

    任何专利发明都是有保护期的,专利权也不例外,下面万商云集小编为大家介绍下专利权的保护期时长的相关问题,希望下面的内容能帮助到大家。    一、专利权的保护期是多久?专利权的保护期时长  专利权保护期限:发明专利权的保护期限为二十年,…查看详情

这8款微信插件一定要安装,让你的微信比别人更方便

在使用微信这个平台时,插件作为必然之势,许多衍生的功能都有外界的丰富的组件库和功能库的支撑。小程序插件的设计,可以让第三方服务成为一种更可靠的模式被使用,你知道有哪些好用的微信插件吗?这8款微信插件一定要安装。 1.微信伴侣-自动抢红包 微…查看详情

什么是网页快照

  网页快照(WebSnapshot),也称为网页截图(WebScree1hot)或网页缓存(Web Cache),是指将网页内容在一定时间内进行保存,并存储为图片或HTML文件等格式的操作。一般情况下,网页快照是由搜索引擎等服务提供商提…查看详情

ug是什么软件

UG是用来干什么的?UG软件主要功能是将原有2维平面制图拓展至三维立体制图的软件,主要是迅速帮助设计加工等人员认知产品结构,还可向下生成2维图纸并标注细节尺寸、表面要求、技术要求等。相同类型软件有pro/E,solidworks,CATIA…查看详情

淘宝用户钻石等级有什么用?

淘宝店铺的五星和钻石哪个好?淘宝的钻和星,这是对淘宝荣誉的描述。钻的比星的好,说明店铺经营时间长,卖的东西多,更容易让人信任。 淘宝将消费者和企业分为四个阶段。每个阶段分为五个等级。四个阶段是心形、钻石和两种不同颜色的皇冠。每次在淘宝,网…查看详情

有哪些高效又操作方便的剪辑软件

有越来越多的人,想要通过视频剪辑的方法来让自己的事业发展的日益壮大,既然是想要学习视频剪辑,那么必然会少不了一些剪辑软件,那么有哪些高效又操作方便的剪辑软件推荐呢? 1、必剪 这款软件是专门由b站出的,因为b站也算是一个视…查看详情

ems网点的优缺点总结大全

ems网点作为全国范围最广的快递网点,相信许多人都用它寄存过东西。作为中国速递行业的最大运营商和领导者,它能吸引人们的不仅仅是因为它的范围广阔,还由于它各处优于其它网点的特点,那么今天我们来分析一下ems网点的优缺点。…查看详情

想做电商运营高手?先看看电商运营需要哪些能力吧

在这弥漫着电商气息的社会里,人们总想着依靠电商能够发家致富。但是很多新手卖家往往在开店之后就不知道该怎么运营,甚至不知道电商运营需要哪些能力才可以胜任,导致店铺逐渐没落。那么作为电商运营者,又该具有那些能力呢?针对这个问题,接下来小万就来和…查看详情

最新文章