天天看点

IM服务器:我的千万级即时通信服务器集群

01、傻瓜式部署,一键式启动;

02、单机支持10万以上在线用户聊天(8G内存,如果内存足够大,并发量可超过10万);

03、支持服务器集群,集群间高内聚、低耦合,可动态横向扩展IM服务器,最大支持200台IM服务器的集群;

04、高并发、高稳定性;

05、支持群组聊天;

06、IM业务完全独立:只需uid(用户id)和gid(群组id),可方便的将IM业务集成到上层业务中;

07、内置HTTP访问接口,用于查询用户状态(上线/离线);

07、基于websocket协议,轻松实现网页端开发;

09、访问安全支持;

10、服务器体积小,不依赖任何第三方库和中间件,服务器集群只有三个文件,不到500K;

11、提供外部接口用于处理离线消息;

12、开发成本低,基于websocket协议,消息体为json格式,用户可扩展自己的消息字段;

01、实现自主内存管理,避免内存碎片的产生;

02、采用IOCP模型,充分利用CPU多核性能,支持高并发,IO业务处理完全异步;

03、采用“无锁”化设计,IM服务器内部只有一把锁;

04、内部大量采用HASH表进行数据管理,查询速度实现O(1);

05、采用红黑树进行定时器管理;

06、严格的网络异常处理,防止高并发下内存访问异常;

1、imserver.exe

概要介绍:IM通信服务

默认端口:8210

功能说明:

1、转发用户间的点对点消息;

2、转发群组消息;

3、群组的创建、销毁以及将指定用户加入到指定群组;

如果在线用户数量超出单台imserver的配置,则需要建立IM服务器集群,不同的用户会登录在不同的IM服务器上。 在集群模式下,需要importal.exe和improxy.exe程序的支持。

假设一台imserver支持10万用户,你的上层业务需要支持百万级在线聊天,则需要10台IM服务器。此时这10台服务器 的管理和通信需要如下两个服务支持。

2、importal.exe

概要介绍:负载均衡服务

默认端口:8510

1、实时更新集群中所有聊天服务器上的用户状态(在线、离线);

2、提供HTTP接口,用于查询集群中所有IM服务器的地址,以及当前每台服务器上在线用户数;

3、提供HTTP接口,用于查询指定用户的在线状态;

使用说明:

1、上层业务通过“/importal/getimserverlist.do”接口获取集群中所有IM服务器列表;

2、根据当前IM服务器上登录的用户数量,来决定用户登录到哪台IM服务器上;

3、improxy.exe

概要介绍:消息转发服务。

1、连接importal服务,获取集群中所有imserver服务器地址;

2、转发登录在不同imserver服务器上的用户消息和群组消息;

只需一分钟,一个配置项。

1、部署importal服务,双击importal.exe即可。

2、配置imserver上的imconfig.ini文件

通过imconfig.ini配置文件中的PortalServer字段设置portal服务器的地址。如:PortalServer=127.0.0.1:8510。

imserver服务器启动会读取该配置项,并连接到importal服务上。

3、部署improxy服务,双击improxy.exe即可,improxy会通过importal获取所有IM服务器。

注意:imserver、importal、improxy最好分别部署在不同的服务器上。

单机用户5万时的并发演示。

IM服务器:我的千万级即时通信服务器集群

点击此处访问下载地址

继续阅读