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的组件化思想。

相关推荐
云边散步8 小时前
godot2D游戏教程系列二(4)
笔记·学习·游戏开发
jrlong9 小时前
DataWhale大模型基础与量化微调task4学习笔记(第 2 章:高级微调技术_RLHF 技术详解)
笔记·学习
Darkershadow9 小时前
蓝牙学习之Time Set
python·学习·蓝牙·ble·mesh
好奇龙猫9 小时前
【日语学习-日语知识点小记-日本語体系構造-JLPT-N2前期阶段-第一阶段(9):単語文法】
学习
AI浩9 小时前
约束模型下的目标检测置信学习
学习·目标检测·目标跟踪
m0_7482299910 小时前
ThinkPHP快速入门:从零到实战
c语言·开发语言·数据库·学习
風清掦10 小时前
【江科大STM32学习笔记-04】0.96寸OLED显示屏
笔记·stm32·学习
胡西风_foxww10 小时前
ObsidianAI_学习一个陌生知识领域_建立学习路径和知识库框架_写一本书
人工智能·笔记·学习·知识库·obsidian·notebooklm·写一本书
Haooog10 小时前
AI应用代码生成平台
java·学习·大模型·langchain4j
非凡ghost10 小时前
ShareX(免费截图录屏软件)
windows·学习·软件需求