资讯专栏INFORMATION COLUMN

一个可插拔远程服务框架的诞生

cnio / 1933人阅读

摘要:它是一个非常简单的小框架或者称为微框架也行,其目的很简单快速地将老旧类转变成为远程服务,降低这类工作的难度和门槛。而采用插件的原因则在于分工明确。

这些天因为项目的需要基于Vert.x和PF4J做了一个简单的插件式远程服务框架dfx。它是一个非常简单的小框架(或者称为微框架也行),其目的很简单:快速地将老旧Java类转变成为远程服务,降低这类工作的难度和门槛。

简单到什么程度呢?这么说吧:开发者只要实现一个指定的接口,然后将其打包成一个插件并复制到dfx指定的插件目录之下就ok了(当然,还需要修改对应的配置文件)。

至于为何选定Vert.x为支撑技术,原因在我之前的踩坑记中已经解答。而采用插件的原因则在于:

分工明确。插件开发者只需专注于业务逻辑的开发,不用去为底层各种机制(如断路器,你没看错,dfx管理下的插件天然就具有断路器功能,而插件开发者根本就没有意识到这一点!即使无意间引入了一个慢插件,也不会殃及其他插件。)烦心。

管理的需要。除了功能的扩展性,插件系统带来的一个附加好处就是有效控制了整个系统的代码。即,开发新功能时不需要将整个系统的代码clone得到处都是。从代码安全性上来讲,这无疑是绝佳的选择。同时,这还带来了另一个好处:编译速度的极大改善。要是经历过编译3天才得到一个二机制文件,那你应该明白我在说什么,;)。

对于插件系统,我选择的是PF4J,一个小巧的插件实现。

除了简单和断路器支持,dfx的还支持热更新,只是目前的方式简单粗暴:当发现任意一个变化(conf和插件目录中zip包的变化)时,会重新加载整个服务,即相当于重启。

关于dfx的详细使用和插件的开发,可以从它的README得到更多细节。

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/67993.html

相关文章

  • 基于 Netty 插拔业务通信协议实现「1」协议描述及基本消息对象设计

    摘要:基本消息对象的设计消息对象的设计主要由两部分组成特定数据帧对应的特定消息对象。该类包含上节数据帧主帧及子帧的所有公共信息,仅仅未包含子帧中的数据体信息,该需求由基本消息对象的子类实现。 开发工程中,有一个常见的需求:服务端程序和多个客户端程序通过 TCP 协议进行通信,通信双方需通信的消息种类众多,并且客户端的数量可能有数万个。为此,双方需要约定尽可能丰富、灵活的数据帧「数据包」协议,...

    Barry_Ng 评论0 收藏0
  • Hyperledger Fabric(介绍)

    摘要:比特币和以太币属于一类区块链,我们将其归类为公共无许可的区块链技术。例如,在单个企业中部署时,或由受信任的权威机构运作,完全拜占庭容错的共识可能被认为是不必要的,并且对性能和吞吐量造成过度的拖累。 介绍 一般而言,区块链是一个不可变的交易分类账,维护在一个分布式对等节点网络中。这些节点通过应用已经由共识协议验证的交易来维护分类帐的副本,该交易被分组为包括将每个块绑定到前一个块的散列的块...

    yunhao 评论0 收藏0
  • 基于 Netty 插拔业务通信协议实现「2」特定业务消息对象设计

    摘要:而实际两者之间的通信使用的是基于的自定义二进制数据帧,对象与数据帧之间需进行转换。该类实现了编码解码方法,故可对消息对象进行编码或对数据帧进行解码。该类的静态方法可通过指定功能消息对象生成相应的回复对象。 本文为该系列的第二篇文章,设计需求为:服务端程序和众多客户端程序通过 TCP 协议进行通信,通信双方需通信的消息种类众多。上一篇文章详细描述了该通信协议的二进制数据帧格式以及基本 J...

    Yuqi 评论0 收藏0
  • 基于 Webpack4 插拔式微前端架构 - Puzzle

    项目地址 showImg(https://segmentfault.com/img/remote/1460000019380071); 什么是 Puzzle Puzzle 是基于 Vue 和 Webpack4 实现的一种项目结构;业务模块可以像拼图一样与架构模块组合,形成不同的系统,而这一切都是可以在生产环境热插拔的;这意味着你可以随时向你的系统添加新的功能模块,甚至改版整个系统,而不需要全量替换...

    jsliang 评论0 收藏0
  • Java™ 教程(注解)

    注解 注解(一种元数据形式)提供有关不属于程序本身的程序的数据,注解对它们注解的代码的操作没有直接影响。 注解有许多用途,其中包括: 编译器的信息 — 编译器可以使用注解来检测错误或抑制警告。 编译时和部署时处理 — 软件工具可以处理注解信息以生成代码、XML文件等。 运行时处理 — 可以在运行时检查某些注解。 本课程介绍了可以使用注解的位置,以及如何应用注解,Java平台标准版(Java S...

    econi 评论0 收藏0

发表评论

0条评论

cnio

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<