`
wusuoya
  • 浏览: 643112 次
  • 性别: Icon_minigender_2
  • 来自: 成都
社区版块
存档分类
最新评论

网站加速--动态应用篇 (下)

 
阅读更多

--提升性能的同时为你节约10倍以上成本
From: http://blog.sina.com.cn/iyangjian


五, Memcache & Mysql 常用场景案例

 

 

 

经典篇:

 


更新数据:
全局MC,然后再写DB。

读数据:
先读MC,命中返回数据。不命中则读DB,更新到本地MC,然后返回数据。

 


杨建:网站加速--动态应用篇 <wbr>(下)

 

(这几个逻辑图由kinggen同学提供,看起来比文字直观多了,感谢一下)

 


为什么更新数据写全局MC,而读数据不命中只写本地MC?
因为更新数据写全局保证了只要MC中cache存在则肯定是最新的,要么就不存在。不存在的情况可以从DB中补充。

如果更新数据和不命中的情况下都只写本地MC会有什么后果?
因为MC不会主动获得数据更新,如果更新数据不写全局,会造成其他IDC的cache在失效以前仍然是旧的。出现数据不同步的现象。

进阶篇

 


这里是在动态数据中引入静态数据的last modify特性,以使得在动态应用中可以返回HTTP 304状态。只比较最后更新时间便可以做出判断,减少后续逻辑处理以及数据内容传输,快速做出响应。对于读多,写少的项目,意义巨大。

对于js调用的部分,并不等同与刷新,要想让每次都产生请求,而且还带If-Modified-Since过去,必须加个max-age=1。只能精确到1秒。

更新数据:
将数据和LM写到全局MC,然后将数据写到DB,不用把LM也写入,LM只存在于MC中。

 


杨建:网站加速--动态应用篇 <wbr>(下)


读数据:
如果MC中存在LM: 比较浏览器请求带过来的LM, 大于等于MC中LM则直接返回304。否则返回数据和最新的LM。
如果MC中不存在LM:把当前的响应时间作为LM存在本地MC中,然后返回数据和此LM。

 


杨建:网站加速--动态应用篇 <wbr>(下)

 

 

 

 

 

 

 

杨建:网站加速--动态应用篇 <wbr>(下)


返回数据方法同经典篇里的读数据。取时间请用 $_SERVER['REQUEST_TIME']。
LM的cache时间可以设置的尽量长些,比如一个月。

 

 

 

 

 

PHP中动态数据使用Last-Modified加速原理详细说明:
动态应用项目中充分利用LM来加速响应,减少逻辑处理以及数据传输。
最初考虑是用etag实现,引入这一机制并不仅仅是为了节约带宽。它还用来减化应用程序逻辑。比如正常取一个数据,需要取好几个表的东西,大概消耗 200ms。如果我把etag作为数据版本来用,只需要取memcache里的版本号判断一下,对于大多数用户来说,都没更新数据,就不用走后面的判断 了,直接返回304状态。但是IE6里,如果同时使用gzip,又使用etag,etag就会失效。这是ie6的bug,没有遵守http 1.1。

 

现在使用方法,把数据最后更改时间戳作为版本。模拟静态数据使用Last-Modified 。这样做的缺陷是,单位只能精确到秒,如果一秒内做多次修改,将不能区分。不过对我们目前应用来说,精确到一秒已经足够用了,用户的动作没那么快。另外, 还有一个细节,将决定这个机制能否应用在我们的项目中。我们既要使用缓存,又要其他任终端,或者浏览器通过js拿数据的时候立刻拿到最新的。大家知道,如 果你使用了Last-Modified,通过js在当前浏览器下再次取数据的时候,浏览器不会发起任何请求,新数据当然无从拿到。如果能让浏览器发送请求 的时候带上If-Modified-Since,又能每次都让浏览器产生请求,便能解决问题。
于是,我们通过php输出数据的时候同时使用这样的两个头信息,便达到了目的。

 

Cache-Control: max-age=1

 

Last-Modified: Tue, 11 May 2010 10:58:11 GMT

这样做的假设是:用户点一个组合查看数据,然后用户在手机上添加一个股票信息,然后用户切到了别的组合,然后又切回这个组合查看数据,这4个动作不可能在同一秒内完成。我反正是做不到那么快,超人例外。

分享到:
评论

相关推荐

    F5-BIG-IP-LTM-zh.pdf

    - **动态比率**:根据服务器的实际性能动态调整权重。 ##### 4.2 会话持久性机制 为了保证用户体验的一致性,LTM 提供了多种会话持久性机制: - **源地址散列**:根据客户端的 IP 地址哈希结果来选择服务器。 - *...

    IOS软件开发-Objective-C-UI高级应用(1).ppt

    本篇文章将深入探讨在Objective-C中如何进行UI高级应用的开发,包括真机调试、集成照相机、相册、短信和邮件功能,以及利用加速计进行动态交互。 首先,要进行真机调试,开发者需要在Apple的开发者网站...

    中信证券-互联网研究之汽车篇:加速触网的汽车行业.pdf

    汽车垂直网站通过提供信息透明度,帮助消费者做出更明智的购买决策,同时OEM和经销商也在积极探索汽车电商模式,如C2B的大数据应用和二手车市场。 3. 移动互联与高效用车:基于位置信息的O2O服务。滴滴打车、快的...

    三菱FR-A700变频器使用手册(应用篇)

    本文主要介绍三菱FR-A700系列变频器在应用方面的一些详细说明。FR-A700变频器是三菱电机推出的一款高功率变频器,广泛应用于工业领域中各类机械设备的速度控制。它能够有效地提升工业自动化水平,改善机械设备的运行...

    2021年网站优化-SEO总结-核心技术.pdf

    SEO,即搜索引擎优化,是提升网站在搜索引擎中自然排名的关键技术。在2021年的SEO总结中,我们可以...这些是2021年SEO总结中的核心技术要点,通过理解和应用这些知识,可以有效提升网站在搜索引擎中的可见性和吸引力。

    cudnn-windows-x86-64-8.6.0.163-cuda11-archive.zip

    本篇文章将围绕"cuda11-archive.zip"中的"CUDNN-windows-x86-64-8.6.0.163-cuda11-archive"进行详细的阐述,主要涉及CUDNN的版本信息、系统需求、安装步骤以及在Windows平台上的实际应用。 CUDNN 8.6.0.163是针对...

    图片站下载站之OSS应用篇

    阿里云 OSS 应用篇 在图片站和下载站中,图片和附件的存储问题是一个棘手的难题。随着网站的 büyüklüğü,图片和附件的存储量也在不断增加。如果购买更多的数据盘存储,这将是一笔庞大的开销。另外,使用百度...

    三菱FR-A740变频器使用手册(应用篇)

    使用手册分为基础篇和应用篇,应用篇主要围绕变频器的具体使用环境和使用场景,提供了详细的技术指导。在使用过程中,用户需要根据实际的电机参数和负载特性来合理设置变频器的各项参数,以便更好地发挥变频器的性能...

    learning-opencv-3-0-with-qt-5-ch

    在Windows环境下,可以直接从官方网站下载预编译的动态库文件,然后按照Qt的指引进行集成即可。 ##### Mac下的安装步骤 由于OpenCV没有提供Mac平台的预编译动态库,需要自行编译。使用Mac版本的Qt时,推荐的编译器...

    1.大脚蟹快速开发平台学习教程[一]--环境搭建篇1

    1. **大脚蟹开发环境**:从官方网站下载开发工具包,建议放在D:\Crab或E:\Crab目录下。 2. **文本编辑器**:推荐SublimeText 3.0,尤其是轻便包版,便于不同Windows系统使用。 对于**高级玩家**,可能还需要固件...

    MySQL-5.5.28-winx64安装包以及说明文档

    本篇文章将深入探讨MySQL 5.5.28在Windows x64环境下的安装过程和关键知识点。 首先,安装MySQL-5.5.28-winx64之前,确保你的计算机运行的是64位Windows操作系统,并检查系统是否满足最低硬件要求,包括足够的内存...

    高性能ASP-NET应用程序的探讨与研究共4页.pdf.z

    ASP.NET是由微软公司推出的用于构建动态网站、Web应用和Web服务的开发平台。它提供了一整套强大的工具和服务,帮助开发者快速、高效地创建功能丰富的Web应用程序。 本篇探讨的主题是“高性能ASP.NET应用程序的探讨...

    course_s5_ZYNQ那些事儿-PYNQ实验篇.pdf

    在实际的开发实践中,PYNQ可以用来进行各种硬件加速应用的开发,例如使用USB摄像头进行边沿检测和人脸识别等。这些实验加深了开发者对PYNQ项目中Overlays的应用以及如何将算法移植到Zynq平台上进行加速的理解。 ...

    基于Spring Boot的商城系统的设计与实现(-java-springboot-项目-代码-源码-项目-系统-毕设-网站)

    因此,当代企业纷纷建立自己的网站,借助互联网信息快速传播的特点加速自身发展。企业网站的规划与建设自然而然地成为了多种类型网站规划与建设的典范;企业网站建设的研究课题也自然而然地成为了企业内部及互联网上...

    论文研究-基于MVC的医疗咨询网站设计 .pdf

    总而言之,这篇论文介绍了一种现代信息化背景下医疗网站的构建方式,展示了如何利用MVC模式和相关技术实现一个功能完善的医疗咨询网站,以应对日益增长的互联网医疗需求,并通过实验验证了系统设计的可靠性和稳定性...

    文件滚动-----css

    本篇将深入探讨如何利用CSS实现文件滚动效果,以及相关的技巧和知识点。 1. **CSS 滚动条定制** CSS3 引入了新的属性,如 `scrollbar-color`、`scrollbar-width` 和 `scrollbar-track-color` 等,允许开发者自定义...

    SuperSlide2.1-demo-00.zip

    了解SuperSlide2.1的工作原理后,开发者可以将其应用于各种项目,如产品展示、新闻轮播、网站头部广告等,提升用户体验。 通过研究"SuperSlide2.1-demo-00",我们可以深入理解jQuery插件的设计思路,进一步提升...

    博士论文--信息系统开发

    温浩宇的这篇博士论文全面覆盖了信息系统开发的关键领域,不仅提供了丰富的理论基础,还深入分析了各种开发模式、数据库技术、网络技术、安全技术以及结构设计、XML技术、Web服务、访问控制、工作流管理和商业智能...

    “新资讯”行业系列报告—疫情篇-极光-202005.pdf

    根据提供的文件信息,这份名为“新资讯”行业系列报告—疫情篇-极光-202005.pdf的文件是极光公司发布的,涉及疫情期间的新资讯行业动态。报告中包含了对特定时间段内行业数据的分析,以及对一些关键指标的对比。下面...

    CentOS下Nginx0.8.52-PHP5.3.3-MySQL5.5.6-Memcached1.4.5安装配置优化

    Memcached是一种高性能的分布式内存对象缓存系统,用于加速动态web应用,减轻数据库负载。它通过缓存数据和对象来减少数据库查询的次数,从而降低延迟和提高吞吐量。 1. 安装Memcached ```bash yum install ...

Global site tag (gtag.js) - Google Analytics