您好,登錄后才能下訂單哦!
redis安裝請點擊這里:Redis安裝
redis數據結構
1、string
string是簡單的類型,可以理解成與Memcached一樣的類型,一個key對應一個value;支持的操作也與Memcached的操作類似,不過它的功能更豐富。可以存二進制的對象。
操作之前先做個別名,因為進入redis的命令很長,每次輸入都很麻煩。
[root@gz1 etc]# alias redis-cli='/usr/local/redis/bin/redis-cli' [root@gz1 etc]# vim .bashrc //寫入后開機自動會加載 alias redis-cli='/usr/local/redis/bin/redis-cli' [root@gz1 etc]# redis-cli //若設置了密碼,則登入的命令為:redis-cli -a 123456 127.0.0.1:6379> 示例1: 127.0.0.1:6379> set key1 hello OK 127.0.0.1:6379> get key1 "hello" 127.0.0.1:6379> mset key1 helloworld key2 howareyou key3 youarewelcome OK 127.0.0.1:6379> mget key1 key2 key3 1) "helloworld" 2) "howareyou" 3) "youarewelcome" Ctrl+d 退出
2、list
list 是一個鏈表結構(相當于一個管道,隨時可以從左右插入和取出值,區別于只能先進后出的站),主要功能是 push、pop、獲取一個范圍的所有值等等。操作中 key 理解為鏈表的名字。使用 List 結構,我們可以輕松地實現最新消息排行等功能(比如微博的 TimeLine)。list 的另一個應用就是消息隊列,可以利用 list 的 push 操作,將任務存在 list 中,然后工作線程再用 pop 操作將任務取出進行執行。
127.0.0.1:6379> lpush list1 123 //從左邊插入數值 (integer) 1 127.0.0.1:6379> lpush list1 aaa (integer) 2 127.0.0.1:6379> lpush list1 bbb (integer) 3 127.0.0.1:6379> lpush list1 "ccc ddd" (integer) 4 127.0.0.1:6379> lrange list1 0 -1 //從左邊開始獲取所有值,沒有從右邊的命令 1) "ccc ddd" 2) "bbb" 3) "aaa" 4) "123" 127.0.0.1:6379> lpop list1 //從左邊取出一個值 "ccc ddd" 127.0.0.1:6379> lrange list1 0 -1 1) "bbb" 2) "aaa" 127.0.0.1:6379> rpush list1 fff //從右邊插入數值 (integer) 3 127.0.0.1:6379> lrange list1 0 -1 1) "bbb" 2) "aaa" 3) "fff" 127.0.0.1:6379> rpop list1 //從右邊取出一個值 "123" 127.0.0.1:6379> lrange list1 0 -1 1) "ccc ddd" 2) "bbb" 3) "aaa"
set
set 即集合,和我們數學中的集合概念相似,對集合的操作有添加、刪除元素,有對多個集合求交、并、差等操作。操作中的 key 理解為集合的名字。
比如微博應用中,可以將一個用戶所有的關注人存儲在一個集合中,將其所有粉絲存儲在一個集合。因為 Redis 非常人性化的為集合提供了求交集、并集、差集等操作,你還可以使用不用的命令選擇將結果返回給客戶端還是存儲到一個新的集合中。
另外QQ也有一個社交功能叫“好友標簽”,大家可以給好友貼標簽,比如“高富帥”“白富美”“歐巴”等,這時就可以使用 Redis 的集合來實現,把每一個用戶的標簽都存儲在一個集合之中。
示例:
127.0.0.1:6379> sadd set1 aaa //添加集合set1數值 (integer) 1 127.0.0.1:6379> sadd set1 bbb (integer) 1 127.0.0.1:6379> sadd set1 ccc (integer) 1 127.0.0.1:6379> sadd set1 ddd (integer) 1 127.0.0.1:6379> smembers set1 //獲取集合中數值(無序的列出) 1) "aaa" 2) "bbb" 3) "ddd" 4) "ccc"
sorted set
sorted set 即有序集合,它比 set 多一個權重參數 score,使得集合中的元素能夠按 score 進行有序排列,比如一個存儲全班同學成績的 Sorted Sets,其集合 value 可以是同學的學號,而 score 就可以是其考試成績,這樣在數據插入集合的時候,就已經進行了天然的排序。
示例:
127.0.0.1:6379> zadd set2 10 aaa //10為權重參數 score,下同 (integer) 1 127.0.0.1:6379> zadd set2 2 bbb (integer) 1 127.0.0.1:6379> zadd set2 6 ccc (integer) 1 127.0.0.1:6379> zadd set2 13 "ab cd" (integer) 1 127.0.0.1:6379> zadd set2 8 "ef-gh" (integer) 1 127.0.0.1:6379> zrange set2 0 -1 //正序排列輸出 1) "bbb" 2) "ccc" 3) "ef-gh" 4) "aaa" 5) "ab cd" 127.0.0.1:6379> zrevrange set2 0 -1 //倒序排列輸出 1) "ab cd" 2) "aaa" 3) "ef-gh" 4) "ccc" 5) "bbb"
hash
在 Redis 中,我們經常將一些結構化的信息打包成 hashmap,在客戶端序列化后存儲為一個字符串的值(一般是 JSON 格式)。可以把多個鍵值對存儲到一個 hash 中去,比如用戶的昵稱、年齡、性別可以存儲到一個 hash 中去。
示例:
127.0.0.1:6379> hset hash2 name tpp (integer) 1 127.0.0.1:6379> hset hash2 age 25 (integer) 1 127.0.0.1:6379> hset hash2 sex man (integer) 1 127.0.0.1:6379> hgetall hash2 //全部取出 1) "name" 2) "tpp" 3) "age" 4) "25" 5) "sex" 6) "man" 127.0.0.1:6379> hget hash2 name //取出單個 "tpp"
Redis持久化
Redis 提供了兩種持久化的方式,分別是 RDB(Redis DataBase)和AOF(Append Only File)。
RDB 簡而言之就是在不同的時間點,將 redis 存儲的數據生成快照并存儲到磁盤等介質上。
AOF 則是換了一個角度來實現持久化,是將 redis 執行過的所有寫指令記錄下來,在下次 redis 重新啟動時,只要把這些寫指令從前到后再重復執行一遍,就可以實現數據恢復了。
其實 RDB 和 AOF 兩種方式可以同時使用,在這種情況下,如果 redis 重啟的話,則會優先采用 AOF方式來進行數據恢復,這是因為 AOF 方式的數據恢復完整度更高。
如果沒有數據持久化的需求,也完全可以關閉 RDB 和 AOF 方式,這樣的話,redis將會變成一個純內存數據庫,就像 Memcached 一樣。
Redis配置文件解析
配置文件:/usr/local/redis/etc/redis.conf
1、查看及重設配置
127.0.0.1:6379> config get * 1) "dbfilename" 2) "dump.rdb" 3) "requirepass" 4) "" 5) "masterauth" 6) "" 7) "unixsocket" 8) "" 9) "logfile" 10) "/usr/local/redis/var/redis.log" 11) "pidfile" 12) "/usr/local/redis/var/redis.pid" 13) "maxmemory" 14) "0" 15) "maxmemory-samples" 16) "3" 17) "timeout" 18) "300" 19) "tcp-keepalive" 20) "0" 21) "auto-aof-rewrite-percentage" 22) "100" 23) "auto-aof-rewrite-min-size" 24) "67108864" 25) "hash-max-ziplist-entries" 26) "512" 27) "hash-max-ziplist-value" 28) "64" 29) "list-max-ziplist-entries" 30) "512" 31) "list-max-ziplist-value" 32) "64" 33) "set-max-intset-entries" 34) "512" 35) "zset-max-ziplist-entries" 36) "128" 37) "zset-max-ziplist-value" 38) "64" 39) "hll-sparse-max-bytes" 40) "3000" 41) "lua-time-limit" 42) "5000" 43) "slowlog-log-slower-than" 44) "10000" 45) "latency-monitor-threshold" 46) "0" 47) "slowlog-max-len" 48) "128" 49) "port" 50) "6379" 51) "tcp-backlog" 52) "511" 53) "databases" 54) "16" 55) "repl-ping-slave-period" 56) "10" 57) "repl-timeout" 58) "60" 59) "repl-backlog-size" 60) "1048576" 61) "repl-backlog-ttl" 62) "3600" 63) "maxclients" 64) "4064" 65) "watchdog-period" 66) "0" 67) "slave-priority" 68) "100" 69) "min-slaves-to-write" 70) "0" 71) "min-slaves-max-lag" 72) "10" 73) "hz" 74) "10" 75) "repl-diskless-sync-delay" 76) "5" 77) "no-appendfsync-on-rewrite" 78) "no" 79) "slave-serve-stale-data" 80) "yes" 81) "slave-read-only" 82) "yes" 83) "stop-writes-on-bgsave-error" 84) "yes" 85) "daemonize" 86) "yes" 87) "rdbcompression" 88) "yes" 89) "rdbchecksum" 90) "yes" 91) "activerehashing" 92) "yes" 93) "repl-disable-tcp-nodelay" 94) "no" 95) "repl-diskless-sync" 96) "no" 97) "aof-rewrite-incremental-fsync" 98) "yes" 99) "aof-load-truncated" 100) "yes" 101) "appendonly" 102) "no" 103) "dir" 104) "/usr/local/redis/var" 105) "maxmemory-policy" 106) "volatile-lru" 107) "appendfsync" 108) "always" 109) "save" 110) "900 1 300 10 60 10000" 111) "loglevel" 112) "debug" 113) "client-output-buffer-limit" 114) "normal 0 0 0 slave 268435456 67108864 60 pubsub 33554432 8388608 60" 115) "unixsocketperm" 116) "0" 117) "slaveof" 118) "" 119) "notify-keyspace-events" 120) "" 121) "bind" 122) ""
2、Redis通用配置
1)daemonize no //默認情況下redis并不是以daemon形式來運行的,通過daemonize配置項可以控制redis的運行方式。
2)pidfile /path/to/redis.pid //當以daemon形式運行時,redis會默認生成一個pid文件/var/run/redis.pid
3)bind 192.168.1.2 10.8.4.2 //指定綁定的ip,可以有多個
4)port 6379 //指定監聽端口
5)unixsocket /tmp/redis.sock //也可以監聽socket
6)unixsocketperm 755 //當監聽socket時可以指定權限為755
7)timeout 0 //當一個redis-client一直沒有請求發出server端,那么server端有權主動關閉這個連接,可以通過timeout來設置“空閑超時時限”,0表示永不關閉。
8)tcp-keepalive 0 //tcp連接保活策略,可以通過tcp-keepalive配置項來進行設置,單位為秒,假如設置為60秒,則server端會每60秒向連接空閑的客戶端發起一次ACK請求,以檢查客戶端是否已經掛掉,對于無響應的客戶端則會關閉其連接。如果設置為0,則不會進行保活檢測。
9)loglevel notice //日志級別,有debug、verbose、notice、warning四種。
10)logfile "" //定義日志路徑
11)syslog-ident redis //如果希望日志打印到syslog中,通過syslog-enabled來控制。另外,syslog-ident還可以讓你指定syslog里的日志標志。
12)syslog-facility local0 //指定syslog的設備,可以是USER或者local0-local7
13)databases 16 //設置數據庫的總數量,select n選擇數據庫,0-15
3、Redis快照配置(RDB持久化)
1)save 900 1 //表示每15分鐘且至少有1個key改變,就觸發一次持久化
2)save 300 10 //表示每5分鐘且至少有10個key改變,就觸發一次持久化
3)save 60 10000 //表示每60秒且至少有10000個key改變,就觸發一次持久化
4)save "" //這樣可以禁用RDB持久化
5)stop-writes-on-bgsave-error yes //RDB持久化寫入磁盤避免不了會出現失敗的情況,默認一旦出現失敗,redis會馬上停止寫操作。如果你覺得無所謂,那就可以使用該選項關閉這個功能。
6)rdbcompression yes //是否要壓縮
7)rdbchecksum yes //是否進行數據校驗
8)dbfilename dump.rdb //定義快照文件的名字
9)dir ./ //定義快照文件存儲路徑
4、Redis安全相關配置
1)requirepass 123456 //設置redis-server的密碼,登入命令為:redis-cli -a 123456
2)rename-command config tpplinux.config //將config命令更名為tpplinux.config,這樣可以避免誤操作,但如果使用了AOF持久化,建議不要啟用該功能。
3)rename-command config "" //定義為空,表示禁掉了config命令。
5、Redis限制相關配置
1)maxclients 10000 //限制最大客戶端連接數
2)maxmemory <bytes> //設定最大內存使用數,單位是byte
3)maxmemory-policy volatile-lru //指定內存移除規則
4)maxmemory-samples 3 //LRU算法和最小TTL算法都并非是精確的算法,而是估算值。所以你可以設置樣本的大小。假如redis默認會檢查三個key,并選擇其中LRU的那個,那么你可以改變這個key樣本的數量。
6、Redis AOF持久化相關配置
1)appendonly yes //開啟持久化
2)appendfilename "appendonly.aof" //指定aof文件(二進制日志形式)名字,保存在dir參數指定的目錄
3)appendfsync everysec //指定fsync()調用模式,有三種:no(不調用fsync)、always(每次寫都會調用fsync)、ecverysec(每秒鐘調用一次fsync)。第一種最快;第二種數據最安全,但性能會差一些;第三種為這種方案,默認為第三種。
4)no-appendfsync-on-reweite no //使用no可避免當寫入量非常大時的磁盤io阻塞。
5)auto-aof-rewrite-percentage 10 //規定什么情況下會觸發aof重寫。該值為一個比例,10表示當aof文件增幅達到10%時則會觸發重寫機制。
6)auto-aof-rewrite-min-size 64mb //重寫會有一個條件,就是不能低于64MB
7、Redis 慢日志相關配置
針對慢日志,可以設置兩個參數,一個是執行時長,單位是微秒;另一個是慢日志的長度。當一個新的命令被寫入日志時,最老的一條會從命令日志隊列中被移除。
1)slowlog-log-slower-than 10000 //慢于10000微秒,則記錄日志
2)slowlog-max-len 128 //日志長度
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。