分布式聊天服务器 Tim

Apache
Google Go
跨平台
2016-09-09
donnie-wu

Tim是一个分布式聊天服务器,采用go语言开发,有很好的并发支持与良好的性能。

1.支持im的基本功能。
2.支持群聊。
3.支持用户状态信息推送,"在线","离开"等。
4.支持消息回执.消息不丢失。
5.支持离线信息,聊天信息等存储与拉取。
6.通过协议拓展,可以支持视频,音频等通讯。
7.支持心跳检测异常断开的客户端,检测客户端验证超时等。
8.支持可配置的同一账号多客户端同时登陆。
9.可以配置关联其他数据库用户系统,tim可以独立于业务之外。
10.支持无数据库模式,此模式无法保存数据。
11.支持自定义消息类型,如发送位置,分享购物信息等。
12.支持分布式部署,服务器横向拓展。

目前实现的客户端有java,golang,Obj-C,由于使用thrift作为传输协议,开发相对简单许多,大部分只是简单接口调用即可,协议拓展也相对容易许多。

实际应用场景:已在公司上线使用,原使用阿里悟空即时通讯,由于需求的增加,及部分消息类型需要定制,后来改用了tim即时通讯,基本可以满足当前以及以后的拓展需求。

支持分布式部署是tim的重要功能也是许多使用im的开发者关心的问题。经过一段时间的思考,决定采用最简单有效的方式:tim的集群非常简单,只需额外提供一个redis服务即可,每个tim节点会从redis服务上读取其他tim节点的信息,使用thrift协议在服务器之间进行信息交互。tim与redis的交换也非常简单,存,读,删,除redis命令以外如果还有逻辑,则采用lua完成。集群的数量没有限制,理论上可以无限的扩展。

tim服务器启动时需要指定配置文件
如 tim  f  tim.xml  d  debug   c cluster.xml   
f后跟基本配置文件tim.xml    d后跟日志打印级别debug,info,warn,error等,可参考github.com/donnie4w/go-logger项目     c后跟集群文件cluster.xml

protocols文件夹中有几门语言的thrift协议,通过这协议可与服务器通信,通讯流程请在doc中查阅.

tim即时通讯项目虽然已经投入使用,但是目前的改动还是比较大,项目尚在不断完善当中!有任何建议或意见请随时email给我:donnie4w@gmail.com .谢谢!

体验demo
另外tim提供了windows环境的两个可执行文件,有兴趣的人可以玩一下,server.exe与client.exe 。启动请看命令说明,主要是用户登录发送信息,状态信息等简单的体验。没有上下线的通知是由于用户关系没有建立。

加载中

评论(3)

ATBBE
ATBBE
案例分析是否可以为社群和社区分享呢?
_
_wangzhilin
golang thrift最多支持多少并发量?
zzuqiang
zzuqiang
看起来很强大,赞一个! #Tim#

分布式即时通讯服务 Tim 1.1.0 发布

Tim version 1.1.0 更新说明 1.修复了部分bug 2.增加了对hbase存储的支持,聊天消息可以存储的hbase中 对消息量比较大的服务,可以使用Hbase存储数据,hbase版本要求0.98以上,需开启hbase的t...

2016/10/24 11:48

即时聊天服务器 Tim 1.0.1 发布

即时聊天服务器 Tim 1.0.1 版本发布了,更新内容如下: 1.修复了部分bug以及部分功能优化 2.增加了TLS安全传输协议 3.golang客户端timgo https://github.com/donnie4w/timgo java客户端 atim...

2016/09/22 01:33

没有更多内容

加载失败,请刷新页面

没有更多内容

暂无问答

四轴飞控系列-电机PWM控制驱动

四轴飞控系列-电机PWM控制驱动原理

2016/10/19 17:41
76
0
四轴飞控系列-电机PWM控制

四轴飞控系列-电机PWM控制驱动

2016/10/19 17:50
55
0
qt小车

#include "stm32f10x.h" #include <stdio.h> void NVIC_Configuration(void); void GPIO_Configuration(void); void EXIT_Configuration(void); void TIM_Configuration_PWM_TIM1(void); voi...

04/09 16:56
0
0
STM32 基本定时器

1. STM32的Timer简介 STM32中一共有11个定时器,其中2个高级控制定时器,4个普通定时器和2个基本定时器,以及2个看门狗定时器和1个系统嘀嗒定时器。其中系统嘀嗒定时器是前文中所描述的SysTi...

2013/04/24 14:20
1K
0
stm32 通用定时器使用

介绍stm32 通用定时器使用,PWM模式和简单的使用。

2015/09/07 20:41
357
0
DAC

国电临近,总结一下之前写过的一些程序和电路。时间不多,只能抽空写了,等闲的时候再一并写好,以飨读者。 STM32F103VCT6自带两个12位DAC,DAC的转换速度一直没有查到,网上有人说是1MHZ的频...

2016/03/25 11:39
46
2
STM32 之定时时间计算

我是最棒的

2015/07/15 13:39
255
0
DefineDosDevice设备名欺骗

首先来Windows下编译运行下面这一段代码 #include "windows.h" #include<stdio.h> int main() { BOOL ret; ret=DefineDosDeviceA(DDD_RAW_TARGET_PATH,"P:","\\GLOBAL??\\C:\\Windows"); //...

2018/07/06 18:03
79
0
PyCharm下部署【变饼档】教程

#pychram下部署【变饼档】教程 一些Django入门者,需要用该网站作为Dome来练习,下载完程序之后不知道在本地如何运行,本教程作为0基础进行介绍 下载网站程序 点击这里进入网站源码的下载地址...

04/22 13:06
0
0
简介Lucene2.0中Query

基本流程 1、 初始化IndexSearcher :Searcher searcher = new IndexSearcher(indexDir);//indexDir为索引存放路径 2、 生成Query对象: QueryParser类的parse()方法返回Query类形对象 3、 使用...

2012/03/27 18:01
33
0

没有更多内容

加载失败,请刷新页面

返回顶部
顶部