请设计一个核心功能稳定适合二开扩展的软件系统 – 知乎

请设计一个核心功能稳定适合二开扩展的软件系统

图片[1]就去ID网请设计一个核心功能稳定适合二开扩展的软件系统 – 知乎就去ID网97ID网

李福春

好的成长是持续输出!

图片[2]就去ID网请设计一个核心功能稳定适合二开扩展的软件系统 – 知乎就去ID网97ID网

如何设计出核心功能稳定,业务功能不断扩展的软件系统,我想到了微内核架构。

定义

微内核架构又叫做插件架构,是面向功能进行拆分的可扩展架构。

比如:Eclipse插件,Linux ;

架构图

图片[3]就去ID网请设计一个核心功能稳定适合二开扩展的软件系统 – 知乎就去ID网97ID网

图片[4]就去ID网请设计一个核心功能稳定适合二开扩展的软件系统 – 知乎就去ID网97ID网

插件管理

插件注册表机制:名字,位置,加载时机;

插件连接

指的是插件如何连接到核心系统。

图片[5]就去ID网请设计一个核心功能稳定适合二开扩展的软件系统 – 知乎就去ID网97ID网

插件间通信

插件之间是解耦的,插件之间通信必须通过核心系统,核心系统提供插件的通信机制;

OSGI

Open Services Gateway initiative 主动开放服务网关;
OSGi 具备动态化、热插拔、高可复用性、高效性、扩展方便等优点;

最具代表性的是Eclipse的插件,采用的是OSGI规范设计规范。

OSGI框架

图片[6]就去ID网请设计一个核心功能稳定适合二开扩展的软件系统 – 知乎就去ID网97ID网

OSGI架构图

图片[7]就去ID网请设计一个核心功能稳定适合二开扩展的软件系统 – 知乎就去ID网97ID网

图片[8]就去ID网请设计一个核心功能稳定适合二开扩展的软件系统 – 知乎就去ID网97ID网

规则引擎

属于微内核架构的一种实现,执行引擎对应core system核心系统(微内核),执行引擎执行配置好的业务流程,规则,通过这种方式来支持业务的灵活多变。

工作场景:

图片[9]就去ID网请设计一个核心功能稳定适合二开扩展的软件系统 – 知乎就去ID网97ID网

工作流程:

图片[10]就去ID网请设计一个核心功能稳定适合二开扩展的软件系统 – 知乎就去ID网97ID网

对应微内核架构的插件核心:

图片[11]就去ID网请设计一个核心功能稳定适合二开扩展的软件系统 – 知乎就去ID网97ID网

代表产品 jboss drools, 基于 rete算法实现规则引擎,他的规则语言接近编程语言,一般包装成可视化界面来间接生成。

小结

本篇首先定义了微内核架构,即 面向功能拆分的可扩展架构。

以及他的组成部分,即内核和插件。

以及它需要解决的核心问题,插件管理,插件连接,插件间通信;

最后介绍了两种微内核架构,OSGI 和规则引擎 ;

我会持续分享Java软件编程知识和程序员发展职业之路!
原创不易,关注诚可贵,转发价更高!转载请注明出处,让我们互通有无,共同进步,欢迎沟通交流。

发布于 2020-04-27 20:08

程序员

推荐阅读

还没有评论

写下你的评论…

© 版权声明
THE END
喜欢就支持一下吧
点赞14 分享
评论 抢沙发
头像
欢迎您留下宝贵的见解!
提交
头像

昵称

取消
昵称表情代码图片

    请登录后查看评论内容