继“Java开发微信朋友圈PC版系统-架构1.0”之后,debug这段时间日撸夜撸,终于赶在春节放假前给诸位带来了这一系统的架构2.0版本,特此分享给诸位进行学习,以掌握、巩固更多的技术栈以及项目和产品开发经验,同时也为即将到来的金三银四跳槽季做准备!
言归正传,下面仍然以问答的方式介绍下本门课程的相关内容!
(1)问题一:这是一门什么样的课程?
很明显,本门课程是建立在架构1.0,即 第1门课程 的基础上发布的,包含了架构1.0的内容,即它仍然是一门项目、产品实战课,基于Spring Boot2.X + 分布式中间件开发的一款类似“新浪微博”、“QQ空间”、“微信朋友圈”PC版的互联网社交软件,包含完整的门户网前端 以及 后台系统管理端,可以说是一套相当完整的系统!
(2)问题二:架构2.0融入了哪些新技术以及各自有什么作用?
本课程对应着系统架构2.0,即第2阶段,主要目标:基于架构1.0,优化系统的整体性能,实现一个真正的互联网社交产品;
其中,可以学习到的技术干货非常多,包括:系统架构设计、Spring Boot2.X、缓存Redis、多线程并发编程、消息中间件RabbitMQ、全文搜索引擎Elastic Search、前后端消息实时通知WebSocket、分布式任务调度中间件Elastic Job、Http Restful编程、Http通信OKHttp3、分布式全局唯一ID、雪花算法SnowFlake、注册中心ZooKeeper、Shiro+Redis 集群Session共享、敏感词自动过滤、Java8 等等;
A. 基于Elastic Search实现首页列表数据的初始化加载、首页全文检索;
B. 基于缓存Redis缓存首页朋友圈“是否已点赞、收藏、关注、评论、转发”等统计数据;整合Shiro实现集群部署模式下Session共享;
C. 多线程并发编程并发处理系统产生的废弃图片、文件数据;
D. 基于Elastic Job切片作业调度分布式多线程清理系统产生的废弃图片;
E. 基于RabbitMQ解耦同步调用的服务模块,实现服务模块之间异步通信;
F. 基于WebSocket实现系统后端 与 首页前端 当前登录用户实时消息通知;
G. 基于OKHttp3、Restful风格的Rest API实现ES文档、分词数据存储与检索;
H. 分布式全局唯一ID 雪花算法SnowFlake实现朋友圈图片的唯一命名;
I. ZooKeeper充当Elastic Job创建的系统作业的注册中心;
J. 为塑造一个健康的网络环境,对用户发的朋友圈、评论、回复内容进行敏感词过滤;
K. 大量优雅的Java8 Lambda编程、Stream编程;
(3)问题三:系统运行起来有效果图看吗?