Redis入門基礎(chǔ)常用操作命令整理
Redis基礎(chǔ)
Redis 是一個(gè)開源(BSD許可)的,內(nèi)存中的數(shù)據(jù)結(jié)構(gòu)存儲(chǔ)系統(tǒng),它可以用作數(shù)據(jù)庫(kù)、緩存和消息中間件。它支持多種類型的數(shù)據(jù)結(jié)構(gòu),如字符串(strings),散列(hashes),列表(lists),集合(sets),有序集合(sorted sets)與范圍查詢,bitmaps,hyperloglogs 和地理空間(geospatial) 索引半徑查詢。
Redis 內(nèi)置了復(fù)制(replication),LUA腳本(Lua scripting),LRU驅(qū)動(dòng)事件(LRU eviction),事務(wù)(transactions)和不同級(jí)別的磁盤持久化(persistence),并通過Redis哨兵(Sentinel)和自動(dòng) 分區(qū)(Cluster)提供高可用性(high availability)。
一、redis是單線程
redis是基于內(nèi)存操作的,cpu并不是redis的性能瓶頸,它的瓶頸取決于機(jī)器的內(nèi)存和網(wǎng)絡(luò)帶寬,所以能用單線程實(shí)現(xiàn)那就用單線程好了。
那么為什么用單線程還能這么快?
首先有2個(gè)誤區(qū)先要明確:
- 高性能的服務(wù)器不一定是多線程的。
- 多線程也不是一定比單線程效率高。
redis是將所有的數(shù)據(jù)放到內(nèi)存里去,多線程的話反而會(huì)存在cpu切換上下文從而增加耗時(shí),而對(duì)內(nèi)存系統(tǒng)來說,沒有上下文的切換,單線程操作效率就是最高的。
二、關(guān)于數(shù)據(jù)庫(kù)的常用操作
1. 默認(rèn)數(shù)據(jù)庫(kù)
redis默認(rèn)有16個(gè)數(shù)據(jù)庫(kù),默認(rèn)使用是第一個(gè)數(shù)據(jù)庫(kù)(下標(biāo)為0)??梢圆榭聪屡渲梦募?,里面有database 16
。
2. 切換數(shù)據(jù)庫(kù)
select 3
,可以切換到第4個(gè)數(shù)據(jù)庫(kù)。
3. 查看數(shù)據(jù)庫(kù)大小
dbsize
可以查看當(dāng)前數(shù)據(jù)庫(kù)大小。
這時(shí),給數(shù)據(jù)庫(kù)里set一個(gè)值,再次查看數(shù)據(jù)庫(kù)大小,就變化了。
4. 清空數(shù)據(jù)庫(kù)
清空當(dāng)前的數(shù)據(jù)庫(kù)
flushdb
清空所有的數(shù)據(jù)庫(kù)
flushall
三、關(guān)于Redis-Key的常用操作
1. set 設(shè)置key 和 value
set name pingguo222
2. keys * 查看所有的key
可以查看所有的key。這里切換回默認(rèn)的數(shù)據(jù)庫(kù),查看所有key。
keys *
3. get key 的 value
get name
4. exists key 是否存在key
exists name
存在,則返回1,不存在則返回0。
5. move 移動(dòng) key
MOVE 命令是將當(dāng)前數(shù)據(jù)庫(kù)的 key 移動(dòng)到給定的數(shù)據(jù)庫(kù) db 當(dāng)中。
move name 0
比如當(dāng)前所在3數(shù)據(jù)庫(kù),命令是 把當(dāng)前3數(shù)據(jù)庫(kù)下的name移動(dòng)到 0數(shù)據(jù)庫(kù)下。如果成功了返回1,失敗了返回0。
6. 設(shè)置key過期時(shí)間
我設(shè)置age 10s后過期,等10s后再次get就拿不到值了。
expire age 10
7. 查看key的剩余時(shí)間
我設(shè)置name過期時(shí)間100s,使用ttl查看。
ttl name
8. 查看key的類型
type name
命令實(shí)際上有很多,redis官網(wǎng)提供了查詢命令的地方,后面啥不會(huì)就查啥。
以上就是Redis入門基礎(chǔ)常用操作命令整理的詳細(xì)內(nèi)容,更多關(guān)于Redis基礎(chǔ)操作命令的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Redis與本地緩存的結(jié)合實(shí)現(xiàn)
我們開發(fā)中經(jīng)常用到Redis作為緩存,本文主要介紹了Redis與本地緩存的結(jié)合實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-07-07Redis數(shù)據(jù)類型string和Hash詳解
大家都知道Redis中有五大數(shù)據(jù)類型分別是String、List、Set、Hash和Zset,本文給大家分享Redis數(shù)據(jù)類型string和Hash的相關(guān)操作,感興趣的朋友跟隨小編一起看看吧2022-03-03Redis主從復(fù)制問題和擴(kuò)容問題的解決思路
這篇文章主要介紹了Redis主從復(fù)制問題和擴(kuò)容問題的解決思路,其中擴(kuò)容問題的解決思路來自Redis作者,需要的朋友可以參考下2014-06-06關(guān)于Redis數(shù)據(jù)庫(kù)三種持久化方案介紹
大家好,本篇文章主要講的是關(guān)于Redis數(shù)據(jù)庫(kù)三種持久化方案介紹,感興趣的同學(xué)趕快來看一看吧,對(duì)你有幫助的話記得收藏一下2022-01-01Redis+Hbase+RocketMQ?實(shí)際使用問題案例講解
這篇文章主要介紹了Redis+Hbase+RocketMQ?實(shí)際使用問題案例分享,本文結(jié)合示例代碼給大家講解的非常詳細(xì),需要的朋友可以參考下2023-01-01Spring Boot整合Redis實(shí)現(xiàn)訂單超時(shí)處理問題
這篇文章主要介紹了Spring Boot整合Redis實(shí)現(xiàn)訂單超時(shí)處理,通過這個(gè)基本的示例,你可以了解如何使用Spring Boot和Redis來處理訂單超時(shí)問題,并根據(jù)需要進(jìn)行擴(kuò)展和定制,需要的朋友可以參考下2023-11-11