一个简单的Redis结合Spring MVC架构以及实现过程
为了加快开发人员对公司项目的理解、更加容易入手和对公司项目的整体把控。
整体框架
首先介绍公司项目的整体框架,闲话少说,直接上图

整体性能分析
这就是公司的一个整体的架构,为了开发人员对架构的侧重点的把控,接下来先分析一下架构的整体性能并畅谈一下架构的功能扩展分面。
前台项目
还是从前台项目说起吧。毕竟做这么多工作,最终的目的是把公司的产品展示给客户看,给客户更高的用户体验
用了提高前面页面的读取速度,所以设计者采用具有“内存数据库”美誉的Redis数据库,但是Redis的缺点就在于事务的处理和检索。所用设计
者又采用了第三方全文检索来进行弥补。而且这个第三方全文检索的检索速度绝对不是MySQL的检索速度所能比的,至少检索速度在MySQL
检索的数千倍甚至上万倍。
页面缓存
用户访问首先会经过一个页面缓存OSCache如果缓存中已有该页面内容,则直接返回内容给用户,这样极大的减少了服务器的压力。建议接手者
尽量在该块的扩展,这样能极大的减少服务器的压力,并提供非常之高的用户体验。
全文检索&Redis
如果用户的访问访问的内容在OSCache中不存在,也就是访问穿透了页面的缓存,这里首先会走全文检索去检索服务条件的内容再从Redis中取出
相应的内容,通过freemarker静态渲染之后返回给用户。
发布项目
该项目具有极大的扩展性,现在主要是做数据资源的同步,后期可以考虑做静态页面的发布,主要处理运算和IO这一块的功能,最后如果访问量
暴增,可以在这里做MySQL的主从库的同步,真正的实现读写分离。
技术实现分析
该项目主要采用了线程池的技术,主线程不断去扫描gt_template这个数据的表,因为公司员工对后台数据的更新的数据都会被mysql中的触发器给触发到gt_template这个表中,gt_template的数据库的字段如下:
其中的source_id是资源的id,如线路的id或酒店的id,source_type为资源的类型,
主线程一旦扫描到数据就会根据这个资源的类型从线程池中开辟新的线程并选择对应的发布程序进行发布。
发布程序会根据source_id也就是资源的id去MySQL数据库中提取相应的产品,如果产品不存在,则说明该数据被删除不存在了,为了减少脏数据
的存在,所以发布程序也做一次清理的过程,不管该条产品是否在全文检索Solr和非关系性数据库Redis中存在,都做一次清理该产品;如果产品
存在,则应该根据产品的当前状态做及时的处理,如果是发布状态则做如下的操作:1、清理脏数据,直接从全文检索Solr和非关系性数据库Redis
中把该条产品清理掉;2、把最新的数据更新到全文检索Solr和非关系性数据库Redis中。3、从gt_template中删除该条记录。
后台项目
该项目相对比较简单,主要就是采用Spring MVC模式加上mybatis实现的,相信开发人员对此种架构已经是相当的熟悉了,我就不在这里卖弄了,
免得被扔鞋子、臭鸡蛋等。
关于架构的性能就写这么多了,免得大牛们看得不下去了。由于自己知识浅薄,就写到这吧,大牛们轻拍。
一个简单的Redis结合Spring MVC架构以及实现过程的更多相关文章
- Go语言之从0到1实现一个简单的Redis连接池
Go语言之从0到1实现一个简单的Redis连接池 前言 最近学习了一些Go语言开发相关内容,但是苦于手头没有可以练手的项目,学的时候理解不清楚,学过容易忘. 结合之前组内分享时学到的Redis相关知识 ...
- Spring MVC架构浅析
阅读目录 Spring MVC概述 Spring MVC框架的特点 Spring MVC工作原理 Spring MVC概述 Spring的web框架围绕DispatcherServlet设计,Disp ...
- 一个简单可参考的API网关架构设计
网关一词较早出现在网络设备里面,比如两个相互独立的局域网段之间通过路由器或者桥接设备进行通信, 这中间的路由或者桥接设备我们称之为网关. 相应的 API 网关将各系统对外暴露的服务聚合起来,所有要调用 ...
- 演示一个简单的Redis队列
0.Windows Service版下载 https://github.com/rgl/redis/downloads 1.新建一个Console项目 打开Nuget控制台,执行以下命令 Instal ...
- 一个简单的示例在spring boot中实现国际化
最近在网上找了一个有关账单管理的spring boot项目,其中有一部分是涉及显示国际化信息的,即将页面上的中英文进行转换.因为在这之前这部分内容没有接触过,所以在这记录下过程. 中文效果图如下所示: ...
- 一个简单的redis调用类
能只能判断函数的调用规则,容错规则, 例如set函数 set($key, $value, $time = false) 根据time的真假来判断是否使用set,或者是setex函数 get函数 get ...
- Spring MVC 架构的java web工程如何添加登录过滤器
发布到外网的web工程必须添加登录过滤器来阻挡一些非法的请求,即只有登录的用户才能对web工程进行请求,否则无论请求什么资源都需要调整到登录页面进行登录操作.这时就需要用到过滤器,其实非常简单,只需要 ...
- 从一个简单的例子看spring ApplicationContext上下文隔离
前言 某天,浏览博客园的时候,对首页上面的一篇文章,标题为:<<一个普通类就能干趴你的springboot,你信吗?>>,文章链接:https://www.cnblogs.co ...
- 用Nodejs 实现一个简单的 Redis客户端
目录 0. 写在前面 1. 背景映入 2. 数据库选择 3. Nodejs TCP连接 3. 代码编写 4. 实验 5. wireshark 抓包分析 6. 杂与代码 0. 写在前面 大家如果有去看过 ...
随机推荐
- 怎么SDCard上的获取相册照片
private String getRealPathFromURI(Uri contentUri) { Cursor cursor = null; String result = contentUri ...
- PostgreSQL的 initdb 源代码分析之十五
继续分析: if (pwprompt || pwfilename) get_set_pwd(); 由于我启动initdb的时候,没有设置口令相关的选项,故此略过. 接下来: setup_depend( ...
- C语言signal处理的小例子
[pgsql@localhost tst]$ cat sig01.c #include <stdio.h> #include <signal.h> static void tr ...
- Crystal Reports课程01-连接SQL Sever数据库
选择[OLE DB(ADO)] 选择[microsoft DB provider for SQL Sever],点击[下一步] 填写连接的服务器,数据库,用户名,密码等信息,然后点击[下一步] 选择[ ...
- UVA 11990 ``Dynamic'' Inversion 动态逆序对
``Dynamic'' Inversion Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 https://uva.onlinejudge.org/index ...
- POJ1463:Strategic game(树形DP)
Description Bob enjoys playing computer games, especially strategic games, but sometimes he cannot f ...
- 图形化OpenGL调试器 BuGLe [转]
BuGLe 结合图形化的OpenGL调试与选择的过滤器上的OpenGL命令流.调试器可以查看状态.纹理.framebuffers ,着色器,而过滤器允许日志,错误检查,自由相机控制,视频捕捉等. 主页 ...
- Delphi 多文件拖放获取路径示例
unit Unit1;interfaceuses Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms, ...
- Android中this.*与*.this还有*.class的区别是什么?
这些是java的基础知识.首先this代表本类的一个引用,this.*表示调用本类的某个方法,这个时候通常可以省略this:但在内部类中不能省略,否则编译器会认为是内部类的引用,所以要在this前加上 ...
- 为laravel分页样式制定class
做的项目有一个上翻页和下翻页,使用了框架提供的