Xmpp通信模块框架(基于webrtc的libjingle)

 

前言:年总了,针对今年的一些工作进行总结,重新整理了发出来共享讨论。

一、概述

1、背景

提高与tigase通信的稳定性,降低因为代码混乱引起开发难度及开发出现的内测问题BUG等。

现有的xmpp框架使用第三方库libjingle,使用时存崩溃风险;现有的xmpp框架的可维护性低,开发修改存在较大风险。

2、说明

本设计文档作为模块的设计文档,为编码的依据。

二、分析

1、Libjingle库的分析

1)、分析libjingle的库,得出如下类图:

 

 

 

2)、分析相关使用:

l xmpp的所有操作都是放在一个独立现场处理的。XmppThread的消息队列、PresenceReceiveTask是线程安全的;除此之外对外暴露的接口都不是现场安全的。

l 分析发送方式

1、示例PresenceOutTask首先它不是现场安全的,如果使用需要自己加锁。

2、通过XmppThread的消息队列来达到发送的方式。

2、代码中使用存在的问题:

1)、线程对象每次重新删除,容易引起线程出错:XmppThread

2)、线程对象删除后,该对象为空,使用该对象发送消息会崩溃:buzz::XmppClient*

3)、任务不要要自己删除,libjingle会自己删除:buzz::XmppTask

4)、通信模块和业务模块混合在一起,结构不清晰、混乱。如连接模块的连接逻辑、重连逻辑和真正的通信逻辑混杂在一起,已日趋复杂与不可读。

三、设计

1、两层模块,分为通信层和通信相关业务逻辑层。

 

通信层作为通信的基础框架,只做通信相关的处理。

xmpp的业务逻辑层,比如收到的状态维护等。

 

2、通信层(Xmpp Net Module);

通信层只关心与同向相关的内容,不涉及具体业务。

解决问题:

1、通信层的线程不删除。

2、为保证注销之后的发送数据等是正常的,重新创建了底层通信模块。

3、接受任务不自己删除,由底层通信模块删除。

4、发送任务通过线程的消息队列投递发送。

 

3、业务逻辑层处理(Xmpp Logic)

XmppApp:业务逻辑对象与通信层对象转换模块。

ConnManaager:连接管理,连接、断线、重连等。

PresenceManager: 状态管理,状态的发送和其他用户状态变化管理。

MessageManager:消息管理,消息的发送和接受。

IQManagerIQ管理,包括IQACK的注册和IQNOTICE的发送和接受。

 

 

posted @ 2017-01-23 11:28  littlezcb  阅读(1846)  评论(0编辑  收藏  举报