今天TJ君要给大家分享的是一个集合各种技术的开源社区平台,Echo
平台使用的主要技术有:SpringBoot + MyBatis + MySQL + Redis + Kafka + Elasticsearch + Spring Security,常见社区平台中应有的帖子、评论、私信、系统通知、点赞、关注、搜索、用户设置、数据统计等模块都可以支持实现。
前后端主要用到的技术栈有:
前端
Thymeleaf
Bootstrap 4.x
Jquery
Ajax
后端
Spring
Spring Boot 2.1.5 RELEASE
Spring MVC
ORM:MyBatis
数据库:MySQL 5.7
分布式缓存:Redis
本地缓存:Caffeine
消息队列:Kafka 2.13-2.7.0
搜索引擎:Elasticsearch 6.4.3
安全:Spring Security
邮件任务:Spring Mail
分布式定时任务:Spring Quartz
日志:SLF4J(日志接口) + Logback(日志实现)
这些技术栈与功能列表的详细对应关系可从下图看出:
TJ君简单看了一下,如果要更进一步详细描述平台已经实现的功能的话,就是:
注册
登录 | 登出
动态生成验证码
记住我
账号设置
修改头像
修改密码
过滤敏感词
前缀树
帖子模块
发布帖子(过滤敏感词)
分页显示所有的帖子
支持按照 “发帖时间” 显示
支持按照 “热度排行” 显示(Spring Quartz)
查看帖子详情
权限管理(Spring Security + Thymeleaf Security)
未登录用户无法发帖
“版主” 可以看到帖子的置顶和加精按钮并执行相应操作
“管理员” 可以看到帖子的删除按钮并执行相应操作
“普通用户” 无法看到帖子的置顶、加精、删除按钮,也无法执行相应操作
评论模块
发布对帖子的评论(过滤敏感词)
分页显示评论
发布对评论的回复(过滤敏感词)
权限管理(Spring Security)
未登录用户无法使用评论功能
私信模块
发送私信(过滤敏感词)
私信列表
查询当前用户的会话列表
每个会话只显示一条最新的私信
支持分页显示
私信详情
查询某个会话所包含的所有私信
访问私信详情时,将显示的私信设为已读状态
支持分页显示
权限管理(Spring Security)
统一处理 404 / 500 异常
普通请求异常
异步请求异常
统一记录日志
点赞模块
支持对帖子、评论/回复点赞
第 1 次点赞,第 2 次取消点赞
首页统计帖子的点赞数量
详情页统计帖子和评论/回复的点赞数量
详情页显示当前登录用户的点赞状态(赞过了则显示已赞)
统计我的获赞数量
权限管理(Spring Security)
未登录用户无法使用点赞相关功能
关注模块
关注功能
取消关注功能
统计用户的关注数和粉丝数
我的关注列表(查询某个用户关注的人),支持分页
我的粉丝列表(查询某个用户的粉丝),支持分页
权限管理(Spring Security)
未登录用户无法使用关注相关功能
系统通知模块
通知列表
显示评论、点赞、关注三种类型的通知
通知详情
分页显示某一类主题所包含的通知
进入某种类型的系统通知详情,则将该页的所有未读的系统通知状态设置为已读
未读数量
分别显示每种类型的系统通知的未读数量
显示所有系统通知的未读数量
导航栏显示所有消息的未读数量(未读私信 + 未读系统通知)
权限管理(Spring Security)
未登录用户无法使用系统通知功能
搜索模块
网站数据统计(管理员专属)
独立访客 UV
支持单日查询和区间日期查询
日活跃用户 DAU
支持单日查询和区间日期查询
权限管理(Spring Security)
只有管理员可以查看网站数据统计
优化网站性能
处理每次请求时,都要通过拦截器根据登录凭证查询用户信息,访问的频率非常高。因此将已成功登录的用户信息在缓存 Redis 中保存一段时间,查询用户信息的时候优先从缓存中取值;若缓存中没有该用户信息,则将其存入缓存;用户信息变更时清除对应的缓存数据;
引入本地缓存 Caffeine,缓存热帖列表和帖子的总数,避免缓存雪崩(这里面还能再加一层二级缓存 Redis)。
本地部署先确保一下环境都已安装 Java 8、 MySQL 5.7、 Redis、 Kafka 2.13-2.7.0、 Elasticsearch 6.4.3
然后修改本地配置文件信息:
application-develop.properties:
MySQL
Spring Mail(邮箱需要开启 SMTP 服务)
Kafka:consumer.group-id(该字段见 Kafka 安装包中的 consumer.proerties,可自行修改, 修改完毕后需要重启 Kafka)
Elasticsearch:cluster-name(该字段见 Elasticsearch 安装包中的 elasticsearch.yml,可自行修改)
七牛云(需要新建一个七牛云的对象存储空间,用来存放上传的头像图片)
logback-spring-develop.xml:
LOG_PATH:日志存放的位置
需要注意的是,每次运行需要打开如下软件:
MySQL
Redis
Elasticsearch
Kafka
另外,还需要建好数据库 greatecommunity,然后依次运行项目 sql 文件夹下的这几个 sql 文件建立数据库表:
同时针对每一个功能模块,平台作者还提供了自己的思维导图,方便用户理解:
例如注册功能
登录登出功能
几乎每个功能都有,也方便小伙伴们进行理解和学习。
最后看下实际的运行效果:
预祝大家学习愉快~~~项目地址如下:
https://github.com/Veal98/Echo
TJ君将之前发过的各种项目及工具进行了整理,收录到了GitHub项目,欢迎各位小伙伴光临Star,地址如下:https://github.com/Wechat-TJ/TJ-WORLD-FORU



