首页 >知识讲堂 >网站建设知识>案例分享:当当网的内部框架开源策略

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

2021-01-05 09:40:38 阅读(231 评论(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刚刚在当当内部推广。目前已使用支付系统、订单系统、发票系统和促销系统,快递系统和仓储系统即将使用。开源后也了解到很多公司都有使用计划。

以上就是关于案例分享:当当网的内部框架开源策略的相关介绍,更多案例分享:当当网的内部框架开源策略相关内容可以咨询我们或者浏览页面上的推荐内容。我们将让你对案例分享:当当网的内部框架开源策略有更深的了解和认识。

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

推荐阅读

2022年六大英文学习软件

相信大家都有英语烦恼的问题吧,每个人都想学好英语但还是太难了,今天我就来给大家介绍一下2022年六大英文学习软件,相信你只要选择了以上这几款软件之一,你的英语一定会学的非常好的。1.乐词英文学习软件乐词英语教学app一个在手…查看详情

python与c++学哪个好

计算机二级c和python哪个好考?哪个语言更有用,必然是见仁见智,无论选哪一个都会有人不同意,但是可以肯定的是,想学习编程的话,这两个语言都很不错,学完都会帮助你打开新世界的大门。有意思的是,C和Python差不多正好是编程世界的…查看详情

免费修图软件app有哪些?免费修图软件app介绍

当自己看到自己喜欢的图片或者是拍摄照片之后,保存在手机里,想要带来更好的效果,就可以进行修图,其实修图之后会让图片变得更加清晰,而且还可以打造出明星照片的感觉,但是在选择修图的时候,应该要找到一些好的软件,有些软…查看详情

优化供应链,是B2B企业加速发展的主要动力

在国内,B2B电子商务并不是什么新鲜的话题;但真正利用B2B手段在供应链上创造价值的企业仍相对缺乏。对B2B和供应链的真正价值认同、行业标准和经验的缺乏是我国B2B电子商务发展缓慢的重要因素,使得优化供应链成为B2B企业加速发展的动…查看详情

加客户微信被拒怎么办?可以这样联系TA!

你是否有被客户拒加微信的经历呢?向客户索要联系方式,或要求加微信好友时很多顾客会各种推脱 之所以如此,主要由于信息泄露问题十分严重大多数顾客都已产生戒备心理担心留下联系方式后,会被反复叨扰还在为没有添加客户好友无法给ta发送信息而...查看详情

怎样在网上做生意赚钱

网上怎样才能挣钱?网上挣钱的门路很多,就像我们平常做买卖一样,有的能挣钱有的挣不到钱,同行没同利,就是这个理,我们要想在网上挣到钱,可以开直播,卖货,卖些季节性的衣服,水果一类的东西,少便宜点,大众化,需求量自然不…查看详情

2023年水费多少钱一吨

  优质答案(1)  收取二十几元一吨的水费违法。《民法典》中规定违反要求私自涨水费属于违法行为,需要承担相应的法律责任。正常的水费是4块左右一吨  优质答案(2)  不合法,  因为自来水国家是由物价部门进行定价的…查看详情

图片制作软件选哪款?这几款值得选择

怎样让自己的图片更加的独一无二,或者是想要增强高级感提升质感的话,都是缺少不了一款好用的图片制作软件的,现在这样的软件不仅类型多,所带来的各种功能也越来越丰富了,那么到底图片制作软件选哪款呢?这几款都值得选择,一…查看详情

做商城网站需要多少钱

做商城网站需要的费用因多个因素而异,包括网站规模、功能需求、设计复杂度和开发方式等。以下是一些可能影响商城网站开发费用的关键因素: 1.网站规模和功能需求:商城网站的规模和所需功能将直接影响开发成本。一个简单的小型…查看详情

软件开发自学步骤 软件开发如何自学?

  很多人想开发一款手机软件应用基本都是请第三方外包公司或软件工具进行,但是却不知道软件开发需要经过什么样的流程,下面小编就给大家来详细介绍一下软件开发自学步骤 软件开发如何自学?这一块的相关内容,希望能帮助到…查看详情

中小企业如何保护知识产权?看完这几点你就知道

知识产权是在科学技术、文学艺术等领域中,发明者、创造者等对自己的创造性劳动成果享有的专有权。图片来源网络,侵删随着经济社会的不断发展,知识产权对经济发展的重要性不断凸显。作为国民经济支柱的中小企业,受知识产权的影…查看详情

如何增加百度收录 增加百度收录的几种方法介绍

  相信很多的公司自己做了网站后都想办法增加网站在百度的收录,现在很多的网站收录情况都不是很理想,下面万商云集小编给大家来详细介绍一下增加百度收录的相关方法技巧,希望能帮助到大家增加自己网站在百度的收录。  一、…查看详情

字符串是什么意思 哪些属于字符串

相信很多没用接触到计算的朋友都不知道字符串是什么意思,在计算机技术领域比较常用,在编程代码这块也比较常见,下面万商云集小编给大家来详细介绍一下字符串的相关常识。  什么是Python中的字符串?  我们许多熟悉C,C++等编程…查看详情

淘宝产品上下架时间怎么优化?

淘宝商品上下架时间是影响淘宝商品排名的因素之一,越接近下架的商品,排名越有可能靠前。对于小卖家或者新开设的淘宝网店而言,受成本和淘宝网店等级的影响,很多推广活动都无法参加,此时设置商品上下架时间就成了获取商品流量…查看详情

盘点那些好用的记账代理软件排行

记账代理软件是专门为公司财务发展而设计的,对公司的财务记账有着较大的作用,但是对于公司来说,选择一个好的记账代理软件是比较困难的,今天我就来为你们盘点那些好用的记账代理软件排行。 1.畅捷通记账代理软件 畅捷通是…查看详情

首页

产品

万商学院

客户服务

会员中心

当前站点

h

选择站点

全国站成都

一 客户顾问-张三

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

    电话咨询

    在线咨询