日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 前端技术 > javascript >内容正文

javascript

深入理解Spring Redis的使用 (一)、Spring Redis基本使用

發(fā)布時(shí)間:2024/1/17 javascript 28 豆豆
生活随笔 收集整理的這篇文章主要介紹了 深入理解Spring Redis的使用 (一)、Spring Redis基本使用 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

關(guān)于spring redis框架的使用,網(wǎng)上的例子很多很多。但是在自己最近一段時(shí)間的使用中,發(fā)現(xiàn)這些教程都是入門教程,包括很多的使用方法,與spring redis豐富的api大相徑庭,真是浪費(fèi)了這么優(yōu)秀的一個(gè)框架。這里,我們就對(duì)比之前對(duì)spring orm中對(duì)hibernate的使用,來(lái)理解使用spring redis的使用。(本文章不做redis基本命令使用的講解)

1. Redis使用場(chǎng)景

Redis是一個(gè)開(kāi)源的使用ANSI C語(yǔ)言編寫、支持網(wǎng)絡(luò)、可基于內(nèi)存亦可持久化的日志型、Key-Value數(shù)據(jù)庫(kù),并提供多種語(yǔ)言的API。

我們都知道,在日常的應(yīng)用中,數(shù)據(jù)庫(kù)瓶頸是最容易出現(xiàn)的。數(shù)據(jù)量太大和頻繁的查詢,由于磁盤IO性能的局限性,導(dǎo)致項(xiàng)目的性能越來(lái)越低。

這時(shí)候,基于內(nèi)存的緩存框架,就能解決我們很多問(wèn)題。例如Memcache,Redis等。將一些頻繁使用的數(shù)據(jù)放入緩存讀取,大大降低了數(shù)據(jù)庫(kù)的負(fù)擔(dān)。提升了系統(tǒng)的性能。

其實(shí),對(duì)于hibernate的二級(jí)緩存,是同樣的道理。利用內(nèi)存高速的讀寫速度,來(lái)解決硬盤的瓶頸。

?

2. 配置使用redis

首先,我們需要引入基本的jar包。maven中的基本引用如下:

    <dependency><groupId>org.springframework.data</groupId> <artifactId>spring-data-redis</artifactId> <version>1.4.2.RELEASE</version> </dependency> <dependency> <groupId>redis.clients</groupId> <artifactId>jedis</artifactId> <version>2.6.2</version> </dependency>

?

然后,在applicationContext中配置如下:

<bean id="poolConfig" class="redis.clients.jedis.JedisPoolConfig"> <property name="maxIdle" value="${redis.maxIdle}" /> <property name="maxTotal" value="${redis.maxActive}" /> <property name="maxWaitMillis" value="${redis.maxWait}" /> <property name="testOnBorrow" value="${redis.testOnBorrow}" /> </bean> <bean id="connectionFactory" class="org.springframework.data.redis.connection.jedis.JedisConnectionFactory" p:host-name="${redis.host}" p:port="${redis.port}" p:password="${redis.pass}" p:pool-config-ref="poolConfig" /> <bean id="stringSerializer" class="org.springframework.data.redis.serializer.StringRedisSerializer"/> <!-- 開(kāi)啟事務(wù),可以通過(guò)transcational注解控制 --> <bean id="redisTemplate" class="org.springframework.data.redis.core.RedisTemplate"> <property name="connectionFactory" ref="connectionFactory" /> <property name="keySerializer" ref="stringSerializer" /> <property name="enableTransactionSupport" value="true" /> </bean>

?

對(duì)于hibernate的配置可知,第一個(gè)poolconfig是對(duì)連接池的配置。包括最大連接數(shù),隊(duì)列數(shù),存活時(shí)間,最大等待時(shí)間等等,還有一些額外的配置,請(qǐng)直接點(diǎn)擊JedisPoolConfig類源碼,進(jìn)行查看。

這些配置的意思如果不明白的話,一定要去把線程池好好學(xué)習(xí)下。

?

第一個(gè)配置是連接工廠,顧名思義,最基本的使用一定是對(duì)連接的打開(kāi)和關(guān)閉。我們需要為其配置redis服務(wù)器的賬戶密碼,端口號(hào)。(這里還可以配置數(shù)據(jù)庫(kù)的index,但是我使用時(shí)候一直使用redis的默認(rèn)數(shù)據(jù)庫(kù),也就是第0個(gè))

最后一個(gè)配置特別重要。這個(gè)類似于spring提供的HibernateDaoSupport。

接下來(lái),全部講解都將圍繞這個(gè)類展開(kāi)。

?

3. RedisTemplate的使用

這個(gè)類作為一個(gè)模版類,提供了很多快速使用redis的api,而不需要自己來(lái)維護(hù)連接,事務(wù)。

最初的時(shí)候,我創(chuàng)建的BaseRedisDao是繼承自這個(gè)類的。繼承的好處是我的每個(gè)Dao中,都可以自由的控制序列化器,自由的控制自己是否需要事務(wù),這個(gè)先不需要了解,跟著我目前的這種配置方法來(lái)即可。

?

template提供了一系列的operation,比如valueOperation,HashOperation,ListOperation,SetOperation等,用來(lái)操作不同數(shù)據(jù)類型的Redis。

并且,RedisTemplate還提供了對(duì)應(yīng)的*OperationsEditor,用來(lái)通過(guò)RedisTemplate直接注入對(duì)應(yīng)的Operation。我們暫時(shí)不講這個(gè)。

?

對(duì)于下面的test1方法,我們暫時(shí)不用考慮,先了解通過(guò)RedisTemplate來(lái)使用connection操作Redis。

Test代碼如下:

package cn.test.spjedis;import javax.annotation.Resource;import org.junit.Test; import org.junit.runner.RunWith; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.dao.DataAccessException; import org.springframework.data.redis.connection.RedisConnection; import org.springframework.data.redis.core.RedisCallback; import org.springframework.data.redis.core.RedisTemplate; import org.springframework.data.redis.core.ValueOperations; import org.springframework.test.context.ContextConfiguration; import org.springframework.test.context.junit4.SpringJUnit4ClassRunner; import com.cn.redis2.dao.IncrDao; @RunWith(SpringJUnit4ClassRunner.class) @ContextConfiguration(locations = "classpath:applicationContext.xml") public class TestRedis { @Resource(name = "redisTemplate") private RedisTemplate<String, String> template; // inject the template as ListOperations //至于這個(gè)為什么可以注入。需要參考AbstractBeanFactory doGetBean //super.setValue(((RedisOperations) value).opsForValue());就這一行代碼 依靠一個(gè)editor @Resource(name = "redisTemplate") private ValueOperations<String, Object> vOps; public void testSet(){ template.execute(new RedisCallback<Boolean>() { @Override public Boolean doInRedis(RedisConnection connection) throws DataAccessException { byte [] key = "tempkey".getBytes(); byte[] value = "tempvalue".getBytes(); connection.set(key, value); return true; } }); } public void testSet1(){ vOps.set("tempkey", "tempvalue"); } @Autowired private IncrDao incr; @Test public void addLink() { System.out.println(incr.incr(13)); System.out.println(incr.get(13)); } }

?

這個(gè)是對(duì)String類型插入的兩個(gè)測(cè)試。test方法中,使用了模版類提交回調(diào)(RedisCallBack)的方法來(lái)使用jedis connection操作數(shù)據(jù)。這一部分,有沒(méi)有似曾相識(shí)呢?

?

HibernateTemplate的HibernateCallback,以及Hibernate Session類中的doWork以及doReturningWork方法,都是使用了這樣的機(jī)制,方便對(duì)于連接或者session的統(tǒng)一管理。

public int excuteHqlUpdate(final String hql,final Object ...params){return getHibernateTemplate().executeWithNativeSession(new HibernateCallback<Integer>() { @Override @SuppressWarnings("unchecked") public Integer doInHibernate(Session session) throws HibernateException { Query queryObject = session.createQuery(hql); if (params != null) { for (int i = 0; i < params.length; i++) { queryObject.setParameter(i, params[i]); } } return queryObject.executeUpdate(); } }); }

?

4. 總結(jié)

我們這節(jié),講了spring redis的配置使用,基本特性,以及引入使用RedisTemplate。通過(guò)之前HibernateTemplate的對(duì)比,也應(yīng)該對(duì) RedisTemplate的基本設(shè)計(jì)有了一定的了解。下節(jié),我們將進(jìn)行深入學(xué)習(xí)RedisTempalte。

本文原文,以及相關(guān)系列文章請(qǐng)查看:深入理解Spring Redis的使用 (一)、Spring Redis基本使用 以及相關(guān)鏈接

轉(zhuǎn)載于:https://www.cnblogs.com/langtianya/p/5190201.html

總結(jié)

以上是生活随笔為你收集整理的深入理解Spring Redis的使用 (一)、Spring Redis基本使用的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。