项目实战之中小网站数据缓存的设计与实现

news/2024/5/11 20:37:16/文章来源:https://blog.csdn.net/joeyon/article/details/46873321

1.背景

传统的基于B/S架构jsp项目一般是这样的:客户端(浏览器)向服务端发送请求,服务端接受请求后,JAVAseverlet或者jsp会从数据库读取数据,在后台拼装好后以HTML的形式传输给前台。这样也很好理解:比如一个用户为了获得一个文章的信息,这些信息一般肯定是在数据库里面读取,毋庸置疑。但是这样做会有一个很明显的问题:用户每次一浏览一篇新闻都会往数据库里面读取一次,即便这个文章更本没有改变!这在有很多访问请求对数据库负载是一个大灾难。


现在网上很大一部分解决方案是将这些页面静态化,每一个页面都生成一个静态的HTML,在每一次请求其实在请求这个HTML文件,不与数据库打交道,当文章有所改变时,相对应的HTML也会改变。这种方法是将数据来源是数据库改变成了磁盘文件,很大一部分减轻。

我们这边的条件是这样的,服务器是在网上买的虚拟主机,其对MYSQL和文件存储都有很大的限制,如下图



2.我们的解决方案

我们是这样考虑的:由于本身文件硬盘大小有限制,而且具体内存服务提供商并无要求,所以我们放弃生成HTML页面的方案,决定设计一套数据在内存里面的解决方案,页面显示的数据全是从内存里面读出来的。




其中AsbPage是一个抽象类,提供了一个抽象方法initData,其功能由具体子类来实现,有子类调用Service将数据保存在dataMap中。

我们设计了一个专门的来管理这些Map的管理类,具体类图如下:



在这个类中管理所有的Page类,并且提供了刷新数据的功能,这个类是随着Spring的启动而启动的,大家都知道Spring在启动的时候默认是单例,并且在内存中已经实例化出来了,这样我们就把初始化数据放在管理类的构造函数里面,当项目启动的时候,内存中已经有这些数据了,在Spring中的配置如下

[html]view plaincopy在CODE上查看代码片派生到我的代码片
  1. <bean id="dataCacheManager" class="com.cqut.cache.DataCacheManager" />  

现在既然已经在内存里面有了,那剩下的问题就是怎么取了。我们在gardenDynamic.jsp这个JSP里面,通过SpringUtilBean容器里面的管理类(DataCacheManager)取出来,然后调用getPageData方法,其中有两个参数,第一个你要去取的哪一个页面,第二个参数是要去取的具体内容,其中第一个数据是在管理类里面设置的,第二个参数在具体的Page页面里面设置的。

[java]view plaincopy在CODE上查看代码片派生到我的代码片
  1. //对推荐阅读和点击排行的数据缓存启动  
  2.     DataCacheManager dm = (DataCacheManager)SpringUtil.getBeanByName("dataCacheManager");  
  3.     //取得gardenDynamic这个页面的recommendDynamic数据  
  4.     List<Map<String,Object>>  infoListTop2 = (List<Map<String,Object>>)dm.getPageData("gardenDynamic","recommendDynamic");  

好了,现在已经大功告成了,可是有人问了,如果后台管理员改变了文章内容但你的内存里面的没有改变啊,问得好,我们的解决方案有两种:

1.定时刷新内存

2.通过事件机制如果有变动则刷新

   第二种方式通过AJAX调用后台方法来刷新,我们项目用的是第一种,我们采用的任务调度框架是quartz ,每6秒来调用一下DataCacheManager 中的reloadData 方法。具体配置如下:


[java]view plaincopy在CODE上查看代码片派生到我的代码片
  1. <bean id="dataCacheManager" class="com.cqut.cache.DataCacheManager" />  
  2.     
  3. <bean name="quartzScheduler" class="org.springframework.scheduling.quartz.SchedulerFactoryBean">  
  4.     <property name="triggers">  
  5.         <list>  
  6.             <ref bean="simpleTrigger" />  
  7.         </list>  
  8.     </property>  
  9.     <property name="configLocation" value="classpath:config/quartz.properties" />  
  10. </bean>  
  11. <bean id="simpleTrigger" class="org.springframework.scheduling.quartz.SimpleTriggerBean">  
  12.     <property name="jobDetail">  
  13.         <ref bean="jobDetail" />  
  14.     </property>  
  15.     <property name="startDelay">  
  16.         <value>0</value>  
  17.     </property>  
  18.     <property name="repeatInterval">  
  19.         <value>6000</value>  
  20.     </property>  
  21. </bean>  
  22.   
  23.   
  24. <bean id="jobDetail" class="org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean">  
  25.     <property name="targetObject" ref="dataCacheManager" />  
  26.     <property name="targetMethod" value="reloadData" />  
  27. </bean>  

这样,我们就完成了从内存读取数据的需求,每一次访问不涉及数据库的读取,远远加大了访问速度

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.luyixian.cn/news_show_809067.aspx

如若内容造成侵权/违法违规/事实不符,请联系dt猫网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

SQL Server数据库版本升级网站

发现了一个SQLServer数据库版本升级的网站 SQLServerCentral – The #1 SQL Server community 进去后在搜索框中输入 SQL Server xxx Build List &#xff08;xxx-版本&#xff09; 以2008r2 为例 最新版本为sp3 10.50.6560 可在帮助-关于 中查看自己的数据库版本 找到需要更…

atitit 破解 拦截 绕过 网站 手机 短信 验证码 之自动获取手机短信方式 attilax 总结

分享一下我老师大神的人工智能教程&#xff01;零基础&#xff0c;通俗易懂&#xff01;http://blog.csdn.net/jiangjunshow也欢迎大家转载本篇文章。分享知识&#xff0c;造福人民&#xff0c;实现我们中华民族伟大复兴&#xff01;atitit.破解 拦截 绕过 网站 手机 短信 验证…

paip 破解网站手机验证码

分享一下我老师大神的人工智能教程&#xff01;零基础&#xff0c;通俗易懂&#xff01;http://blog.csdn.net/jiangjunshow也欢迎大家转载本篇文章。分享知识&#xff0c;造福人民&#xff0c;实现我们中华民族伟大复兴&#xff01;paip.破解网站手机验证码作者Attilax &#…

paip 提升安全 网站登录密码明文传输的登录高危漏洞解决方案

分享一下我老师大神的人工智能教程&#xff01;零基础&#xff0c;通俗易懂&#xff01;http://blog.csdn.net/jiangjunshow也欢迎大家转载本篇文章。分享知识&#xff0c;造福人民&#xff0c;实现我们中华民族伟大复兴&#xff01;paip.提升安全---绝大多数网站的登录高危漏洞…

paip 突破 网站 手机 验证码 的 破解 总结

分享一下我老师大神的人工智能教程&#xff01;零基础&#xff0c;通俗易懂&#xff01;http://blog.csdn.net/jiangjunshow也欢迎大家转载本篇文章。分享知识&#xff0c;造福人民&#xff0c;实现我们中华民族伟大复兴&#xff01;paip.突破 网站 手机 验证码 的 破解 总结 作…

paip 网站扫描安全工具hp WebInspect 使用指南

分享一下我老师大神的人工智能教程&#xff01;零基础&#xff0c;通俗易懂&#xff01;http://blog.csdn.net/jiangjunshow也欢迎大家转载本篇文章。分享知识&#xff0c;造福人民&#xff0c;实现我们中华民族伟大复兴&#xff01;paip.网站扫描安全工具hp WebInspect 使用指…

PAIP WEB程序网站安全扫描检测工具(桌面程序)总结

分享一下我老师大神的人工智能教程&#xff01;零基础&#xff0c;通俗易懂&#xff01;http://blog.csdn.net/jiangjunshow也欢迎大家转载本篇文章。分享知识&#xff0c;造福人民&#xff0c;实现我们中华民族伟大复兴&#xff01;PAIP.WEB程序网站安全扫描检测工具&#xff…

大型网站架构和优化策略和常见处理方案实例

大型在线商务网站的构架设计 本项目是一个在线商品交易平台&#xff0c;平台的主要目的是让企业在平台上发布商品及资讯&#xff0c;用户可以在此平台上购买商品并参与商品的评论。围绕这一目的&#xff0c;系统需要实现商品管理&#xff0c;商品订购&#xff0c;多部门订单处理…

一步步构建大型网站

之前我简单向大家介绍了各个知名大型网站的架构&#xff0c;MySpace的五个里程碑、Flickr的架构、YouTube的架构、PlentyOfFish的架构、WikiPedia的架构。这几个都很典型&#xff0c;我们可以从中获取很多有关网站架构方面的知识&#xff0c;看了之后你会发现你原来的想法很可能…

大型网站的架构设计图

近段时间以来&#xff0c;通过接触有关海量数据处理和搜索引擎的诸多技术&#xff0c;常常见识到不少精妙绝伦的架构图。除了每每感叹于每幅图表面上的绘制的精细之外&#xff0c;更为架构图背后所隐藏的设计思想所叹服。个人这两天一直在搜集各大型网站的架构设计图&#xff0…

国内外大型SNS网站后台架构对比

要问时下什么类型的站点人气最旺&#xff1f;答案当属SNS网站。短短几年的时间&#xff0c;SNS便迅速确立了Web 2.0核心的地位。用户的增长量之快更是让人咂舌&#xff0c;而Facebook访问量首次超越Google的消息也让人觉得SNS的前途不可限量。当然&#xff0c;面对庞大且繁琐的…

各大网站架构总结笔记

各大网站架构总结笔记 记得在大学里不止一次关注网站架构方面的东西了&#xff0c;但每次都是泛泛了解&#xff0c;也没有着重记录&#xff0c;一段时间后对各种架构的思想也就模糊了。这几天不知怎么的又心血来潮&#xff08;可能是快毕业了冲动了&#xff09;想深入了解一下网…

网站启用GZip压缩后,速度快了3倍!

GZip压缩&#xff0c;是一种网站速度优化技术&#xff0c;也是一把SEO优化利器&#xff0c;许多网站都采用了这种技术&#xff0c;以达到提升网页打开速度、缩短网页打开时间的目的。 本文是一篇研究性文章&#xff0c;将通过某个案例来给大家显示网站采用GZip压缩前后的对比效…

中小型网站的缓存策略

在上一篇文章《大型网站系统架构分析》中&#xff0c;介绍了大型网站的系统架构&#xff0c;其中缓存环境非常重要&#xff0c;大型网站往往使用Squid前端缓存服务器群&#xff0c;memcache分布式缓存&#xff0c;负载均衡&#xff0c;CDN等来提升性能。但中小型网站使用这些大…

瞬时响应:网站的高性能架构

什么叫高性能的网站&#xff1f; 两个网站性能架构设计方案&#xff1a;A方案和B方案&#xff0c;A方案在小于100个并发用户访问时&#xff0c;每个请求的响应时间是1秒&#xff0c;当并发请求达到200的时候&#xff0c;请求的响应时间将骤增到10秒。B方案不管是100个并发用户访…

Mysql在大型网站的应用架构演变

本文主要描述在网站的不同的并发访问量级下&#xff0c;Mysql架构的演变,下面分别从不同的角度思考mysql的演变过程.可扩展性架构的可扩展性往往和并发是息息相关&#xff0c;没有并发的增长&#xff0c;也就没有必要做高可扩展性的架构&#xff0c;这里对可扩展性进行简单介绍…

大型网站架构与分布式架构

大型互联网架构 解决问题的通用思路是将分而治之&#xff08;divide-and-conquer&#xff09;&#xff0c;将大问题分为若干个小问题&#xff0c;各个击破。在大型互联网的架构实践中&#xff0c;无一不体现这种思想。 架构目标 低成本:任何公司存在的价值都是为了获取商业利益…

网站分布式架构的演进

来源&#xff1a;知乎 http://www.zhihu.com/question/22764869/answer/31277656首先推荐4本书 大型分布式网站架构设计与实践 http://item.jd.com/11529266.html 大型网站技术架构&#xff1a;核心原理与案例分析 http://item.jd.com/11322972.html 大型网站系统与Java中间件实…

浅谈Web网站架构演变过程及各阶段所用的技术和架构设计

前言 我们以javaweb为例&#xff0c;来搭建一个简单的电商系统&#xff0c;看看这个系统可以如何一步步演变。该系统具备的功能&#xff1a;用户模块&#xff1a;用户注册和管理商品模块&#xff1a;商品展示和管理交易模块&#xff1a;创建交易和管理 阶段一、单机构建网站 网…

大型网站电商网站架构案例和技术架构的示例

大型网站架构是一个系列文档&#xff0c;欢迎大家关注。本次分享主题&#xff1a;电商网站架构案例。从电商网站的需求&#xff0c;到单机架构&#xff0c;逐步演变为常用的&#xff0c;可供参考的分布式架构的原型。除具备功能需求外&#xff0c;还具备一定的高性能&#xff0…