在ssm項(xiàng)目中使用redis緩存查詢(xún)數(shù)據(jù)的方法
在項(xiàng)目中常常需要后臺(tái)程序的持久層查詢(xún)數(shù)據(jù)庫(kù)來(lái)獲取數(shù)據(jù),然后將數(shù)據(jù)交給服務(wù)層、控制層,最后才交給視圖層。如果數(shù)據(jù)訪問(wèn)緩慢,就會(huì)影響程序的運(yùn)行。
為了加快程序的運(yùn)行,可以將數(shù)據(jù)放入緩存中,包括數(shù)據(jù)緩存和頁(yè)面緩存。
所謂緩存,就是將程序或系統(tǒng)經(jīng)常要調(diào)用的對(duì)象存在內(nèi)存中,一遍其使用時(shí)可以快速調(diào)用,不必再去創(chuàng)建新的重復(fù)的實(shí)例。這樣做可以減少系統(tǒng)開(kāi)銷(xiāo),提高系統(tǒng)效率。
其中頁(yè)面緩存主要是oscache,可以整頁(yè)或者指定網(wǎng)頁(yè)某一部分緩存,同時(shí)指定他的過(guò)期時(shí)間,這樣在此時(shí)間段里面訪問(wèn)的數(shù)據(jù)都是一樣的 。
數(shù)據(jù)緩存則比較多,有著名的ehcache,redis,memcached等。
本文主要簡(jiǎn)單的使用Java代碼進(jìn)行redis緩存,即在查詢(xún)的時(shí)候先在service層從redis緩存中獲取數(shù)據(jù)。如果不存在,則再經(jīng)過(guò)dao層從數(shù)據(jù)庫(kù)中獲取,最后將查詢(xún)到的數(shù)據(jù)緩存到redis中;如果存在,直接從redis緩存中讀取,并交給controller層。
xml配置:
<bean id="poolConfig" class="redis.clients.jedis.JedisPoolConfig"> <property name="maxTotal" value="${redis.maxTotal}"></property> <property name="maxIdle" value="${redis.maxIdle}"></property> <property name="testOnBorrow" value="${redis.testOnBorrow}"></property> <property name="maxWaitMillis" value="${redis.maxWaitMillis}"></property> </bean> <!-- jedis客戶端單機(jī)版 --> <bean id="jedisPool" class="redis.clients.jedis.JedisPool"> <constructor-arg name="poolConfig" ref="poolConfig"></constructor-arg> <constructor-arg name="host" value="${redis.hostName}"></constructor-arg> <constructor-arg name="port" value="${redis.port}"></constructor-arg> </bean> <!-- jedis集群版配置 --> <bean id="jedisCluster" class="redis.clients.jedis.JedisCluster"> <constructor-arg name="poolConfig" ref="poolConfig"></constructor-arg> <constructor-arg name="nodes"> <set> <bean class="redis.clients.jedis.HostAndPort"> <constructor-arg name="host" value="127.0.0.1"></constructor-arg> <constructor-arg name="port" value="7001"></constructor-arg> </bean> <bean class="redis.clients.jedis.HostAndPort"> <constructor-arg name="host" value="127.0.0.1"></constructor-arg> <constructor-arg name="port" value="7002"></constructor-arg> </bean> <bean class="redis.clients.jedis.HostAndPort"> <constructor-arg name="host" value="127.0.0.1"></constructor-arg> <constructor-arg name="port" value="7003"></constructor-arg> </bean> <bean class="redis.clients.jedis.HostAndPort"> <constructor-arg name="host" value="127.0.0.1"></constructor-arg> <constructor-arg name="port" value="7004"></constructor-arg> </bean> <bean class="redis.clients.jedis.HostAndPort"> <constructor-arg name="host" value="127.0.0.1"></constructor-arg> <constructor-arg name="port" value="7005"></constructor-arg> </bean> </set> </constructor-arg> </bean> [java] view plain copy java調(diào)用 //service層查詢(xún)時(shí)代碼 @Autowired private JedisClient jedisClient; @Override public List<User> list() { // TODO Auto-generated method stub try { String json = jedisClient.hget("user", "list"); if (StringUtils.isNotBlank(json)) { List<User> users = JsonUtils.jsonToList(json, User.class); return users; } } catch (Exception e) { e.printStackTrace(); } //使用持久層查詢(xún)數(shù)據(jù)庫(kù) List<User> list = userMapper.list(); try { jedisClient.hset("user", "list", JsonUtils.objectToJson(list)); } catch (Exception e) { e.printStackTrace(); } return list; }
總結(jié)
以上所述是小編給大家介紹的在ssm項(xiàng)目中使用redis緩存查詢(xún)數(shù)據(jù),希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
相關(guān)文章
RedisTemplate中boundHashOps的使用小結(jié)
redisTemplate.boundHashOps(key)?是 RedisTemplate 類(lèi)的一個(gè)方法,本文主要介紹了RedisTemplate中boundHashOps的使用小結(jié),具有一定的參考價(jià)值,感興趣的可以了解一下2024-04-04redis如何設(shè)置database個(gè)數(shù)
這篇文章主要介紹了redis如何設(shè)置database個(gè)數(shù)的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-09-09通過(guò)實(shí)例解析布隆過(guò)濾器工作原理及實(shí)例
這篇文章主要介紹了通過(guò)實(shí)例解析布隆過(guò)濾器工作原理及實(shí)例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-11-11Redis基本數(shù)據(jù)類(lèi)型Set常用操作命令
這篇文章主要為大家介紹了Redis基本數(shù)據(jù)類(lèi)型Set常用操作命令,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-05-05詳解利用redis + lua解決搶紅包高并發(fā)的問(wèn)題
本篇文章主要介紹了利用redis + lua解決搶紅包高并發(fā)的問(wèn)題 ,詳細(xì)的講訴了需求分析和方案,有興趣的可以了解一下。2016-11-11生產(chǎn)redisson延時(shí)隊(duì)列不消費(fèi)問(wèn)題排查解決
這篇文章主要為大家介紹了生產(chǎn)redisson延時(shí)隊(duì)列不消費(fèi)問(wèn)題排查解決,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-09-09