一个简单的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. 写在前面 大家如果有去看过 ...
随机推荐
- Nginx启动停止命令
操作环境是Windows 一.nginx命令:启动nginx 在Windows上安装好nginx后,我们需要启动nginx服务,启动nginx服务的命令行操作主要有两种方式,即 cd D:\opens ...
- APK的目录结构
APK 包含以下内容: 被编译的代码文件(.dex文件) 文件资源(resources) assets. 证书(certificates) 清单文件(maifestfile) assets 文件 li ...
- 【转】单例模式(python/c++)
1. 什么是单例模式(Singleton pattern)? 单例模式是一种常用的软件设计模式.在它的核心结构中只包含一个被称为单例类的特殊类.通过单例模式可以保证系统中一个类只有一个实例而且该实例易 ...
- 详解Android Handler的使用-别说你不懂handler
我们进行Android开发时,Handler可以说是使用非常频繁的一个概念,它的用处不言而喻.本文就详细介绍Handler的基本概念和用法. Handler的基本概念 Handler主 ...
- 利用ajax获取到的网页源码不能执行js代码
今天觉得我的博客中加载腾讯微博的速度很慢,所以就想改写为js,本来以为直接新建一个页面,把获取函数移到新的页面中,原来的页面只要使用xmlhttp去GET一下,然后把div的innerhtml属性等于 ...
- [Angular 2] Understanding OpaqueToken
When using provider string tokens, there’s a chance they collide with other third-party tokens. Angu ...
- mysql router 自动failover测试
mysql router 启动服务文件内容: [root@monitor mysqlrouter]# cat /etc/init.d/mysqlrouter#! /bin/bash## mysqlro ...
- android:layout_weight总有你不知道的用法.
都知道weight是权重的意思. 在布局中起到非常重要的作用. 但是这玩意不能嵌套使用, 而且只能使用在LinearLayout中. 下面说说它的几种用法(以下例子全为横排 注意android:lay ...
- Java_Hbase Timeout issue
设置参数hbase.rpc.timeout <property><name>hbase.regionserver.lease.period</name><va ...
- argparse - 命令行选项与参数解析(转)
argparse - 命令行选项与参数解析(译)Mar 30, 2013 原文:argparse – Command line option and argument parsing 译者:young ...