Tim 分布式聊天服务器 Tim

agolangf • 6306 次点击    
这是一个分享于 的项目,其中的信息可能已经有所发展或是发生改变。
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 。启动请看命令说明,主要是用户登录发送信息,状态信息等简单的体验。没有上下线的通知是由于用户关系没有建立。
授权协议:
Apache
开发语言:
Google Go 查看源码»
操作系统:
跨平台
6306 次点击  ∙  1 赞  
加入收藏 微博
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传