此前一直不知道缓存的具体实现,只知道是把数据存储在内存中,以便下次直接从内存中读取。对于缓存的使用也没有概念,觉得缓存技术是一个比较”神秘陌生“的领域。但最近要用到缓存技术,发现还是很有必要一探究竟的。
缓存技术使用背景:一般来说,对于web项目,如果我们要什么数据直接jdbc查库好了,但是在遇到高并发的情形下,不可能每一次都是去查数据库,因为这样在高并发的情形下显得不太合理——频繁地与数据库交互不是件好事儿,除了在并发情况不是很多的情况下或者没有并发的情况下。我们可以找到一个解决方案:那就是第一次去查库,把查询到的数据缓存到内存中(用key来指定该数据),下次再到这一步时,判断查询条件是不是一样,一样的话,直接从内存中取;不一样则去查库,并把结果缓存起来以便下次使用……
这样做的好处,就是减少了与数据库的交互。。
开始使用oscahe缓存技术来探讨吧。这里我用到了oscache.jar包,反编译该jar,找到一个缓存管理的核心类GeneralCacheAdministrator.java,这个类负责创建、销毁、操作缓存Cache对象。这个类extends了一个基类AbstractCacheAdministrator,这个基类有以下一些基本属性:
// 缓存的内存 public static final String CACHE_MEMORY_KEY = "cache.memory"; // 缓存容量(可以容纳的key-value对数) public static final String CACHE_CAPACITY_KEY = "cache.capacity"; //缓存的算法 public static final String CACHE_ALGORITHM_KEY = "cache.algorithm";
看到GeneralCacheAdministrator类里面有些关键的方法:
//得到缓存 public Cache getCache() { return this.applicationCache; } //从缓存中删除内容 public void removeEntry(String key) { getCache().removeEntry(key); } //从缓存中得到内容 public Object getFromCache(String key) throws NeedsRefreshException { return getCache().getFromCache(key); //取消缓存的更新 public void cancelUpdate(String key) { getCache().cancelUpdate(key); } //刷新缓存 public void flushEntry(String key) { getCache().flushEntry(key); } //刷新某组缓存 public void flushGroup(String group) { getCache().flushGroup(group); }
……
还有很多方法,只不过这几个方法用得比较普遍,从代码来看也比较好理解它们的作用。
如何在项目中使用oscahe缓存?
为了能够在web项目中更好地使用oscahe,首先配置是必不可少的:
进一步看GeneralCacheAdministrator.java类的构造方法:
private Cache applicationCache = null;
public GeneralCacheAdministrator()
{
this(null);
}
public GeneralCacheAdministrator(Properties p)
{
super(p);
log.info("Constructed GeneralCacheAdministrator()");
createCache();
}
public Cache getCache()
{
return this.applicationCache;
}
private void createCache()
{
log.info("Creating new cache");
this.applicationCache = new Cache(isMemoryCaching(), isUnlimitedDiskCache(), isOverflowPersistence(), isBlocking(), this.algorithmClass, this.cacheCapacity);
configureStandardListeners(this.applicationCache);
}
我们肯定选带参数的构造了,因为要指定一些必要的属性。。而通过createCache()方法可知,要构建一个缓存对象,可指定一些基本的属性。
<bean id="sysCacheOscache" class="com.opensymphony.oscache.general.GeneralCacheAdministrator" scope="singleton" destroy-method="destroy"> <constructor-arg index="0"> <props> <prop key="cache.memory">true</prop> <prop key="cache.capacity">600</prop><!-- 缓存元素个数最大值 --> <!-- 缓存元素超过最大值,采用先进先出(first int first out)算法移除 --> <prop key="cache.algorithm">com.opensymphony.oscache.base.algorithm.FIFOCache </prop> </props> </constructor-arg> </bean>
注意:
1)数据库数据更新时,别忘了调用flush缓存的方法;
2)缓存的key设置问题:
——当你需要得到一个集合时,缓存的key可用常量表示(select * from);
——当你根据不同的条件去数据库查到结果不一样时(select xxx, xx, xx… from xx where …),需要注意key不能用常量固定死,否则当你第一次查库时,会把结果缓存到内存中,而当你查询条件变化后,本来结果应该改变(重新查库。。,此时数据结构为查询结果为map,查询条件的组合为key)
3)不要忘记数据库数据改变时,缓存也需要调用flushEntry刷新缓存中的内容,避免缓存中的内容没有及时跟数据同步。调用之后,它会重新查库,把新的结果保存在缓存中。
相关推荐
3. **数据库交互**:使用MySQL数据库进行数据存储,C#后端通过ADO.NET或其他ORM框架与数据库进行连接和通信。 理解这些核心概念和技术,对于开发一个完整的Web应用程序至关重要。无论是前端的用户交互,还是后端的...
"带有缓存功能的mysqli数据库操作类"是一个专门为PHP设计的实用工具,它将MySQLi数据库连接与缓存机制相结合,旨在优化数据库查询,减少不必要的数据库交互,从而提升整体性能。 MySQLi(Improved MySQL)是PHP中的...
这篇文章描述了Wonderware InTouch软件如何读、写关系数据库数据的步骤。本文以Microsoft Access ...在实际应用中,Wonderware InTouch软件可通过类似步骤实现与其他关系数据库的数据交互,如Oracle、SQL Server等。
前端通过发送Ajax请求,可能使用JSON格式传递数据,与后端接口进行交互,后端再通过SQL语句与数据库进行通信,实现数据的增删改查。数据库管理系统可能包括MySQL、Oracle、SQL Server等,具体选择取决于项目需求和...
在网络游戏的开发和运营中,游戏服务器与数据库的交互是至关重要的环节,它涉及到玩家数据的存储、查询、更新以及游戏逻辑的执行。本资料主要探讨了这一关键领域的技术和实践,下面将对其中的关键知识点进行详细阐述...
本文主要讲解如何使用 Java Web 技术和 Ajax 技术实现三级联动的数据库交互。三级联动是指在一个表单中,选择一个省份,然后根据选择的省份动态加载城市的选项,最后根据选择的城市动态加载县/区的选项。这需要使用 ...
Flex与java和数据库交互的完美文档
本文将介绍数据库交互式SQL工具的应用和实践,以SQL Server 2000查询分析器为例,详细阐述了使用交互式SQL工具进行数据库操作的步骤和技术要点。 一、数据库交互式SQL工具的概述 数据库交互式SQL工具是数据库管理...
Java缓存技术是提高应用程序性能的关键技术之一,它通过存储频繁访问的数据,减少了对慢速资源(如磁盘或远程服务)的依赖,从而提升了系统的响应速度。本篇将深入探讨Java缓存技术的原理、分类以及在不同层次的应用...
ASP.NET (C#) 与 Highcharts 数据库交互是一个关键的技能点,它涉及Web开发中的数据可视化和后端数据处理。Highcharts 是一个流行的JavaScript图表库,用于在网页上创建交互式的图表,而ASP.NET (C#) 则是微软的...
unity数据库与UI的交互。通过sqlite对文件进行增删改查
在本项目中,我们主要探讨的是如何利用EasyUI框架创建一个具有多级菜单功能的树形结构,并且能够与后台数据库进行动态交互。EasyUI是一个基于jQuery的UI库,提供了丰富的组件,包括我们这里用到的树形控件(tree)。...
Java端接收到这个请求后,可以使用Java的 JDBC(Java Database Connectivity)API与数据库交互,将消息存储到数据库中。 数据库连接是Java后端的重要部分。为了与数据库进行通信,开发者通常会使用诸如MySQL、...
解决方案,研究报告,行业报告
基于Web的交互式数据库查询技术是现代互联网应用中的核心组成部分,它允许用户通过Web界面与后台数据库进行实时数据交互,实现数据的检索、更新和管理。这种技术广泛应用于各种在线服务,如电子商务、信息检索系统和...
综上所述,这个压缩包中的内容可能包含了一个使用Java实现的数据库连接池示例,以及如何在JSP中使用这个连接池与数据库进行交互的代码。学习这部分内容有助于提升Java Web开发者对数据库连接管理和性能优化的理解。
2. 批量处理:批量提交SQL语句,减少与数据库的交互次数,显著提升性能。 3. 数据库连接池:通过连接池管理数据库连接,避免频繁创建和关闭连接,降低系统开销。 二、ORM框架优化 1. Hibernate或MyBatis:选择合适...
数据库缓存是一种将经常访问的数据存储在内存中的技术,以减少对硬盘的读取,从而提高数据的访问速度。本文将深入探讨Java与数据库缓存的相关知识点,并结合给定的标签“源码”和“工具”,来讨论其在实际应用中的...
9. **性能优化**:大量数据导入导出时,可能需要批量处理,避免频繁的数据库交互。还可以考虑使用数据库的批量插入功能,或者使用存储过程来提升效率。 10. **测试与调试**:编写单元测试以验证XML解析、数据库操作...