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

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

定义

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

比如:Eclipse插件,Linux ; 

架构图

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

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

插件管理

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

插件连接

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

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

插件间通信

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

OSGI

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

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

OSGI框架

请设计一个核心功能稳定适合二开扩展的软件系统_规则引擎_05

OSGI架构图

请设计一个核心功能稳定适合二开扩展的软件系统_规则引擎_06

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

规则引擎

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

工作场景:

请设计一个核心功能稳定适合二开扩展的软件系统_规则引擎_08

工作流程:

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

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

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

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

小结

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

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

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