一个简单的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. 写在前面 大家如果有去看过 ...
随机推荐
- 让div变得大方美观 bootstrap
<div class="panel panel-default "> <div class="panel-heading"> <h ...
- Python requests模块在Windows下安装
发现一个爬虫库太方便了,而且支持python3! 安装方法在http://docs.python-requests.org/en/latest/user/install/#install很详细 只不过 ...
- Debug with jdb
原文地址: http://www.javaworld.com/article/2077445/testing-debugging/debug-with-jdb.html Q: How do you u ...
- 【转】Watir, Selenium & WebDriver
转自:http://watirmelon.com/2010/04/10/watir-selenium-webdriver/ Please also see my new ‘Watir-WebDrive ...
- Codeforces Gym 100571A A. Cursed Query 离线
A. Cursed QueryTime Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/gym/100571/problem ...
- GLSL 基础量定义
GLSL语法跟C语言非常相似: 1.数据类型: GLSL包含下面几种简单的数据类型 float bool :false or ture int 向量: vec {2,3,4} 长度为2, ...
- 动态SQL使用小结
1.什么是动态SQL? 静态 SQL:静态 SQL 语句一般用于嵌入式 SQL 应用中,在程序运行前,SQL 语句必须是确定的,例如 SQL 语句中涉及的列名和表名必须是存在的.静态 SQL 语句的编 ...
- 更新mac自带的python
mac lion自带的python是2.7版本的,有点儿低,要使用一些应用的时候还需要3.3以上的,这时可以用以下的方法更新mac自带的python. 先去python的官网下载最新的python,并 ...
- Panopticon跨平台的逆向工程反汇编工具
http://www.freebuf.com/sectool/104045.html Panopticon 使用GPLv3授权许可,其免费. 项目文档:https://panopticon.re. 问 ...
- pydev+python+Eclipse环境搭建+ 调试快捷键汇总
http://www.cnblogs.com/Bonker/p/3584707.html 编辑器: Eclipse + pydev插件 1. Eclipse是写JAVA的IDE, 这样就可以通用了,学 ...