資料來源:http://www.atguigu.com/download.shtml
一,redis是什么?
Redis:REmote DIctionary Server(遠程字典服務器),是一個用C語言編寫的,遵守BSD協議,高性能的(key/value)分布式內存數據庫(開源),基于內存運行并支持持久化,是當前最熱門的NoSql數據庫之一,也被人們稱為數據結構服務器。
二,redis的特點
支持數據的持久化,可以將內存中的數據保持在磁盤中,重啟的時候可以再次加載進行使用。
Redis不僅僅支持簡單的key-value類型的數據,同時還提供list,set,zset,hash等數據結構的存儲。
Redis支持數據的備份,即master-slave模式的數據備份
三,永遠的hello world
安裝redis就不多說了,解壓安裝包之后再在解壓目錄make,makeinstall。查看默認安裝目錄(注,多余的rdb文件和log文件是我自己新建的):
redis-benchmark: 性能測試工具
redis-check-aof:修復有問題的AOF文件
redis-check-dump:修復有問題的dump.rdb文件
redis-cli:客戶端,操作入口
redis-sentinel:redis集群使用
redis-server:Redis服務器啟動命令
為了不改變默認配置,將redis.conf(redis的解壓目錄中)拷貝出來,保存在其他目錄,如我保存在/root/myredis目錄下。
修改redis.conf文件將里面的daemonize no 改成 yes,讓服務在后臺啟動。
啟動redis:
redis-server /root/myredis/redis.conf #設置Redis服務端啟動配置文件redis-cli -p 6379#啟動Redis客戶端進程測試連通性
127.0.0.1:6379> pingPONG127.0.0.1:6379>helloworld示例:
127.0.0.1:6379> set hello HelloWorldOK127.0.0.1:6379> get hello"HelloWorld"四,雜項知識
redis默認16個數據庫,類似數組下標從零開始,初始默認使用零號庫
Select 命令切換數據庫
Dbsize 查看當前數據庫的key的數量
Flushdb:清空當前庫
Flushall:通殺全部庫
統一密碼管理:每一個數據庫都是同樣密碼
redis索引都是從零開始,啟動端口默認是6379
五,redis的key和五大數據類型
key: keys * 查看數據庫中所有的鍵
127.0.0.1:6379> keys *1) "hello"exists key hello 判斷某個key是否存在
127.0.0.1:6379> exists key hello(integer) 1expire key 秒鐘:為給定的key設置過期時間
ttl key 查看還有多少秒過期,-1表示永不過期,-2表示已過期
數據類型之String類型:string是redis最基本的類型,你可以理解成與Memcached一模一樣的類型,一個key對應一個value。
string類型是二進制安全的。意思是redis的string可以包含任何數據。比如jpg圖片或者序列化的對象 。一個redis中字符串value最多可以是512M
set/get/del/append/strlen,添加、查詢、修改、刪除字符串以及得到字符串長度
127.0.0.1:6379> set key1 val1OK127.0.0.1:6379> get key1"val1"127.0.0.1:6379> strlen key1(integer) 4127.0.0.1:6379> append key1 haha(integer) 8127.0.0.1:6379> get key1"val1haha"127.0.0.1:6379> del key1(integer) 1127.0.0.1:6379> keys *1) "hello"incr/decr/incrby/decrby,對字符串進行加減,一定要是數字才能進行加減
127.0.0.1:6379> incr key2(integer) 2127.0.0.1:6379> get key2"2"127.0.0.1:6379> decr key2(integer) 1127.0.0.1:6379> get key2"1"127.0.0.1:6379> incrby key2 3(integer) 4127.0.0.1:6379> get key2"4"127.0.0.1:6379> decrby key2 3(integer) 1127.0.0.1:6379> get key2"1"getrange: 獲取指定范圍內的值,從零到負一表示全部
setrange: 設置指定區域內的值
127.0.0.1:6379> set key3 abcd123OK127.0.0.1:6379> GETRANGE key3 0 -1"abcd123"127.0.0.1:6379> SETRANGE key3 4 efgh(integer) 8127.0.0.1:6379> get key3"abcdefgh"setex(set with expire)鍵秒值/setnx(set if not exist) setex:設置帶過期時間的key,動態設置。格式:setex 鍵 秒值 真實值 setnx:只有在 key 不存在時設置 key 的值。
127.0.0.1:6379> setex k4 10 v4OK127.0.0.1:6379> ttl k4(integer) 5mset/mget/msetnx
mset:同時設置一個或多個 key-value 對。
mget:獲取所有(一個或多個)給定 key 的值。
msetnx:同時設置一個或多個 key-value 對,當且僅當所有給定 key 都不存在。
127.0.0.1:6379> mset k1 v1 k2 v2 k3 v3OK127.0.0.1:6379> mget k1 k2 k31) "v1"2) "v2"3) "v3"127.0.0.1:6379> msetnx k4 v4 k5 v5(integer) 0127.0.0.1:6379> mget k4 k51) (nil)2) "v5"數據類型之list: List(列表)底層實際是個鏈表
lpush/rpush/lrange,生成鏈表,lpush最先保存的序號在最前面
127.0.0.1:6379> LPUSH list01 1 2 3 4 5(integer) 5127.0.0.1:6379> LRANGE list01 0 -11) "5"2) "4"3) "3"4) "2"5) "1"127.0.0.1:6379> RPUSH list02 1 2 3 4 5(integer) 5127.0.0.1:6379> LRANGE list02 0 -11) "1"2) "2"3) "3"4) "4"5) "5"lpop/rpop,得到最左邊的值和最右邊的值
127.0.0.1:6379> lpop list01"5"127.0.0.1:6379> rpop list01"1"127.0.0.1:6379> lrange list01 0 -11) "4"2) "3"3) "2"lindex,按照索引下標獲得元素(從上到下),llen獲取list的大小
127.0.0.1:6379> LINDEX list01 2"2"127.0.0.1:6379> LLEN list01(integer) 3ltrim:截取指定索引區間的元素,格式是ltrim list的key 起始索引 結束索引,截取當前范圍的值再賦值給key
rpoplpush 源列表 目的列表,移除列表的最后一個元素,并將該元素添加到另一個列表并返回
數據類型Set,無序集合
127.0.0.1:6379> sadd set01 1 1 2 2 3 3(integer) 3127.0.0.1:6379> SMEMBERS set01 1) "1"2) "2"3) "3"#判斷是否是set01集合成員127.0.0.1:6379> SISMEMBER set01 1(integer) 1scard,獲取集合里面的元素個數
srem key value 刪除集合中元素
127.0.0.1:6379> SCARD set01(integer) 3127.0.0.1:6379> SREM set01 3(integer) 1127.0.0.1:6379> SMEMBERS set011) "1"2) "2"srandmember key 某個整數(隨機出幾個數)
spop key 隨機出棧
smove key1 key2 在key1里某個值 , 作用是將key1里的某個值賦給key2
127.0.0.1:6379> sadd set02 1 2 3 6 7 8(integer) 6127.0.0.1:6379> smembers set021) "1"2) "2"3) "3"4) "6"5) "7"6) "8"127.0.0.1:6379> sadd set01 1 2 3 4 5 6 7(integer) 5127.0.0.1:6379> smove set01 set02 5(integer) 1127.0.0.1:6379> smembers set021) "1"2) "2"3) "3"4) "5"5) "6"6) "7"7) "8"交集(sinter key1 key2)/并集(sunion key1 key2)/差集(sdiff key1 key2)
數據類型之Hash:Hash(哈希,類似java里的Map
127.0.0.1:6379> hset user id 11(integer) 1127.0.0.1:6379> hget user id"11"127.0.0.1:6379> hmset user id 11 name zhangsan sex male OK127.0.0.1:6379> hgetall user1) "id"2) "11"3) "name"4) "zhangsan"5) "sex"6) "male"127.0.0.1:6379> hmget user id name1) "11"2) "zhangsan"127.0.0.1:6379> hdel user sex(integer) 1127.0.0.1:6379> hgetall user1) "id"2) "11"3) "name"4) "zhangsan"hlen:獲取hash列表的鍵值對數目
127.0.0.1:6379> hmset user id 11 name zhangsan sex male age 22OK127.0.0.1:6379> hgetall user1) "id"2) "11"3) "name"4) "zhangsan"5) "sex"6) "male"7) "age"8) "22"127.0.0.1:6379> hlen user(integer) 4hexists key 在key里面的某個值的key
hkeys/hvals key,獲取某個hash列表的key值和value值
hincrby key key1 n,hash列表某個key的value值加n
127.0.0.1:6379> hexists user id(integer) 1127.0.0.1:6379> hkeys user1) "id"2) "name"3) "sex"4) "age"127.0.0.1:6379> hvals user1) "11"2) "zhangsan"3) "male"4) "22"127.0.0.1:6379> hincrby user age 2(integer) 24127.0.0.1:6379> hvals user1) "11"2) "zhangsan"3) "male"4) "24"數據類型之zset:sorted set,有序集合,在set基礎上,加一個score值。之前set是k1 v1 v2 v3,現在zset是k1 score1 v1 score2 v2。
127.0.0.1:6379> zadd zset01 60 v1 70 v2 80 v3 90 v4 100 v5(integer) 5127.0.0.1:6379> zrange zset01 0 -11) "v1"2) "v2"3) "v3"4) "v4"5) "v5"127.0.0.1:6379> zrange zset01 0 -1 withscores 1) "v1" 2) "60" 3) "v2" 4) "70" 5) "v3" 6) "80" 7) "v4" 8) "90" 9) "v5"10) "100"zrangebyscore key 開始score 結束score
127.0.0.1:6379> zrangebyscore zset01 60 901) "v1"2) "v2"3) "v3"4) "v4"limit用法:
127.0.0.1:6379> zrangebyscore zset01 60 90 limit 2 21) "v3"2) "v4"zrem key 某score下對應的value值,作用是刪除元素
zcount key score區間/zrank key values值,作用是獲得下標值。zscore key 對應值,獲得分數
127.0.0.1:6379> zrank zset01 v4(integer) 3127.0.0.1:6379> zcount zset01 60 90(integer) 4127.0.0.1:6379> zscore zset01 v4"90"逆序獲得zset集合值
127.0.0.1:6379> zrevrange zset01 0 -11) "v4"2) "v3"3) "v2"4) "v1"根據分數逆序獲取value值
127.0.0.1:6379> zrevrangebyscore zset01 90 601) "v4"2) "v3"3) "v2"4) "v1"并不完整。。。。下次再加吧
新聞熱點
疑難解答