案例分享:当当网的内部框架开源策略
2021-01-05 09:40:38 阅读(218) 评论(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刚刚在当当内部推广。目前已使用支付系统、订单系统、发票系统和促销系统,快递系统和仓储系统即将使用。开源后也了解到很多公司都有使用计划。
推荐阅读
- 电商平台代运营要有6个规划,才叫专业,才能选择它
社会发展、互联网发展,迎来的是人们生活方式的改变,企业经营模式的改变。个人在开网店、商家在开网店、企业在开网店,网店数量一直在增加,与此同时电商平台代运营公司也在急速增加。 图片来源于网络 电商平台代运营公司的出现,是为了帮助开网店的个人、…查看详情
- 优质营销短信:格式规范、商业化、时间化
短信营销是当下宣传效果比较好、成本较低的一种推广方式,同时也受到很多中小型的青睐。优质营销短信不仅切合流量发展的大市场方向,为企业和消费者层面创造更好的体验。企业通过不断对短信内容进行解析升级,创造出优质营销短信,让用户一目了然,部分情景增…查看详情
- 微信小程序申请步骤
如何注册申请微信小程序? 1、微信小程序注册在微信公众平台官网首页,按照提示点击右上角的“立即注册”按钮,里面总过有12步,按照要求提交就可以了。 2、小程序申请微信认证政府、媒体、其他组织类型帐号,必须通过微信认证验证主体身份。企…查看详情
- ug是什么软件
UG是用来干什么的?UG软件主要功能是将原有2维平面制图拓展至三维立体制图的软件,主要是迅速帮助设计加工等人员认知产品结构,还可向下生成2维图纸并标注细节尺寸、表面要求、技术要求等。相同类型软件有pro/E,solidworks,CATIA…查看详情
- 文件恢复软件哪个靠谱呢?你选对了吗?
现在的人们通常都会使用手机或者是电脑去办公,但难免会出现误删的情况,让自己的辛苦付之东流。其实文件丢失了不用担心,可以通过文件恢复软件来成功找回,但作为电脑的菜鸟,怎样选择合适的软件,就成为了人们较为关注的问题,那么文件恢复软件…查看详情
- 2022年免费有效的推广平台有哪些
最近几年对于企业做推广来说难度是越来越大,下面万商云集小编就给大家来推荐下2022年免费有效的推广平台有哪些,希望能帮助到大家。 那曾经有哪些属于红利期的营销玩法和渠道?读完这篇文章你能了解到: 1、互联网营销该怎么做? 2、怎么…查看详情
- 谷歌镜像是什么意思?有什么作用?
谷歌镜像(Google Mirror)是指对谷歌搜索引擎的镜像站点,也就是把原来的谷歌网站内容(包括搜索结果、谷歌应用程序等)做了一个完全的备份,用户可以通过访问谷歌镜像站点来获取Google搜索结果或使用Google的其他应用程序。…查看详情
- 注册商标能一样吗?可在不同类别注册相同商标
在这个商标注册成功一天比一天难的今天,在这个最容易因商标相似或相同而被驳回的今天,注册商标能一样吗?答案是,能。具体为什么可以参考《商标法》中的规定。 图片来源于网络 注册商标能一样吗?我国《商标法》规定:同他人在同一种商品或者类似商品上已…查看详情
- 微信公众号怎么开通 微信公众号开通方法
现在微信公众号也成为了很多企业引流推广营销的一个阵营,但是对于新手来说微信公众号都不知道怎么注册,下面万商云集小编就给大家来介绍下信公众号开通方法。 第一步:4步完成微信公众号怎么创建 1、打开网页搜索并登录微信公众号平台,在页面的右上方…查看详情
- 跨境电商自建站平台有哪些
如果企业想要得到更好的推广,那么建设网站就是首选。每一家企业所销售的产品是不一样的,有些企业是属于跨境电商,那么在进行网站建设的时候,就应该要注意选择一些比较不错的自建站平台。那么跨境电商自建站平台有哪些呢?这个问题一定是很多的…查看详情
- 全球范围内好用的个人管理软件详情介绍
在中国,我们更多地接触个人时间管理软件或库存软件。然而,很少有用户知道个人信息管理软件。个人信息管理软件的英文名称是pe1onalinformatiomanagement(个人信息管理),简称PIM,它用于管理我们日常生活中的许…查看详情
- 初级会计刷题软件哪个比较好?冬奥会计云课堂好用吗?
根据网上数据显示和综合个人的经历。我比较推荐东奥“会计云课堂”,一款集资讯、学习、商城为一体的移动学习应用产品,给各位考生更优质的课程体验和服务。初级会计刷题软件哪个比较好?备受关注的冬奥会计云课堂好用吗? 冬奥会计云课堂的功能? 有三种形…查看详情
- 视频去马赛克软件有哪些 好用的视频去马赛克软件
现在属于自媒体时代,很多的小伙伴也选择自媒体创业,这个时候视频处理就是很麻烦的事情了,很多的视频会带上马赛克的,下面万商云集小编给大家来详细介绍一下视频去马赛克软件有哪些 好用的视频去马赛克软件这一块的内容。希望能帮助到大家,。 1.完美…查看详情
- 矿泉水品牌有哪些 2022矿泉水品牌排名
随着中国经济社会的发展,人们生活水平的提高,人们消费的品牌意识越来越强。重视品牌,反映了消费者生活理念的转变。同质同价的矿泉水,消费者更青睐品牌产品。那么国内知名常见的饮用矿泉水中,下面万商云集小编给大家来详细介绍一下矿泉水品牌有哪些 …查看详情
猜你喜欢
最新文章
扫码二维码
立即领取《千元实战营销秘籍》
还可免费试用营销管理系统
*如有疑问,请随时拨打免费咨询热线:400-0033-166
服务时间:8:30-18:00
软件企业
认定号:川RQ-2018-0216
高新技术企业
认定号:GR201951001121
关注微信公众号
和10万中小企业共同成长
扫码下载APP
享全方位服务一触即达
Copyright © 2004-2022 万商云集(成都)科技股份有限公司 版权所有 蜀ICP备12001963号-2 川公网安备 51010402000322号
快速找产品
找一找哪款产品适合您?
咨询热线:400-0033-166
免费查找信息保护中请放心填写-
-
电话沟通
在线咨询
获取方案
下载APP
官方微信
扫码下载APP
全方位服务一触即达
关注万商云集
和10万中小企共成长
TOP
企业首选的数字选用平台