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的线程队列数据处理模型充分利用多线程的优势,并发的处理数据,优先级队列保证了数据处理的顺序性。

相关推荐
海狸老先生1 小时前
Apache Tomcat样例目录session操纵漏洞解读
java·网络安全·tomcat
Jinkxs3 小时前
基础14-Java集合框架:掌握List、Set和Map的使用
java·list
山烛4 小时前
决策树学习全解析:从理论到实战
人工智能·python·学习·算法·决策树·机器学习
遗憾皆是温柔4 小时前
3.JVM,JRE和JDK的关系是什么
java·开发语言·jvm·面试
洛可可白4 小时前
Spring Boot 应用结合 Knife4j 进行 API 分组授权管理配置
java·spring boot·后端
风已经起了5 小时前
FPGA学习笔记——简单的乒乓缓存(RAM)
笔记·学习·fpga开发
22:30Plane-Moon6 小时前
初识SpringBoot
java·spring boot·后端
黄昏晓x6 小时前
数据结构----排序
java·数据结构·排序算法
97zz6 小时前
项目配置文件正确但是启动失败,报配置文件内容错误或中间件地址与实际不符
java·中间件·springboot