利用数据缓存机制提高智能设备应用程序的数据访问性能

转载 2007年09月25日 13:22:00

刚看了 Chris Tacke 的《Improving Data Access Performance with Data Caching》一文,回想起以前做过的一些项目,对数据缓存在提高数据访问性能方面的作用颇有感受,跟大家分享一下。
我们在开发 MIS 项目时,要跟各种业务和数据在打交道。其中数据可以根据它们的用途,分为业务数据和参考数据两种。业务数据是业务的信息载体,如:采购进货单、销售出货单、盘点单等。参考数据是业务数据组成部分,如:度量单位、颜色、城市等。参考数据在英文里面通常叫 Lookup Data 或 Reference Data,它们是在系统中使用频率很高的一类数据。因此,这类数据的访问性能将会影响整个系统的用户体验。那么,如何提高 lookup data 的访问性能呢?
Chris Tacke 在他的文章中分析了三种数据访问方式。前两种访问方式差不多,主要区别在于:第一种在每次访问数据库时都会打开和关闭数据库连接;而第二种是在系统缓存一个数据库连接对象,每次使用后不关闭它。我相信大家都会认为第二种方式在频繁访问数据库时性能更优,因为打开一个数据库连接是比较耗系统资源的。然而结果却让人出乎意料,这两种方式的性能很接近,甚至第二种方式性能还更好。

测试结果1:

Device

Processor

Mean Execution (ms)*

OLDI SAM-L8

800MHz Geode x86

7.5 to 9.5

iCOP eBox 2300

200MHz Vortex86

47 to 52

Dell Axim x51

416MUz Intel PXA270

38 to 62


测试结果2:

Device

Processor

Mean Execution (ms)

OLDI SAM-L8

800MHz Geode x86

7.1 to 14.8

iCOP eBox 2300

200MHz Vortex86

51 to 52

Dell Axim x51

416MUz Intel PXA270

43 to 61


第三种方式利用数据缓存机制,在第一次获取数据时,将数据加载到一个Hashtable中,然后再返回。以后就直接从缓存获取数据。第三种方式的性能跟前面两种相比差了十万八千里呀!

Figure 1

测试结果3:

Device

Processor

Mean Execution (ms)

OLDI SAM-L8

800MHz Geode x86

0.0193 to 0.0201

iCOP eBox 2300

200MHz Vortex86

0.1014 to 0.1164

Dell Axim x51

416MUz Intel PXA270

0.0975 to 0.1437


Chris Tacke 的文章还提供示例代码和PDF格式下载:
Download the Source Code
Download the PDF

另外,Chris Tacke 说他们在那个项目中还开发了一个运行在 Windows CE 的轻量级 ASP.NET Web 服务器,用来展现报表,在后续文章中会详细介绍它的实现,期待ing...  
 

利用数据缓存机制提高智能设备应用程序的数据访问性能

刚看了 Chris Tacke 的《Improving Data Access Performance with Data Caching》一文,回想起以前做过的一些项目,对数据缓存在提高数据访问性能...
  • upto
  • upto
  • 2007年09月24日 20:07
  • 4639

充分利用CPU高速缓存,提高程序效率(原理篇)

提高程序效率应该充分利用CPU的高速缓存。要想编写出对CPU缓存友好的程序就得先明白CPU高速缓存的运行机制。  i5-2400S:       1、有三级缓存分别为 32k(数据、指令缓...
  • huangwenhua5000
  • huangwenhua5000
  • 2014年05月06日 00:19
  • 735

如何提高数据库访问性能

特别说明: 1、  本文只是面对数据库应用开发的程序员,不适合专业DBA,DBA在数据库性能优化方面需要了解更多的知识; 2、  本文许多示例及概念是基于Oracle数据库描述,对于其它关...
  • u010327174
  • u010327174
  • 2014年10月16日 16:35
  • 1796

数据库数据处理性能提升技术

一、数据处理性能存在的问题1、企业的数据都集中存储在数据库中,从海量的数据中查找和定位数据是非常耗时的; 2、数据集中存储后,所有用户都要来访问数据库,当很多用户同时访问数据库时,数据库服务器的负载...
  • dingding_12345
  • dingding_12345
  • 2016年01月07日 10:57
  • 5497

MFC开发智能设备的总结

 原文链接:http://blog.csdn.net/citybug_nj/article/details/2598705 程序中包括四个部分: 系统配置 这个部分用来配置系统中的相关...
  • ljsant
  • ljsant
  • 2016年07月05日 09:55
  • 249

利用 Xerces-C++ 提高 XML 应用程序的性能

随着 Web 服务和面向服务架构(SOA)的出现,XML 已变得非常流行。它对于应用程序之间和 Web 上的数据交换起着非常重要的作用,并且是许多性能关键型场景的基础。 ...
  • ibmjournal
  • ibmjournal
  • 2008年06月20日 19:36
  • 749

提高应用程序的性能

因为处理静态的资产,比如图像、JavaScript和CSS文件的插件,通过调度程序的效率非常低,强烈建议生产符号链接。例如像这样:ln -s app/Plugin/YourPlugin/webroot...
  • nbdzdqvf
  • nbdzdqvf
  • 2014年07月11日 11:56
  • 39

如何提高数据库性能

一个成熟的数据库架构并不是一开始设计就具备高可用、高伸缩等特性的,它是随着用户量的增加,基础架构才逐渐完善。这篇博文主要谈MySQL数据库发展周期中所面临的问题及优化方案,暂且抛开前端应用不说,大致分...
  • wulove52
  • wulove52
  • 2016年09月06日 21:56
  • 2856

数据库索引为何能提高性能

本文只针对mysql进行相关方面的说明。 首先我要问,“数据索引是有序无序的?”。答:“当然是有序的了。” 再问,一个SQL语句可以有几个索引?你先别往下看结果,你这想下,可以使用几个索引...
  • qq_36976949
  • qq_36976949
  • 2016年12月16日 20:25
  • 347

Hibernate提高性能的方法总结

Hibernate 提高性能的方法:(未完) 一、缓存机制:                缓存是介于物理数据源与应用程序之间,是对数据库中的数据复制一份临时放在内存中的容器,其作用是为了减少应用...
  • u014078192
  • u014078192
  • 2014年03月26日 00:35
  • 1034
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:利用数据缓存机制提高智能设备应用程序的数据访问性能
举报原因:
原因补充:

(最多只允许输入30个字)