tigase源码学习杂记-AbstractMessageReceiver

前言

废话,最近把工作中用的基于XMPP协议的经典开源框架又读了一遍,整理一下其优秀的源码学习记录。

概述

AbstractMessageReceiver是tigase核心组件MessageRouter、SessionManager的抽象父类,是tigase消息接收器的抽象。AbstractMessageReceiver使用的是模板的设计模式。对消息接收的基础封装。

类图整体框架分析

类图

抽象接收器主要的实现的核心接口是MessageReceiver接口,该接口定义了接收消息的主要的接口,MesageReceiver接口的核心就是管理路由RegexRouting和往队列中添加数据包操作(addPacket)。AbstractMessageReceiver类实现了接口的所有方法,并向子类提供一个processPacket(Packet)方法进行自定义实现。所以MessageRouter和SessionManger都是重写processPacket(Packet)实现对接受到的消息进行自定义的处理。

其他的接口和类的简介:

  • BasicComponent:全局组件化类的定义实现,tigase官方的全局组件化和可扩展都是基于这个类的实现。后面专门会有一篇文章进行介绍。
  • PacketWriterWithTimeout:相应带超时时间的一个接口定义
  • StatisticsContainer: 统计接口的定义,不是核心,暂时不作为学习的重点

核心数据结构及线程模型分析

基本数据结构介绍

数据和线程模型主要是基于四个成员变量out_queues、in_queues、threadsQueueIn、threadsQueueOut 围绕进行的。其中out_queues、in_queues两个成员变量是两个处理Packet的优先级队列的列表。threadsQueueIn、threadsQueueOut是两个QueueListener的双向队列,QueueListener由上面的类可知,是一个包含可以处理Packet的优先级队列线程的内部类,作用是对出入队消息进行监听和处理。

内部线程数据处理模型

内部线程数据处理模型是一个线程对应一个优先级队列进行数据的处理。线程监听到数据对列中有数据就去take(),take()之后根据消息类是IN_QUEUE还是OUT_QUEUE进行不同数据包的处理。线程数据处理模型如下图所示。

线程数据处理模型图

那么线程模型和队列是如何绑定起来的呢?我们通过初始化的源代码进行分析一下。源码如下所示:

java 复制代码
    /**
	 * 开启线程,初始化QueueListener监听线程,绑定线程和对列
	 */
	private void startThreads() {
		...
		//入队(接收)线程(双向对列)为空,初始化操作
		if (threadsQueueIn == null) {
			threadsQueueIn = new ArrayDeque<>(8);
			//创建指定入队线程,默认是1
			for (int i = 0; i < in_queues_size; i++) {
				QueueListener in_thread = new QueueListener(in_queues.get(i), QueueType.IN_QUEUE);

				in_thread.setName("in_" + i + "-" + getName());
				in_thread.start();
				threadsQueueIn.add(in_thread);
			}
		}
		//出队(转发)线程(双向对列)为空,初始化操作
		if (threadsQueueOut == null) {
			//创建指定出队的线程,默认是1
			threadsQueueOut = new ArrayDeque<>(8);
			for (int i = 0; i < out_queues_size; i++) {
				QueueListener out_thread = new QueueListener(out_queues.get(i), QueueType.OUT_QUEUE);

				out_thread.setName("out_" + i + "-" + getName());
				out_thread.start();
				threadsQueueOut.add(out_thread);
			}
		}    
    ...
}

以上代码是接受器启动调用的核心代码(其中省略了一些日志打印和监听相关的非核心代码),核心就是根据优先级队列进行循环遍历,创建对应的监听器,并设置优先级队列给对应的优先级队列。

小结

AbstractMessageReceiver对象是消息接收器的核心实现,模版的设计模式有利于代码的复用,公共代码的抽象,1对1的线程队列数据处理模型充分利用多线程的优势,并发的处理数据,优先级队列保证了数据处理的顺序性。

相关推荐
躺平大鹅2 小时前
Java面向对象入门(类与对象,新手秒懂)
java
初次攀爬者2 小时前
RocketMQ在Spring Boot上的基础使用
java·spring boot·rocketmq
花花无缺2 小时前
搞懂@Autowired 与@Resuorce
java·spring boot·后端
Derek_Smart4 小时前
从一次 OOM 事故说起:打造生产级的 JVM 健康检查组件
java·jvm·spring boot
NE_STOP5 小时前
MyBatis-mybatis入门与增删改查
java
孟陬8 小时前
国外技术周刊 #1:Paul Graham 重新分享最受欢迎的文章《创作者的品味》、本周被划线最多 YouTube《如何在 19 分钟内学会 AI》、为何我不
java·前端·后端
想用offer打牌8 小时前
一站式了解四种限流算法
java·后端·go
华仔啊9 小时前
Java 开发千万别给布尔变量加 is 前缀!很容易背锅
java
也些宝9 小时前
Java单例模式:饿汉、懒汉、DCL三种实现及最佳实践
java