Skip to content

hyacker/muti-livechat

Repository files navigation

muti-livechat

数据交换说明

  • 加入房间
{
  'msgtype': 'join'
  'username': nick
  'payload': 'joined the chat room'
}
  • 发送消息
{
  'msgtype':'text'
  'username': nick
  'payload': message
}
  • 离开房间
{
  'msgtype':'leave'
  'username': nick
  'payload': 'left the chat room'
}
  • 房间用户列表
{
  'msgtype':'nick_list'
  'username': nick
  'payload': [room-nick-lists]
}

redis using

max room number key 'live-chat-sys-max-room'

  • 用于热更新最大房间数

max users per room key 'live-chat-sys-max-room-users'

  • 用于热更新每个房间最大用户数

a set key members-rooms

  • 存储房间名称 通过redis.sadd 添加集合成员

a set key members-[roomname]-users

'members-%s-users' % (room)
  • 存储一个房间下的用户名称, 通过redis.sadd 添加集合成员

key [client_id]+'room'

  • 用于session id 关联房间名称,key : [client_id]+'room' ,value : roomname

key [client_id]+'nick'

  • 用于session id 关联用户名称,key : [client_id]+'nick' ,vaulue : nickname

PUB/SUB channel

  • 使用房间名称做 发布订阅channel名,解决多房间管理下消息分组广播问题

API 认证

  • 提供两种认证模式
  • 登录第三方如weibo 授权认证模式,采用oauth2协议,通过第三方登录,用户授权后,返回access_token 给客户端,客户端携带asses_token请求服务
  • 使用用户名,密码登录 账户认证系统,成功后返回token给客户端,客户端携带asses_token请求服务

About

a chat with muti-room use tornado,websocket,redis

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published