1、本文章仅记录实现聊天功能遇到的一些问题及处理过程,代码网上几乎都有
2、开发环境是基本的ssm框架,集成websocket,无redis、kafka、mq
3、遇到的问题:消息持久化的方式、获取service层失败、消息丢失、两台服务器之间session数据如何共享(取巧)
以下是解决问题方法:
消息持久化:如果是每发送一条消息就往数据插入一次,在并发不高的情况下可以这样做,但是并发比较多的情况下,频繁io,这无疑会对数据库造成很大的压力,所以我在内存中创建一个静态的集合去保存消息记录,每200条保存一次数据到数据库,这样以来,数据库的压力会小很多
获取service失败:手动加载spring的配置文件
消息丢失:由于内存中消息集合是静态的,在别的类中引用这个静态集合,要进行深拷贝
session数据共享:因为本项目无redis、kafka、mq等中间件,所以走了取巧的方式;将所有的聊天请求通过Nginx统一转发到同一台服务器,项目中采用的方式是监听端口号进行实现的