Linux系統(tǒng)Redis筆記教學(xué)內(nèi)容_第1頁
Linux系統(tǒng)Redis筆記教學(xué)內(nèi)容_第2頁
Linux系統(tǒng)Redis筆記教學(xué)內(nèi)容_第3頁
Linux系統(tǒng)Redis筆記教學(xué)內(nèi)容_第4頁
Linux系統(tǒng)Redis筆記教學(xué)內(nèi)容_第5頁
已閱讀5頁,還剩26頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡介

1課程安排

1.介紹

2.安裝啟動(dòng)及關(guān)閉

3Jedis使用

4.Redis各種數(shù)據(jù)類型的操作

5.Redis持久化方案

6.主從復(fù)制(了解)

2課程目標(biāo)

掌握Redis的安裝

掌握redis常用數(shù)據(jù)結(jié)構(gòu)(string/hash/list/sortedset)的存取數(shù)據(jù)方法

掌握J(rèn)edis的用法

3redis介紹

3.1什么是NoSQL

NoSQL,泛指非關(guān)系型的數(shù)據(jù)庫,NoSQL即Not-OnlySQL,它可以作為關(guān)系型數(shù)據(jù)庫的良好

補(bǔ)充。隨著互聯(lián)網(wǎng)web2.0網(wǎng)站的興起,非關(guān)系型的數(shù)據(jù)庫現(xiàn)在成了一個(gè)極其熱門的新領(lǐng)域,

非關(guān)系數(shù)據(jù)庫產(chǎn)品的發(fā)展非常迅速。而傳統(tǒng)的關(guān)系數(shù)據(jù)庫在應(yīng)付web2.0網(wǎng)站,特別是超大

規(guī)模和高并發(fā)的SNS類型的web2.0純動(dòng)態(tài)網(wǎng)站已經(jīng)顯得力不從心,暴露了很多難以克服的

問題,例如:

1、Highperformance-對數(shù)據(jù)庫高并發(fā)讀寫的需求

web2.0網(wǎng)站要根據(jù)用戶個(gè)性化信息來實(shí)時(shí)生成動(dòng)態(tài)頁面和提供動(dòng)態(tài)信息,所以基本上無法

使用動(dòng)態(tài)頁面靜態(tài)化技術(shù),因此數(shù)據(jù)庫并發(fā)負(fù)載非常高,往往要達(dá)到每秒上萬次讀寫請求。

關(guān)系數(shù)據(jù)庫應(yīng)付上萬次SQL查詢還勉強(qiáng)頂?shù)米?,但是?yīng)付上萬次SQL寫數(shù)據(jù)請求,硬盤10

就已經(jīng)無法承受了。其實(shí)對于普通的BBS網(wǎng)站,往往也存在對高并發(fā)寫請求的需求,例如

網(wǎng)站的實(shí)時(shí)統(tǒng)計(jì)在線用戶狀態(tài),記錄熱門帖子的點(diǎn)擊次數(shù),投票計(jì)數(shù)等,因此這是一個(gè)相

當(dāng)普遍的需求。

2、HugeStorage-對海量數(shù)據(jù)的高效率存儲(chǔ)和訪問的需求

類似Facebook,twitter,Friendfeed這樣的SNS網(wǎng)站,每天用戶產(chǎn)生海量的用戶動(dòng)態(tài),以

Friendfeed為例,一個(gè)月就達(dá)到了2.5億條用戶動(dòng)態(tài),對于關(guān)系數(shù)據(jù)庫來說,在一張2.5億

條記錄的表里面進(jìn)行SQL查詢,效率是極其低下乃至不可忍受的。再例如大型web網(wǎng)站的

用戶登錄系統(tǒng),例如騰訊,盛大,動(dòng)輒數(shù)以億計(jì)的帳號(hào),關(guān)系數(shù)據(jù)庫也很難應(yīng)付。

3、HighScalability&&HighAvailability-對數(shù)據(jù)庫的高可擴(kuò)展性和高可用性的需求

在基于web的架構(gòu)當(dāng)中,數(shù)據(jù)庫是最難進(jìn)行橫向擴(kuò)展的,當(dāng)一個(gè)應(yīng)用系統(tǒng)的用戶量和訪問

量與日俱增的時(shí)候,你的數(shù)據(jù)庫卻沒有辦法像webserver和appserver那樣簡單的通過添加

更多的硬件和服務(wù)節(jié)點(diǎn)來擴(kuò)展性能和負(fù)載能力。對于很多需要提供24小時(shí)不間斷服務(wù)的網(wǎng)

站來說,對數(shù)據(jù)庫系統(tǒng)進(jìn)行升級(jí)和擴(kuò)展是非常痛苦的事情,往往需要停機(jī)維護(hù)和數(shù)據(jù)遷移,

為什么數(shù)據(jù)庫不能通過不斷的添加服務(wù)器節(jié)點(diǎn)來實(shí)現(xiàn)擴(kuò)展呢?

NoSQL數(shù)據(jù)庫的產(chǎn)生就是為了解決大規(guī)模數(shù)據(jù)集合多重?cái)?shù)據(jù)種類帶來的挑戰(zhàn),尤其是大數(shù)

據(jù)應(yīng)用難題。

一些主流的NOSQL產(chǎn)品:

.■R■ed■is

■需rassandra

CouchDB

relaxmongoDB

S^Lmembase*riak

NoSQL數(shù)據(jù)庫的四大分類如下:

鍵值(Key-Value)存儲(chǔ)數(shù)據(jù)庫

相關(guān)產(chǎn)品:TokyoCabinet/Tyrant、Redis、Voldemort、BerkeleyDB

典型應(yīng)用:內(nèi)容緩存,主要用于處理大量數(shù)據(jù)的高訪問負(fù)載。

數(shù)據(jù)模型:一系列鍵值對

優(yōu)勢:快速查詢

劣勢:存儲(chǔ)的數(shù)據(jù)缺少結(jié)構(gòu)化

列存儲(chǔ)數(shù)據(jù)庫

相關(guān)產(chǎn)品:Cassandra,HBase,Riak

典型應(yīng)用:分布式的文件系統(tǒng)

數(shù)據(jù)模型:以列簇式存儲(chǔ),將同一列數(shù)據(jù)存在一起

優(yōu)勢:查找速度快,可擴(kuò)展性強(qiáng),更容易進(jìn)行分布式擴(kuò)展

劣勢:功能相對局限

文檔型數(shù)據(jù)庫

相關(guān)產(chǎn)品:CouchDB、MongoDB

典型應(yīng)用:Web應(yīng)用(與Key-Value類似,Value是結(jié)構(gòu)化的)

數(shù)據(jù)模型:一系列鍵值對

優(yōu)勢:數(shù)據(jù)結(jié)構(gòu)要求不嚴(yán)格

劣勢:查詢性能不高,而且缺乏統(tǒng)一的查詢語法

圖形(Graph)數(shù)據(jù)庫

相關(guān)數(shù)據(jù)庫:

Neo4JsInfoGrid.InfiniteGraph

典型應(yīng)用:社交網(wǎng)絡(luò)

數(shù)據(jù)模型:圖結(jié)構(gòu)

優(yōu)勢:利用圖結(jié)構(gòu)相關(guān)算法。

劣勢:需要對整個(gè)圖做計(jì)算才能得出結(jié)果,不容易做分布式的集群方案。

3.2redis歷史發(fā)展

2008年,意大利的一家創(chuàng)業(yè)公司Merzia推出了一款基于MySQL的網(wǎng)站實(shí)時(shí)統(tǒng)計(jì)系統(tǒng)

LLOOGG,然而沒過多久該公司的創(chuàng)始人SalvatoreSanfilippo便對MySQL的性能感到失望,

于是他決定親自為LLOOGG量身定做一個(gè)數(shù)據(jù)庫,并于2009年開發(fā)完成,這個(gè)數(shù)據(jù)庫就是

不過并不滿足只將用于這一款產(chǎn)品,而是希望更

RedisoSalvatoreSanfilippoRedisLLOOGG

多的人使用它,于是在同一年SalvatoreSanfilippo將Redis開源發(fā)布,并開始和Redis的另

一名主要的代碼貢獻(xiàn)者PieterNoordhuis一起繼續(xù)著Redis的開發(fā),直到今天。

SalvatoreSanfilippo自己也沒有想到,短短的幾年時(shí)間,Redis就擁有了龐大的用戶群體。

HackerNews在2012年發(fā)布了一份數(shù)據(jù)庫的使用情況調(diào)查,結(jié)果顯示有近12%的公司在使

用國內(nèi)如新浪微博、街旁網(wǎng)、知乎網(wǎng),國外如、等都

RedisoGitHubStackOverflowsFlickr

是Redis的用戶。

VMware公司從2010年開始贊助Redis的開發(fā),SalvatoreSanfilippo和PieterNoordhuis也

分別在3月和5月加入VMware,全職開發(fā)Redis。

3.3什么是redis

Redis是用C語言開發(fā)的一個(gè)開源的高性能鍵值對(key-value)數(shù)據(jù)庫。它通過提供多種鍵

值數(shù)據(jù)類型來適應(yīng)不同場景下的存儲(chǔ)需求,目前為止Redis支持的鍵值數(shù)據(jù)類型如

下:

字符串類型

散列類型

列表類型

集合類型

有序集合類型。

3.4redis的應(yīng)用場景

緩存(數(shù)據(jù)查詢、短連接、新聞內(nèi)容、商品內(nèi)容等等)。(最多使用)

分布式集群架構(gòu)中的session分離。

聊天室的在線好友列表。

任務(wù)隊(duì)列。(秒殺、搶購、12306等等)

應(yīng)用排行榜。

網(wǎng)站訪問統(tǒng)計(jì)。

數(shù)據(jù)過期處理(可以精確到毫秒)

客戶,訂單,訂單明細(xì),地址模型來對比下關(guān)系型數(shù)據(jù)和非關(guān)系型數(shù)據(jù)庫

CAP:C強(qiáng)一致性A高可用P分布式容錯(cuò)性

CA傳統(tǒng)Oracle數(shù)據(jù)庫

AP大多數(shù)網(wǎng)站架構(gòu)的選擇

CPRedis、Mongodb

BASE:

基本可用

軟狀態(tài)

最終一致

4測試環(huán)境

redis需要安裝在linux服務(wù)器上運(yùn)行測試,本教程使用linux虛擬機(jī)

5安裝運(yùn)行redis

5.1redis安裝環(huán)境

redis是C語言開發(fā),建議在linux上運(yùn)行,本教程使用Centos6.4作為安裝環(huán)境。

安裝redis需要先將官網(wǎng)下載的源碼進(jìn)行編譯,編譯依賴gcc環(huán)境,如果沒有g(shù)cc

環(huán)境,需要安裝gcc:yuminstallgcc-c++

5.2redis安裝

版本說明

本教程使用redis3.0版本。3.0版本主要增加了redis集群功能。

源碼下載

從官網(wǎng)下載

http://download.redis.io/releases/redis-3.0.0.tar.gz

將redis-3.0.0.tar.gz拷貝到/usr/local下

解壓源碼

tar-xzvfredis-3.0.0.tar.gz-C/usr/local/software

進(jìn)入解壓后的目錄進(jìn)行編譯

cd/usr/local/software/redis-3.0.0

安裝到指定目錄,如/usr/local/redis

makeinstallPREFIX=/usr/local/redis

安裝目錄bin下的文件列表

-rwxrwxrwx.1rootroot41693584月1601:09redis-benchmark

-rwxrwxrwx.1rootroot164634月1601:09redis-check-aof

-rwxrwxrwx.1rootroot376954月1601:09redis-check-dump

-rwxrwxrwx.1rootroot42581284月1601:09redis-cli

-rw-r——r——.1rootroot415094月2818:19redis.conf

1rwxrwxrwx.1rootroot124月1601:09redis-sentinel->redis-server

-rwxrwxrwx.1rootroot56879614月1601:09redis-server

文件名說明

redis-seiverRedis服務(wù)器

redis-cliRedis命令行客戶端

redis-benchmarkRedis性能測試工具

ledis-check-aofAOF文件修復(fù)工具

ledis-clieck-dmupRDB文件檢查工具

redis3.0新增的redis-sentinel是redis集群管理工具可實(shí)現(xiàn)高可用。

即置文件目錄:

Yoot@server01bin]#cd../conf

root@server01conf]#11

總用量44

;rw-r--r—.1rootroot414034月1618:02redis.conf

5.3redis啟動(dòng)

5.3.1前端模式啟動(dòng)

直接運(yùn)行bin/redis-server將以前端模式啟動(dòng),前端模式啟動(dòng)的缺點(diǎn)是ssh命令窗口關(guān)閉

則redis-server程序結(jié)束,不推薦使用此方法。如下圖:

GENERAL##*################*######—#######

*BydefaultRedisdoesnotrunasadaemon,use'yes'ifyouneedit.

*NotethatRediswillwriteapidfilein/var/run/redis.pidwhendaemonized.

daemonizeno

?whenrunningdaemonized,Rediswritesapidfilein/var/run/redis.pidby

*default.Youcanspecifyacustompidfilelocationhere.

aidfile/var/run/redis.pid

#Acceptconnectionsonthespecifiedport,defaultis6379.

*ifport0isspecifiedRediswillnotlistenonaTCPsocket,

port6379

./conf/red1s.conf"938L.41403Cwritten

[rootOserverOlbin]#./redis-server

2583:c17Apr17:29:28.541#warning:noconfigfilespecified,usingthedefaultconfig.Inordertospecifyaconfigfileuse./redis-s

er/path/to/redis.conf

2583:M17Apr17:29:28.545.Increasedmaximumnumberofopenfilesto10032(itwasoriginallysetto1024).

2583:M17Apr17:29:28.590#warning:32bitinstancedetectedbutnomemorylimitset.setting3GBmaxmemorylimitwith'noeviction'po

/now.

Redis3.0.0(00000000/0)32bit

Runninginstandalonemode

Port:6379

PID:2583

http://redis.io

2583:M17Apr17:29:28.599#Serverstarted,Redisversion3.0.0

2583:M17Apr17:29:28.600#WARNINGovercommit_memoryissettoO'Backgroundsavemayfailunderlowmemorycondition.Tofixthi:

dd,vm.overcommir.memory-1'to/etc/sysctl.confandthenrebootorrunthecommandsysctlvtn.overcommit_memory-l'forthis_j:nral

2583:M17Apr17:29:28.601#WARNING:TheTCPbacklogsettingof511cannotbeenforcedbecause/proc/sys/net/core/soaiaxconn

□wervalueof128.

2583:M17Apr17:29:28.601?Theserverisnowreadytoacceptconnectionsonport6379

5.3.2后端模式啟動(dòng)

修改redis.conf配置文件,daemonizeyes以后端模式啟動(dòng)。

redis.conf是redis的配置文件,redis.conf在redis源碼目錄。

把redis-3.0.0/redis.conf復(fù)制到/usr/local/redis/bin目錄下

cp/usr/local/software/redis-3.0.0/redis.conf

/usr/local/redis/bin

修改redis.conf配置文件,daemonizeyes以后端模式啟動(dòng)。

執(zhí)行如下命令啟動(dòng)redis:

cd/usr/local/redis

[root@localhostbin]#./redis-serverredis.conf

redis默認(rèn)使用6379端口。

[root@server01redis]#psauxIgrepredis

root51100.50.1355521724?Ssl19:040:00./bin/redis-server?:6379

也可更改redis.conf文件,修改端口號(hào):

#Acceptconnectionsonthespecifiedport,defaultis6379.

#Ifport0isspecifiedRediswillnotlistenonaTCPsocket.

port6379

5.4redis停止

強(qiáng)行終止Redis進(jìn)程可能會(huì)導(dǎo)致redis持久化數(shù)據(jù)丟失。正確停止Redis的方

式應(yīng)該是向Redis發(fā)送SHUTDOWN命令,方法為:

cd/usr/local/redis

./bin/redis-clishutdown

5.5redis客戶端

在redis的安裝目錄中有redis的客戶端,即redis-cli(RedisCommandLineInterface),

它是Redis自帶的基于命令行的Redis客戶端。

5.5.1連接「edis月艮務(wù)端

執(zhí)行bin/redis-cli連接redis服務(wù)端:

[root@server01bin]#./redis-cli

couldnotconnecttoRedisat:6379:Connectionrefused

從上圖得知redis-cli默認(rèn)連接本機(jī)的redis,本機(jī)的redis沒有啟動(dòng)則報(bào)上圖中的錯(cuò)誤。

[root@combin]#./redis-serverredis.conf

[root@combin]#./redis-cli

:6379>

指定連接redis服務(wù)的ip和端口:

[root@server01bin]#./redis-cli-h-p6379

:6379>

552向redis服務(wù)端發(fā)送命令

redis-cli連上redis服務(wù)后,可以在命令行發(fā)送命令。

Ping

Redis提供了PING命令來測試客戶端與Redis的連接是否正常,如果連接正常會(huì)收到回

復(fù)PONG

[root@serverOlbin]#./redis-cli-h-p6379

:6379>ping

PONG

set/get

使用set和get可以向redis設(shè)置數(shù)據(jù)、獲取數(shù)據(jù)。

:6379>setnamezhangsan

OK

:6379>getname

"zhanasan',

del

刪除指定key的內(nèi)容。

例如:delname

Keys*

查看當(dāng)前庫中所有的key值

5.6redis多數(shù)據(jù)庫

5.6.1redis實(shí)例

一個(gè)redis進(jìn)程就是一個(gè)redis實(shí)例,一臺(tái)服務(wù)器可以同時(shí)有多個(gè)redis實(shí)例,不同的

redis實(shí)例提供不同的服務(wù)端口對外提供服務(wù),每個(gè)redis實(shí)例之間互相影響。每個(gè)redis

實(shí)例都包括自己的數(shù)據(jù)庫,數(shù)據(jù)庫中可以存儲(chǔ)自己的數(shù)據(jù)。

5.6.2多數(shù)據(jù)庫測試

一個(gè)Redis實(shí)例可以包括多個(gè)數(shù)據(jù)庫,客戶端可以指定連接某個(gè)redis實(shí)例的哪個(gè)數(shù)據(jù)

庫,就好比一個(gè)mysql中創(chuàng)建多個(gè)數(shù)據(jù)庫,客戶端連接時(shí)指定連接哪個(gè)數(shù)據(jù)庫。

一個(gè)redis實(shí)例最多可提供16個(gè)數(shù)據(jù)庫,下標(biāo)從0到15,客戶端默認(rèn)連接第0號(hào)數(shù)據(jù)

邑-螞一涯耳利巴控?fù)襁B接哪個(gè)數(shù)據(jù)庫,如下連接1號(hào)庫:

192'168^10^3:6379>select1

OK

:6379[1]>|

在1號(hào)庫中查詢上節(jié)設(shè)置的數(shù)據(jù),結(jié)果查詢不到:

:6379[1]>getname

(nil)一__

重新選擇第0號(hào)數(shù)據(jù)庫,查詢數(shù)據(jù):

:6379[1]>select0

OK

:6379>getname

"zhanasan"

如果選擇一個(gè)不存在數(shù)據(jù)庫則會(huì)報(bào)錯(cuò):

:6379>select16

(error)ERRinvalidDBindex

注意:redis不支持修改數(shù)據(jù)庫的名稱,只能通過select。、select1…選擇數(shù)據(jù)庫。

5.6.3注意問題

在0號(hào)數(shù)據(jù)庫存儲(chǔ)數(shù)據(jù),在1號(hào)數(shù)據(jù)庫執(zhí)行清空數(shù)據(jù)命令卻把0號(hào)數(shù)據(jù)庫的數(shù)據(jù)給清

空了:

:6379[1]>select0

OK

:6379>setnamezhangsan

OK

:6379>getname

"zhangsan"

:6379>select1

OK

:6379[1]>getname

(nil)

:6379[1]>flushall

OK

:6379[1]>select0

OK

:6379>getname

(nil)

建議:不同的應(yīng)用系統(tǒng)要使用不同的redis實(shí)例而不是使用同一個(gè)redis實(shí)例下的不同

數(shù)據(jù)庫。

6jedis

6.1jedis介紹

Redis不僅是使用命令來操作,現(xiàn)在基本上主流的語言都有客戶端支持,比如java、C、

C#、C++、php、Node.js、Go等。

在官方網(wǎng)站里列一些Java的客戶端,有Jedis、Redisson、Jredis、JDBC-Redis、等其中官

方推薦使用Jedis和Redisson。在企業(yè)中用的最多的就是Jedis,下面我們就重點(diǎn)學(xué)習(xí)下

JediSo

Jedis同樣也是托管在github上,地址:https:〃/xetorthio/jedis

6.2通過jedis連接redis單機(jī)

6.2.1jar包

jar包如下:

Qcommons-pool2-2.3.jar

■jedis_2,7.0.jar

6.2.2單實(shí)例連接

通過創(chuàng)建單實(shí)例jedis對象連接redis服務(wù),如下代碼:

//單實(shí)例連接redis

@Test

publicvoidtest3edisSingle(){

:Jedisjedis=new3edis("192.168.32.250",6379);

jedis.set("name"/'bar");

Stringname=jedis.get("name");

System.out.println(name);

jedis.close();

)

622.1連接超時(shí)解決

由于linux防火墻默認(rèn)開啟,redis的服務(wù)端口6379并不在開放規(guī)則之內(nèi),所有需要將

此端口開放訪問或者關(guān)閉防火墻。

關(guān)閉防火墻命令:seviceiptablesstop

如果是修改防火墻規(guī)則,可以修改:/etc/sysconfig/iptables文件

6.2.3使用連接池連接

通過單實(shí)例連接redis不能對redis連接進(jìn)行共享,可以使用連接池對redis連接進(jìn)行共

享,提高資源利用率,使用jedisPool連接redis服務(wù),如下代碼:

〃創(chuàng)建連接池

JedisPoolpool=newJedisPool("192.168.32.250",6379);

〃獲取連接

3edisjedis=pool.getResource();

〃存入

jedis.set("key3"/'aaa");

〃取出

System.out.printin(jedis.get("key3"));

〃使用連接時(shí),連接使用完后一定要關(guān)閉,關(guān)閉后連接會(huì)自動(dòng)回到連接池供別人使用,如果

一直不關(guān)閉則連接被耗盡之后就會(huì)死機(jī)

jedis.close();

〃關(guān)閉武褊

pool.close();

詳細(xì)的連接池配置參數(shù)參考下節(jié)jedis和spring整合中applicationContext.xml的配置內(nèi)

容。

6.2.4jedis與spring整合

配置spring配置文件applicationContext.xml

<?xmlversion="1.0"encoding="UTF-8"?>

<beansxmlns="http://www.springfram/schema/beans"

xmlns:xsi=H/2001/XMLSchema-instance"

xmlns:mvc="http://www.springframew/schema/mvc"

xmlns:context="http://www.springframework.org/schema/context"

xmlns:aop="http://www.springframew/schema/aop"

xmlns:tx="http://www.springframew/schema/tx"

xsi:schemaLocation="http://www.springframework.org/schema/beans

http://www.springframew/schema/beans/spring-beans-3.2.xsd

http://www.springframework.org/schema/mvc

http://www.springframew/schema/mvc/spring-mvc-3.2.xsd

http://www.springframework.org/schema/context

http://www.springframework.org/schema/context/spring-context-3.2.xsd

http://www.springframework.org/schema/aop

http://www.springframework.Org/schema/aop/spring-aop-3.2.xsd

http://www.springframework.org/schema/tx

http://www.springframework.org/schema/tx/spring-tx-3.2.xsd*'>

<!--連接池配置-->

<beanid="jedisPooLConfig,,class="redis.cLients.jedis.JedisPooLConfig">

<!--最大連接數(shù)-->

<propertyname=n/naxTotc?LMvalue=n30*7>

<!--最大空閑連接數(shù)

<propertyname=nwaxIc/LeMvalue=H10,7>

<!--每次釋放連接的最大數(shù)目一)

<propertynav(\e=,'numTestsPerEvictionRunHvalue=H1024"/>

<!--釋放連接的掃描間隔(毫秒)一)

<propertynar(\e="timeBetMeenEvictionRunsMiLLis"\/al\Ae="30000,,/>

<!--連接最小空閑時(shí)間-->

<propertynar(\e="minEvictabLeIdLeTimeMiLLis,,\/alue="1800000"/>

<!一連接空閑多久后釋放,當(dāng)空閑時(shí)間》該值且空閑連接)最大空閑連接數(shù)時(shí)直接釋

放-->

<propertynar(\e=',softMinEvictabLeIdLeTimeMiLLis"\/alue=',10000"/>

<!--獲取連接時(shí)的最大等待毫秒數(shù),小于零:阻塞不確定的時(shí)間,默認(rèn)-1

<propertyname=,,zncrxh/aitMilLis"value=H1500,7>

<!--在獲取連接的時(shí)候檢查有效性,默認(rèn)false-->

<propertyname=,,testOnBorrok/Kvalue=ntrue"/>

<!--在空閑時(shí)檢查有效性,默認(rèn)false-->

<propertyname=,,testh//7iLeIdLeHvalue=Htri/e”/>

<!--連接耗盡時(shí)是否阻塞,false報(bào)異常,ture阻塞直到超時(shí),默認(rèn)true-->

<propertyname="bLock^henExhausted,,\/alue=,'faLse,,/>

</bean>

<!--redis單機(jī)通過連接池

<beanid="jedisPoo£"class=nredis.cLients.jedis.JedisPooL"destroy-

method=nctose,r>

<constructor-argname="poolConfig"ref="jedisPoolConfig"/>

<constructor-argname="host"value="50"/>

<constructor-argname="port"value=,,6379,,/>

</bean>

</beans>

測試代碼:

privateApplicationContextapplicationcontext;

0Before

publicvoidinit(){

applicationContext=newClassPathXmlApplicationContext(

"classpath:applicationcontext.xml");

)

@Test

publicvoidtest3edisPool(){

JedisPoolpool=(OedisPool)applicationcontext.getBean("jedisPool");

try(

Dedisjedis=pool.getResource();

jedis.set(?'name'1,"lisi");

Stringname=jedis.get("name");

System.out.printin(name);

}catch(Exceptionex){

ex.printStackTrace();

}finally{

if(jedis!=null){

〃關(guān)閉連接

jedis.close();

)

)

)

7數(shù)據(jù)類型--string

7.1redisstring介紹

redis中沒有使用C語言的字符串表示,而是自定義一個(gè)數(shù)據(jù)結(jié)構(gòu)叫SDS(simple

dynamicstring)即簡單動(dòng)態(tài)字符串。

打開下載的redis源碼包,找到src下的sds.h文件查看sds源碼:

structsdshdr{

〃字符串長度

unsignedintlen;

//buf數(shù)組中未使用的字節(jié)數(shù)量

unsignedintfree;

〃用于保存字符串

charbuf[];

);

c語言對字符串的存儲(chǔ)是使用字符數(shù)組,遇到‘'0’字符則認(rèn)為字符串結(jié)束,redis的字符

串可以存儲(chǔ)任何類型的數(shù)據(jù),因?yàn)槿魏晤愋蛿?shù)據(jù)都可以表示成二進(jìn)制,sds結(jié)構(gòu)中的

charbuf口就是存儲(chǔ)了二進(jìn)制數(shù)據(jù)。

redis的字符串是二進(jìn)制安全的,什么是二進(jìn)制安全?簡單理解就是存入什么數(shù)據(jù)取出

的還是什么數(shù)據(jù)。redis中的sds不像c語言處理字符串那樣遇到字符則認(rèn)證字符串

結(jié)束,它不會(huì)對存儲(chǔ)進(jìn)去的二進(jìn)制數(shù)據(jù)進(jìn)行處理,存入什么數(shù)據(jù)取出還是什么數(shù)據(jù)。

7.2命令

7.2.1賦值

SETkeyvalue

:6379>settest123

OK

7.2.2取值

賦值與取值:

GETkey

:6379>gettest

"123"

當(dāng)鍵不存在時(shí)返回空結(jié)果。

GETSETkeyvalue

取值時(shí)同時(shí)對key進(jìn)行賦值操作。

7.2.3刪除

Delkey

:6379>deltest

(integer)1

7.2.4數(shù)值增減

遞增數(shù)字

INCRkey

當(dāng)存儲(chǔ)的字符串是整數(shù)時(shí),Redis提供了一個(gè)實(shí)用的命令I(lǐng)NCR,其作用是讓當(dāng)前鍵值遞

增,并返回遞增后的值。

:6379>incrnum

(integer)1

:6379>incrnum

(integer)2

:6379>incrnum

(integer)3

增加指定的整數(shù)

INCRBYkeyincrement

示例:

:6379>incrbynum2

(integer)5

:6379>incrbynum2

(integer)7

:6379>incrbynum2

(integer)9

遞減數(shù)值

DECRkey

7.2.5其它命令(自學(xué))

減少指定的整數(shù)

DECRBYkeydecrement

示例:

:6379>deernum

(integer)6

:6379>deernum

(integer)5

:6379>deerbynum3

(integer)2

:6379>deerbynum3

(integer)-1

向尾部追加值

APPENDkeyvalue

的作用是向鍵值的末尾追加如果鍵不存在則將該鍵的值設(shè)置為

APPENDvalueovalue,

即相當(dāng)于SETkeyvalue。返回值是追加后字符串的總長度。

127.0.0,1:6379>setstrhello

OK

:6379>appendstr"world!"

(integer)12

:6379>getstr

"helloworld!*'

獲取字符串長度

STRLENkey

STRLEN命令返回鍵值的長度,如果鍵不存在則返回0。

:6379>strlenstr

(integer)0

:6379>setstrhello

OK

:6379>strlenstr

(integer)5

同時(shí)設(shè)置/獲取多個(gè)鍵值

MSETkeyvalue[keyvalue■■]■

MGETkey[key--]

:6379>msetklvlk2v2k3v3

OK

:6379>getkl

"vl"

:6379>mgetklk3

1)"vl"

2)"v3"

8數(shù)據(jù)類型—hash

8.1使用string的問題

假設(shè)有User對象以JSON序列化的形式存儲(chǔ)到Redis中,User對象有id,username,

password,age、name等屬性,存儲(chǔ)的過程如下:

保存、更新:

User對象json(string)redis

如果在業(yè)務(wù)上只是更新age屬性,其他的屬性并不做更新我應(yīng)該怎么做呢?如果仍然采

用上邊的方法在傳輸、處理時(shí)會(huì)造成資源浪費(fèi),下邊講的hash可以很好的解決這個(gè)問

題。

8.2redishash介紹

hash叫散列類型,它提供了字段和字段值的映射。字段值只能是字符串類型,不支持

散列類型、集合類型等其它類型。如下:

鍵字段字段值

8.3命令

8.3.1賦值

HSETkeyfieldvalue一次只能設(shè)置一個(gè)字段值

:6379>hsetuserusernamezhangsan

(integer)1

HMSETkeyfieldvalue[fieldvalue...]一次可以設(shè)置多個(gè)字段值

:6379>hmsetuserage20usernamelisi

OK

8.3.2取值

HGETkeyfield一次只能獲取一個(gè)字段值

:6379>hgetuserusername

"zhangsan”

HMGETkeyfield[field…1一次可以獲取多個(gè)字段值

:6379>hmgetuserageusername

1)"20"

2)“l(fā)isi”

HGETALLkey

:6379>hgetalluser

1)"age"

2)"20"

3)"username"

4),,lisin

HSET命令不區(qū)分插入和更新操作,當(dāng)執(zhí)行插入操作時(shí)HSET命令返回1,當(dāng)執(zhí)行更新操

作時(shí)返回0.

8.3.3刪除字段

可以刪除一個(gè)或多個(gè)字段,返回值是被刪除的字段個(gè)數(shù)

HDELkeyfield[field...]

:6379>hdeluserage

(integer)1

:6379>hdeluseragename

(integer)0

:6379>hdeluserageusername

(integer)1

8.3.4增加數(shù)字

HINCRBYkeyfieldincrement

:6379>hincrbyuserage2將用戶的年齡加2

(integer)22

:6379>hgetuserage獲取用戶的年齡

"22”

8.3.5其它命令(自學(xué))

判斷字段是否存在

HEXISTSkeyfield

:6379>hexistsuserage查看user中是否有age字段

(integer)1

:6379>hexistsusername查看user中是否有name字段

(integer)0

HSETNXkeyfieldvalue

當(dāng)字段不存在時(shí)賦值,類似HSET,區(qū)別在于如果字段已經(jīng)存在,該命令不執(zhí)行任何操

作。

:6379>hsetnxuserage30如果user中沒有age字段則設(shè)置age值為30,否則

不做任何操作

(integer)0

只獲取字段名或字段值

HKEYSkey

HVALSkey

:6379>hmsetuserage20namelisi

OK

:6379>hkeysuser

1)“age”

2)"name"

:6379>hvalsuser

1)“20”

2)"lisi"

獲取字段數(shù)量

HLENkey

:6379>hlenuser

(integer)2

9數(shù)據(jù)類型一list

9.1ArrayList與LinkedList的區(qū)別

ArrayList使用數(shù)組方式存儲(chǔ)數(shù)據(jù),所以根據(jù)索引查詢數(shù)據(jù)速度快,而新增或者刪除元素

時(shí)需要設(shè)計(jì)到位移操作,所以比較慢。

LinkedList使用雙向鏈接方式存儲(chǔ)數(shù)據(jù),每個(gè)元素都記錄前后元素的指針,所以插入、

刪除數(shù)據(jù)時(shí)只是更改前后元素的指針指向即可,速度非常快,然后通過下標(biāo)查詢元素

時(shí)需要從頭開始索引,所以比較慢,但是如果查詢前幾個(gè)元素或后幾個(gè)元素速度比較

快。

―?已有鏈接

一?刪除的鏈接

—?新增的鏈接

9.2redislist介紹

列表類型(list)可以存儲(chǔ)一個(gè)有序的字符串列表,常用的操作是向列表兩端添加元素,

或者獲得列表的某一個(gè)片段。

列表類型內(nèi)部是使用雙向鏈表(doublelinkedlist)實(shí)現(xiàn)的,所以向列表兩端添加元素

的時(shí)間復(fù)雜度為0(1),獲取越接近兩端的元素速度就越快。這意味著即使是一個(gè)有幾千

萬個(gè)元素的列表,獲取頭部或尾部的10條記錄也是極快的。

9.3命令

9.3.1向列表兩端增加元素。

LPUSHkeyvalue[value...]

RPUSHkeyvalue[value...]

向列表左邊增加元素

:6379>Ipushlkeyll23

(integer)3

向列表右邊增加元素

:6379>rpushIkeyl456

(integer)3

9.3.2查看列表

LRANGEkeystartstop

LRANGE命令是列表類型最常用的命令之一,獲取列表中的某一片段,將返回Start,

stop之間的所有元素(包含兩端的元素),索引從0開始。索弓I可以是負(fù)數(shù),如:

r代表最后邊的一個(gè)元素。

:6379>IrangeIkeyl0-1

:6379>IrangelkeylO2

1)"2"

2)ur

3/4”

933從列表兩端彈出元素

LPOPkey

RPOPkey

LPOP命令從列表左邊彈出一個(gè)元素,會(huì)分兩步完成,第一步是將列表左邊的元素從列

表中移除,第二步是返回被移除的元素值。

:6379>lpopIkeyl

"3"

:6379>rpopIkeyl

9.3.4獲取列表中元素的個(gè)數(shù)

LLENkey

:6379>lienIkeyl

(integer)2

9.3.5其它命令(自學(xué))

刪除列表中指定的值

LREMkeycountvalue

LREM命令會(huì)刪除列表中前count個(gè)值為value的元素,返回實(shí)際刪除的元素個(gè)數(shù)。根

據(jù)count值的不同,該命令的執(zhí)行方式會(huì)有所不同:

?當(dāng)count〉。時(shí),LREM會(huì)從列表左邊開始刪除。

?當(dāng)count<0時(shí),LREM會(huì)從列表后邊開始刪除。

?當(dāng)count=0時(shí),LREM刪除所有值為value的元素。

獲得/設(shè)置指定索引的元素值

LINDEXkeyindex

LSETkeyindexvalue

127.0.0.1:6379>lindexIkeyl2

:6379>lsetlkeyl22

OK

127.0.0.1:6379>IrangeIkeyl0-1

1)"6"

2)"5H

3)"2"

4)"2H

只保留列表指定片段,指定范圍和LRANGE一致

LTRIMkeystartstop

:6379>IrangeIkeyl0-1

1)"6n

2)“5”

3)“0”

4)"2n

:6379>ItrimIkeyl02

OK

:6379>IrangeIkeyl0-1

1)n6"

2)“5〃

3)n0n

向列表中插入元素

LINSERTkeyBEFORE/AFTERpivotvalue

該命令首先會(huì)在列表中從左到右查找值為Pivot的元素,然后根據(jù)第二個(gè)參數(shù)是BEFORE

還是AFTER來決定將value插入到該元素的前面還是后面。

:6379>Irange/keylO-1

1)"3"

2)"2n

3)"1"

:6379>linsert/keylafter34

(integer)4

:6379>Irange/keylO-1

1)"3"

2)"4n

3)"2"

4)"1"

將元素從一個(gè)列表轉(zhuǎn)移到另一個(gè)列表中

RPOPLPUSHsourcedestination

:6379>rpoplpushlistnewlist

:6379>Irangenewlist0-1

1)nr

:6379>Irangelist0-1

1)"3"

2)u4"

3)"2"

10數(shù)據(jù)類型一set

lO.lredisset介紹

在集合中的每個(gè)元素都是不同的,且沒有順序。

集合類型和列表類型的對比:

集合類型列表類型

存儲(chǔ)內(nèi)容至多2*T個(gè)字符串至多產(chǎn)-1個(gè)字符串

有序件否是

唯ft是否

集合類型的常用操作是向集合中加入或刪除元素、判斷某個(gè)元素是否存在等,由于集

合類型的Redis內(nèi)部是使用值為空的散列表實(shí)現(xiàn),所有這些操作的時(shí)間復(fù)雜度都為0(1)。

Redis還提供了多個(gè)集合之間的交集、并集、差集的運(yùn)算。

10.2命令

10.2.1增加/刪除元素

SADDkeymember[member...]

SREMkeymember[member...]

:6379>saddsetabc

(integer)3

:6379>saddseta

(integer)0

:6379>sremsetcd

(integer)1

10.2.2獲得集合中的所有元素

SMEMBERSkey

:6379>smembersset

1)"b"

2)"aH

判斷元素是否在集合中,無論集合中有多少元素都可以極速的返回結(jié)果。

SISMEMBERkeymember

:6379>sismemberseta

(integer)1

:6379>sismemberseth

(integer)0

10.3其它命令

10.3.1集合的差集運(yùn)算A-B

屬于A并且不屬于B的元素構(gòu)成的集合。

A^B

SDIFFkey[key...]

:6379>saddsetA123

(integer)3

:6379>saddsetB234

(integer)3

:6379>sdiffsetAsetB

1)"1"

:6379>sdiffsetBsetA

1)"4n

10.3.2集合的交集運(yùn)算APB

屬于A且屬于B的元素構(gòu)成的集合。

SINTERkey[key...]

127.0.0,1:6379>sintersetAsetB

1)"2"

2)"3"

10.3.3集合的并集運(yùn)算AUB

屬于A或者屬于B的元素構(gòu)成的集合

A\JB

SUNIONkey[key...]

:6379>sunionsetAsetB

1)nr

2)“2"

3)n3u

4)“4"

10.3.4其它命令(自學(xué))

獲得集合中元素的個(gè)數(shù)

SCARDkey

:6379>smemberssetA

1)"1"

2)"2"

3)"3"

:6379>seardsetA

(integer)3

從集合中彈出一個(gè)元素

SPOPkey

:6379>spopsetA

注意:由于集合是無序的,所有SPOP命令會(huì)從集合中隨機(jī)選擇一個(gè)元素彈出

11數(shù)據(jù)類型--sortedset

ll.lredissortedset介紹

在集合類型的基礎(chǔ)上有序集合類型為集合中的每個(gè)元素都關(guān)聯(lián)一個(gè)分?jǐn)?shù),這使得我們

不僅可以完成插入、刪除和判斷元素是否存在在集合中,還能夠獲得分?jǐn)?shù)最高或最低

的前N個(gè)元素、獲取指定分?jǐn)?shù)范圍內(nèi)的元素等與分?jǐn)?shù)有關(guān)的操作。

在某些方面有序集合和列表類型有些相似。

1、二者都是有序的。

2、二者都可以獲得某一范圍的元素。

但是,二者有著很大區(qū)別:

1、列表類型是通過鏈表實(shí)現(xiàn)的,獲取靠近兩端的數(shù)據(jù)速度極快,而當(dāng)元素增多后,訪

問中間數(shù)據(jù)的速度會(huì)變慢。

2、有序集合類型使用散列表實(shí)現(xiàn),所有即使讀取位于中間部分的數(shù)據(jù)也很快。

3、列表中不能簡單的調(diào)整某個(gè)元素的位置,但是有序集合可以(通過更改分?jǐn)?shù)實(shí)現(xiàn))

4、有序集合要比列表類型更耗內(nèi)存。

11.2命令

11.2.1增加元素

向有序集合中加入一個(gè)元素和該元素的分?jǐn)?shù),如果該元素已經(jīng)存在則會(huì)用新的分?jǐn)?shù)替

換原有的分?jǐn)?shù)。返回值是新加入到集合中的元素個(gè)數(shù),不包含之前已經(jīng)存在的元素。

ZADDkeyscoremember[scoremember...]

:6379>zaddscoreboard80zhangsan89lisi94wangwu

(integer)3

:6379>zaddscoreboard97lisi

(integer)0

獲取元素的分?jǐn)?shù)

ZSCOREkeymember

:6379>zscorescoreboardlisi

1122刪除元素

ZREMkeymember[member...]

移除有序集key中的一個(gè)或多個(gè)成員,不存在的成員將被忽略。

當(dāng)key存在但不是有序集類型時(shí),返回一個(gè)錯(cuò)誤。

:6379>zremscoreboardlisi

(integer)1

11.2.3獲得排名在某個(gè)范圍的元素列表

獲得排名在某個(gè)范圍的元素列表

ZRANGEkeystartstop/W/177SC。/?的照元素分?jǐn)?shù)從小至IJ大的順序返回索弓|從start到stop

之間的所有元素(包含兩端的元素)

:6379>zrangescoreboard02

1)"zhangsan"

2)"wangwu"

3)"lisi,l

ZREVRANGEkeystartstop/W/丁HSCORES/照元素分?jǐn)?shù)從大到小的順序返回索弓|從start到

stop之間的所有元素(包含兩端的元素)

:6379>zrevrangescoreboard02

1)'*lisi"

2)"wangwu"

3)"zhangsan"

如果需要獲得元素的分?jǐn)?shù)的可以在命令尾部加上WITHSCORES參數(shù)

:6379>zrangescoreboard01WITHSCORES

1)"zhangsan"

2)"80"

3)"wangwu"

4)"94"

11.2.4其它命令(自學(xué))

獲得指定分?jǐn)?shù)范圍的元素

ZRANGEBYSCOREkeyminmax[WITHSCORES][LIMIToffsetcount]

:6379>ZRANGEBYSCOREscoreboard9097WITHSCORES

1)"wangwu"

2)“94”

3)"lisi"

4)"97"

:6379>ZRANGEBYSCOREscoreboard70100limit12

1)"wangwu"

2)“l(fā)isi”

增加某個(gè)元素的分?jǐn)?shù),返回值是更改后的分?jǐn)?shù)。

ZINCRBYkeyincrementmember

給lisi加4分

:6379>ZINCRBYscoreboard4lisi

"101”

獲得集合中元素的數(shù)量

ZCARDkey

:6379>ZCARDscoreboard

(integer)3

獲得指定分?jǐn)?shù)范圍內(nèi)的元素個(gè)數(shù)

ZCOUNTkeyminmax

:6379>ZCOUNTscoreboard8090

(integer)1

按照排名范圍刪除元素

ZREMRANGEBYRANKkeystartstop

:6379>ZREMRANGEBYRANKscoreboard01

(integer)2

:6379>ZRANGEscoreboard0-1

1)"lisin

ZREMRANGEBYSCOREkeyminmax

按照分?jǐn)?shù)范圍刪除元素

:6379>zaddscoreboard84zhangsan

(integer)1

:6379>ZREMRANGEBYSCOREscoreboard80100

(integer)1

獲取元素的排名

ZRANKkey

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論