tigase源码学习杂记-组件化设计

前言

tigase官方号称高度抽象和组件化。这篇文章就记录一下我研究组件化的相关设计

概述

我的理解tigase高度组件化是所有的关键的功能的类,它都称之为组件,即只要继承于BasicComponent,它都可以成为组件,BasicComponent类实现了基于组件的实现和抽象了所有组件需要完成的操作和定义。我们自定义组件的时候,只需要定义一个类继承BasicComponent类,然后重写我们的自己需要的方法就行了,加载组件的时候就只需要在配置文件(config.tdsl)中新增一行组件的类信息(如下所示:自定义MyComponent组件)

复制代码
myComponentName (class: tigase.muc.MyComponent) {}

tigase就能利用反射加载我们自定义的组件。那我们就来看窥探一下这个类的基本设计。个人的理解他这样设计的好处是,组件的底层设计全部给我们做好了,我们只需要继承拿来使用就行了,如果需要修改就根据业务需求对组件进行简单的重写就可以快速进行业务逻辑的开发。和模版模式设计有异曲同工之妙。

BasicComponent(tigase-server-module中)继承类图

为了证明我说的只要继承BasicComponent的都叫做组件,我们可以看一下,tigase的核心类基本都是继承自BasicComponent组件。

tigase官方的架构图

tigase的核心类包括:

  • 连接管理器(ConnectionManager):用于处理客户端的各种连接
  • Session管理器(SessionManager):用于管理用户的连接的Session
  • 消息路由器(MessageRouter):用户处理消息各种路由转发等等操作
  • 集群连接管理器(ClusterConnectionManager):用于管理集群相关的连接
  • 群聊组件(MUCComponent): 用户群聊信息
  • 发布订阅组件(PubSub): 用于发布订阅相关功能实现
  • ...

PS(因为tigase是多模块项目,就没有贴MUCComponnet等组件的继承图,但是都是继承了BasicComponent类的)

类图设计&继承关系

BasicComponent设计类图

由图可知,BasicComponent类集多功能于一身,其核心的功能定义是基于ServerComponent接口,定义关于核心的数据包处理,初始化,初始化完成,获取组件信息。其他的接口就接口隔离原则,提供BasicComponent的功能包括:

  • ClusteredComponentIfc接口:提供集群的控制器和断连,连接的处理方法
  • XMPPService接口:提供服务发现相关的功能定义
  • VHostListener接口:提供域名监听相关的功能的定义,包括设置域名管理器等等
  • ConfigurationChangedAware接口:提供监听配置动态修改的功能
  • Initializable接口:提供组件可初始化相关的功能

小结

tigase高度组件化其实就是基于接口隔离原则,将每个组件都需要的功能在BasicComponent类上面实现,如果其他人需要自定义实现组件的话,直接继承BasicComponent类即可。这就是tigase的组件化思想。

相关推荐
列星随旋1 小时前
线段树和树状数组的学习
学习·算法
辰海Coding2 小时前
MiniSpring框架学习-整合 IoC 和 MVC(NPC)
学习·spring·mvc
知识分享小能手4 小时前
Flask入门学习教程,从入门到精通,数据库操作 — 知识点详解与案例代码(4)
数据库·学习·flask
wubba lubba dub dub7505 小时前
第四十八周学习周报
学习
生成论实验室5 小时前
用事件关系网络重新理解AI(三):激活函数、微调与元学习
人工智能·学习·算法·语言模型·可信计算技术
辰海Coding6 小时前
MiniSpring框架学习-为什么一个请求访问 /helloworld,最后能调用到某个 Controller 方法?原始 MVC实现
java·学习·程序人生·spring·mvc
凉、介6 小时前
深入理解 ARMv7-A|异常/中断处理
笔记·学习·嵌入式·arm
wxytxdy6 小时前
通过猜数字游戏学习Shell脚本的分支、循环编写
linux·学习
我想我不够好。6 小时前
观察对方打野的动向,预判下一次gank的时机
学习
java小吕布7 小时前
Hermes Agent:自带学习闭环的开源 AI 智能体,一键部署全平台可用
人工智能·学习·开源