Redis安裝 java
1.拷貝到/opt目錄下 解壓 tar -zxvf redis.gz 2.make 命令 建立文件夾 mkdir myredis 進入redis文件夾 拷貝配置文件到新的目錄下 cp redis.conf /myredis/
3.找到redis安裝目錄 cd /opt/redis-3.0.4/src 4.執行./redis-server /myredis//redis.conf 開啓服務端
5.執行./redis-cli -p 6379 開啓客戶端 6.退出 shutdown exit
單進程
以Epoll包裝在大批量文件處理裏面多路的IO複用 Linux內核爲基礎,爲處理大批量文件而改進的Epoll,是Linux下多路複用IO接口select/poll的加強版本 能顯著提升程序在大量併發鏈接中只有少許活躍的狀況下的系統CPU利用率 16個數據庫 根據 select 命令切換數據庫 從0開始 到15 Dbsize :查看當前數據庫的key數量 keys * :查看全部的數據 keys k? flushdb:清空當前數據庫 flushall:清空全部數據庫
數據類型 String(字符串) 最基本的類型,一個key對應一個value。 二進制安全的。能夠包含jpg圖片或者序列化對象。 一個redis字符串最多能夠是512M。 Hash(哈希,相似java裏的Map) 是一個鍵值對集合。 是一個string類型的field和value的映射表,hash特別適用於存儲對象。 相似於Java裏面的Map<String,Object> List (列表) 簡單的字符串列表,按照插入順序排序。你能夠添加一個元素到列表的頭部或者尾部 底層是一個鏈表 Set (集合) string類型的無序集合。經過HashTable實現的。 Zset(sorted set:有序集合) 和set同樣是string類型的元素的集合,且不容許重複的成員 不一樣的是每一個元素都會關聯一個double類型的分數。 redis正式經過分數來爲集合的成員進行從小到大的排序。zset的成員是惟一的,但分數能夠重複。 Key鍵: exists key的名字,判斷某個key是否存在 move key db ---> 當前庫就沒有了,被移除了 expire key 秒鐘: 爲給定的key設置過時時間 ttl key 查看還有多少秒過時,-1表示永不過時,-2表示已過時 typ e key 查看你的key是什麼類型 String del key 刪除鍵 append key value 追加 strlen key 獲取值長度 incr 遞增 decr 遞減 incrby key 2 一次加2 decrby key 3 一次減3 getrange key [區間] 範圍內取值 setrange key [區間] 範圍內設置值 setex k4 10 v4 k4存活時間爲10秒 setnx k1 v11 當k1不存在值時設置值爲v11 mset k1 v1 k2 v2 k3 v3 mget k1 k2 k3 一次設置多個 List lpush list01 1 2 3 4 5 lrange list01 0 -1 rpush list02 1 2 3 4 5 lpop key 出棧 rpop key lindex key 索引 查看key的 llen key 鍵的長度 lrem list03 2 3 刪除2個3 ltrim list1 3 5 截取3-5字符串複製給list1 Set 不容許重複數據 127.0.0.1:6379> sadd s01 1 1 2 2 3 3 (integer) 3 127.0.0.1:6379> SMEMBERS s01 scard 獲取集合裏面的元素個數 srem key value 刪除集合中元素 srandmember key 某個整數(隨機出幾個數) spop key 隨機出棧 smove key1 key2 在key1裏某個值 做用是將key1裏的某個值賦給key2 在第一個key裏面 不在第二個key裏面 sdlff 差集 key1 key2 sinter 交集 key1 key2 sunion 並集 key1 key2 Hash(哈希,相似java裏的Map) KV模式不變,但V是一個鍵值對 hset user id 11 hget user id HMSET Teacher name li4 age 12 id 1 HMGET Teacher name HGETALL Teacher hexists key 在key裏面的某個值的key hkeys/hvals 獲得key或者values hincrby/hincrbyfloat 增長值 hsetnx 不存在則添加 Zset(sorted set) 在set基礎上,加一個score值。以前set是 k1 v1 v2 v3, 如今zset是看 score1 v1 score2 v2 limit 截取 zadd /zrange zadd zset01 60 v1 70 v2 80 v3 90 v4 100 v5 ZRANGE zset01 0 -1 withscores ZRANGEBYSCORE zset01 60 90 ZRANGEBYSCORE zset01 60 (90 90>x>=60 zrem key 某score下對應的value值,做用是刪除元素 zcard key 統計key的個數
redis配置文件解釋 #是否在後臺執行,yes:後臺運行;no:不是後臺運行(老版本默認) daemonize yes 是否開啓保護模式,默認開啓。要是配置裏沒有指定bind和密碼。開啓該參數後,redis只會本地進行訪問,拒絕外部訪問。要是開啓了密碼 和bind,能夠開啓。否 則最好關閉,設置爲no。 protected-mode yes #redis的進程文件 pidfile /var/run/redis/redis-server.pid #redis監聽的端口號。 port 6379 #指定 redis 只接收來自於該 IP 地址的請求,若是不進行設置,那麼將處理全部請求 bind 127.0.0.1 # 此參數爲設置客戶端空閒超過timeout,服務端會斷開鏈接,爲0則服務端不會主動斷開鏈接,不能小於0。 timeout 0 #tcp keepalive參數。若是設置不爲0,就使用配置tcp的SO_KEEPALIVE值,使用keepalive有兩個好處:檢測掛掉的對端。
下降中間設備出問題而致使網絡看似鏈接卻已經與對端端口的問題。在Linux內核中,設置了keepalive,redis會定時給對端發送ack。檢測到對端關閉須要兩倍的設置值。 tcp-keepalive 0 #指定了服務端日誌的級別。級別包括:debug(不少信息,方便開發、測試),verbose(許多有用的信息,可是沒有debug級別信息多),notice(適當的日誌級別,適合生產環境),warn(只有很是重要的信息) loglevel notice #指定了記錄日誌的文件。空字符串的話,日誌會打印到標準輸出設備。後臺運行的redis標準輸出是/dev/null。 logfile /var/log/redis/redis-server.log #是否打開記錄syslog功能 # syslog-enabled no #syslog的標識符。 # syslog-ident redis #日誌的來源、設備 # syslog-facility local0 #數據庫的數量,默認使用的數據庫是DB 0。能夠經過」SELECT 「命令選擇一個db databases 16 ################################ SNAPSHOTTING ################################ # 快照配置 # 註釋掉「save」這一行配置項就可讓保存數據庫功能失效 # 設置sedis進行數據庫鏡像的頻率。 # 900秒(15分鐘)內至少1個key值改變(則進行數據庫保存--持久化) # 300秒(5分鐘)內至少10個key值改變(則進行數據庫保存--持久化) # 60秒(1分鐘)內至少10000個key值改變(則進行數據庫保存--持久化) save 900 1 save 300 10 save 60 10000 #當RDB持久化出現錯誤後,是否依然進行繼續進行工做,yes:不能進行工做,no:能夠繼續進行工做,能夠經過info中的rdb_last_bgsave_status瞭解RDB持久化是否有錯誤 stop-writes-on-bgsave-error yes #使用壓縮rdb文件,rdb文件壓縮使用LZF壓縮算法,yes:壓縮,可是須要一些cpu的消耗。no:不壓縮,須要更多的磁盤空間 rdbcompression yes #是否校驗rdb文件。從rdb格式的第五個版本開始,在rdb文件的末尾會帶上CRC64的校驗和。這跟有利於文件的容錯性,可是在保存rdb文件的時候,會有大概10%的性能損耗,因此若是你追求高性能,能夠關閉該配置。 rdbchecksum yes #rdb文件的名稱 dbfilename dump.rdb #數據目錄,數據庫的寫入會在這個目錄。rdb、aof文件也會寫在這個目錄 dir /var/lib/redis ################################# REPLICATION ################################# #複製選項,slave複製對應的master。 # slaveof <masterip> <masterport> #若是master設置了requirepass,那麼slave要連上master,須要有master的密碼才行。masterauth就是用來配置master的密碼,這樣能夠在連上master後進行認證。 # masterauth <master-password> #當從庫同主機失去鏈接或者複製正在進行,從機庫有兩種運行方式:1) 若是slave-serve-stale-data設置爲yes(默認設置),從庫會繼續響應客戶端的請求。2) 若是slave-serve-stale-data設置爲no,除去INFO和SLAVOF命令以外的任何請求都會返回一個錯誤」SYNC with master in progress」。 slave-serve-stale-data yes #做爲從服務器,默認狀況下是隻讀的(yes),能夠修改爲NO,用於寫(不建議)。 slave-read-only yes #是否使用socket方式複製數據。目前redis複製提供兩種方式,disk和socket。若是新的slave連上來或者重連的slave沒法部分同步,就會執行全量同步,master會生成rdb文件。有2種方式:disk方式是master建立一個新的進程把rdb文件保存到磁盤,再把磁盤上的rdb文件傳遞給slave。socket是master建立一個新的進程,直接把rdb文件以socket的方式發給slave。disk方式的時候,當一個rdb保存的過程當中,多個slave都能共享這個rdb文件。socket的方式就的一個個slave順序複製。在磁盤速度緩慢,網速快的狀況下推薦用socket方式。 repl-diskless-sync no #diskless複製的延遲時間,防止設置爲0。一旦複製開始,節點不會再接收新slave的複製請求直到下一個rdb傳輸。因此最好等待一段時間,等更多的slave連上來。 repl-diskless-sync-delay 5 #slave根據指定的時間間隔向服務器發送ping請求。時間間隔能夠經過 repl_ping_slave_period 來設置,默認10秒。 # repl-ping-slave-period 10 #複製鏈接超時時間。master和slave都有超時時間的設置。master檢測到slave上次發送的時間超過repl-timeout,即認爲slave離線,清除該slave信息。slave檢測到上次和master交互的時間超過repl-timeout,則認爲master離線。須要注意的是repl-timeout須要設置一個比repl-ping-slave-period更大的值,否則會常常檢測到超時。 # repl-timeout 60 #是否禁止複製tcp連接的tcp nodelay參數,可傳遞yes或者no。默認是no,即便用tcp nodelay。若是master設置了yes來禁止tcp nodelay設置,在把數據複製給slave的時候,會減小包的數量和更小的網絡帶寬。可是這也可能帶來數據的延遲。默認咱們推薦更小的延遲,可是在數據量傳輸很大的場景下,建議選擇yes。 repl-disable-tcp-nodelay no #複製緩衝區大小,這是一個環形複製緩衝區,用來保存最新複製的命令。這樣在slave離線的時候,不須要徹底複製master的數據,若是能夠執行部分同步,只須要把緩衝區的部分數據複製給slave,就能恢復正常複製狀態。緩衝區的大小越大,slave離線的時間能夠更長,複製緩衝區只有在有slave鏈接的時候才分配內存。沒有slave的一段時間,內存會被釋放出來,默認1m。 # repl-backlog-size 5mb #master沒有slave一段時間會釋放複製緩衝區的內存,repl-backlog-ttl用來設置該時間長度。單位爲秒。 # repl-backlog-ttl 3600 #當master不可用,Sentinel會根據slave的優先級選舉一個master。最低的優先級的slave,當選master。而配置成0,永遠不會被選舉。 slave-priority 100 #redis提供了可讓master中止寫入的方式,若是配置了min-slaves-to-write,健康的slave的個數小於N,mater就禁止寫入。master最少得有多少個健康的slave存活才能執行寫命令。這個配置雖然不能保證N個slave都必定能接收到master的寫操做,可是能避免沒有足夠健康的slave的時候,master不能寫入來避免數據丟失。設置爲0是關閉該功能。 # min-slaves-to-write 3 #延遲小於min-slaves-max-lag秒的slave才認爲是健康的slave。 # min-slaves-max-lag 10 # 設置1或另外一個設置爲0禁用這個特性。 # Setting one or the other to 0 disables the feature. # By default min-slaves-to-write is set to 0 (feature disabled) and # min-slaves-max-lag is set to 10. ################################## SECURITY ################################### #requirepass配置可讓用戶使用AUTH命令來認證密碼,才能使用其餘命令。這讓redis可使用在不受信任的網絡中。爲了保持向後的兼容性,能夠註釋該命令,由於大部分用戶也不須要認證。使用requirepass的時候須要注意,由於redis太快了,每秒能夠認證15w次密碼,簡單的密碼很容易被攻破,因此最好使用一個更復雜的密碼。 # requirepass foobared #把危險的命令給修改爲其餘名稱。好比CONFIG命令能夠重命名爲一個很難被猜到的命令,這樣用戶不能使用,而內部工具還能接着使用。 # rename-command CONFIG b840fc02d524045429941cc15f59e41cb7be6c52 #設置成一個空的值,能夠禁止一個命令 # rename-command CONFIG "" ################################### LIMITS #################################### # 設置能連上redis的最大客戶端鏈接數量。默認是10000個客戶端鏈接。因爲redis不區分鏈接是客戶端鏈接仍是內部打開文件或者和slave鏈接等,因此maxclients最小建議設置到32。若是超過了maxclients,redis會給新的鏈接發送’max number of clients reached’,並關閉鏈接。 # maxclients 10000 #redis配置的最大內存容量。當內存滿了,須要配合maxmemory-policy策略進行處理。注意slave的輸出緩衝區是不計算在maxmemory內的。因此爲了防止主機內存使用完,建議設置的maxmemory須要更小一些。 # maxmemory <bytes> #內存容量超過maxmemory後的處理策略。 #volatile-lru:利用LRU算法移除設置過過時時間的key。 #volatile-random:隨機移除設置過過時時間的key。 #volatile-ttl:移除即將過時的key,根據最近過時時間來刪除(輔以TTL) #allkeys-lru:利用LRU算法移除任何key。 #allkeys-random:隨機移除任何key。 #noeviction:不移除任何key,只是返回一個寫錯誤。 #上面的這些驅逐策略,若是redis沒有合適的key驅逐,對於寫命令,仍是會返回錯誤。redis將再也不接收寫請求,只接收get請求。寫命令包括:set setnx setex append incr decr rpush lpush rpushx lpushx linsert lset rpoplpush sadd sinter sinterstore sunion sunionstore sdiff sdiffstore zadd zincrby zunionstore zinterstore hset hsetnx hmset hincrby incrby decrby getset mset msetnx exec sort。 # maxmemory-policy noeviction #lru檢測的樣本數。使用lru或者ttl淘汰算法,從須要淘汰的列表中隨機選擇sample個key,選出閒置時間最長的key移除。 # maxmemory-samples 5 ############################## APPEND ONLY MODE ############################### #默認redis使用的是rdb方式持久化,這種方式在許多應用中已經足夠用了。可是redis若是中途宕機,會致使可能有幾分鐘的數據丟失,根據save來策略進行持久化,Append Only File是另外一種持久化方式,能夠提供更好的持久化特性。Redis會把每次寫入的數據在接收後都寫入 appendonly.aof 文件,每次啓動時Redis都會先把這個文件的數據讀入內存裏,先忽略RDB文件。 appendonly no #aof文件名 appendfilename "appendonly.aof" #aof持久化策略的配置 #no表示不執行fsync,由操做系統保證數據同步到磁盤,速度最快。 #always表示每次寫入都執行fsync,以保證數據同步到磁盤。 #everysec表示每秒執行一次fsync,可能會致使丟失這1s數據。 appendfsync everysec # 在aof重寫或者寫入rdb文件的時候,會執行大量IO,此時對於everysec和always的aof模式來講,執行fsync會形成阻塞過長時間,no-appendfsync-on-rewrite字段設置爲默認設置爲no。若是對延遲要求很高的應用,這個字段能夠設置爲yes,不然仍是設置爲no,這樣對持久化特性來講這是更安全的選擇。設置爲yes表示rewrite期間對新寫操做不fsync,暫時存在內存中,等rewrite完成後再寫入,默認爲no,建議yes。Linux的默認fsync策略是30秒。可能丟失30秒數據。 no-appendfsync-on-rewrite no #aof自動重寫配置。當目前aof文件大小超過上一次重寫的aof文件大小的百分之多少進行重寫,即當aof文件增加到必定大小的時候Redis可以調用bgrewriteaof對日誌文件進行重寫。當前AOF文件大小是上第二天志重寫獲得AOF文件大小的二倍(設置爲100)時,自動啓動新的日誌重寫過程。 auto-aof-rewrite-percentage 100 #設置容許重寫的最小aof文件大小,避免了達到約定百分比但尺寸仍然很小的狀況還要重寫 auto-aof-rewrite-min-size 64mb #aof文件可能在尾部是不完整的,當redis啓動的時候,aof文件的數據被載入內存。重啓可能發生在redis所在的主機操做系統宕機後,尤爲在ext4文件系統沒有加上data=ordered選項(redis宕機或者異常終止不會形成尾部不完整現象。)出現這種現象,能夠選擇讓redis退出,或者導入儘量多的數據。若是選擇的是yes,當截斷的aof文件被導入的時候,會自動發佈一個log給客戶端而後load。若是是no,用戶必須手動redis-check-aof修復AOF文件才能夠。 aof-load-truncated yes ################################ LUA SCRIPTING ############################### # 若是達到最大時間限制(毫秒),redis會記個log,而後返回error。當一個腳本超過了最大時限。只有SCRIPT KILL和SHUTDOWN NOSAVE能夠用。第一個能夠殺沒有調write命令的東西。要是已經調用了write,只能用第二個命令殺。 lua-time-limit 5000 ################################ REDIS CLUSTER ############################### #集羣開關,默認是不開啓集羣模式。 # cluster-enabled yes #集羣配置文件的名稱,每一個節點都有一個集羣相關的配置文件,持久化保存集羣的信息。這個文件並不須要手動配置,這個配置文件有Redis生成並更新,每一個Redis集羣節點須要一個單獨的配置文件,請確保與實例運行的系統中配置文件名稱不衝突 # cluster-config-file nodes-6379.conf #節點互連超時的閥值。集羣節點超時毫秒數 # cluster-node-timeout 15000 #在進行故障轉移的時候,所有slave都會請求申請爲master,可是有些slave可能與master斷開鏈接一段時間了,致使數據過於陳舊,這樣的slave不該該被提高爲master。該參數就是用來判斷slave節點與master斷線的時間是否過長。判斷方法是: #比較slave斷開鏈接的時間和(node-timeout * slave-validity-factor) + repl-ping-slave-period #若是節點超時時間爲三十秒, 而且slave-validity-factor爲10,假設默認的repl-ping-slave-period是10秒,即若是超過310秒slave將不會嘗試進行故障轉移 # cluster-slave-validity-factor 10 #master的slave數量大於該值,slave才能遷移到其餘孤立master上,如這個參數若被設爲2,那麼只有當一個主節點擁有2 個可工做的從節點時,它的一個從節點會嘗試遷移。 # cluster-migration-barrier 1 #默認狀況下,集羣所有的slot有節點負責,集羣狀態才爲ok,才能提供服務。設置爲no,能夠在slot沒有所有分配的時候提供服務。不建議打開該配置,這樣會形成分區的時候,小分區的master一直在接受寫請求,而形成很長時間數據不一致。 # cluster-require-full-coverage yes ################################## SLOW LOG ################################### ###slog log是用來記錄redis運行中執行比較慢的命令耗時。當命令的執行超過了指定時間,就記錄在slow log中,slog log保存在內存中,因此沒有IO操做。 #執行時間比slowlog-log-slower-than大的請求記錄到slowlog裏面,單位是微秒,因此1000000就是1秒。注意,負數時間會禁用慢查詢日誌,而0則會強制記錄全部命令。 slowlog-log-slower-than 10000 #慢查詢日誌長度。當一個新的命令被寫進日誌的時候,最老的那個記錄會被刪掉。這個長度沒有限制。只要有足夠的內存就行。你能夠經過 SLOWLOG RESET 來釋放內存。 slowlog-max-len 128 ################################ LATENCY MONITOR ############################## #延遲監控功能是用來監控redis中執行比較緩慢的一些操做,用LATENCY打印redis實例在跑命令時的耗時圖表。只記錄大於等於下邊設置的值的操做。0的話,就是關閉監視。默認延遲監控功能是關閉的,若是你須要打開,也能夠經過CONFIG SET命令動態設置。 latency-monitor-threshold 0 ############################# EVENT NOTIFICATION ############################## #鍵空間通知使得客戶端能夠經過訂閱頻道或模式,來接收那些以某種方式改動了 Redis 數據集的事件。由於開啓鍵空間通知功能須要消耗一些 CPU ,因此在默認配置下,該功能處於關閉狀態。 #notify-keyspace-events 的參數能夠是如下字符的任意組合,它指定了服務器該發送哪些類型的通知: ##K 鍵空間通知,全部通知以 __keyspace@__ 爲前綴 ##E 鍵事件通知,全部通知以 __keyevent@__ 爲前綴 ##g DEL 、 EXPIRE 、 RENAME 等類型無關的通用命令的通知 ##$ 字符串命令的通知 ##l 列表命令的通知 ##s 集合命令的通知 ##h 哈希命令的通知 ##z 有序集合命令的通知 ##x 過時事件:每當有過時鍵被刪除時發送 ##e 驅逐(evict)事件:每當有鍵由於 maxmemory 政策而被刪除時發送 ##A 參數 g$lshzxe 的別名 #輸入的參數中至少要有一個 K 或者 E,不然的話,無論其他的參數是什麼,都不會有任何 通知被分發。詳細使用能夠參考http://redis.io/topics/notifications notify-keyspace-events "" ############################### ADVANCED CONFIG ############################### #數據量小於等於hash-max-ziplist-entries的用ziplist,大於hash-max-ziplist-entries用hash hash-max-ziplist-entries 512 #value大小小於等於hash-max-ziplist-value的用ziplist,大於hash-max-ziplist-value用hash。 hash-max-ziplist-value 64 #數據量小於等於list-max-ziplist-entries用ziplist,大於list-max-ziplist-entries用list。 list-max-ziplist-entries 512 #value大小小於等於list-max-ziplist-value的用ziplist,大於list-max-ziplist-value用list。 list-max-ziplist-value 64 #數據量小於等於set-max-intset-entries用iniset,大於set-max-intset-entries用set。 set-max-intset-entries 512 #數據量小於等於zset-max-ziplist-entries用ziplist,大於zset-max-ziplist-entries用zset。 zset-max-ziplist-entries 128 #value大小小於等於zset-max-ziplist-value用ziplist,大於zset-max-ziplist-value用zset。 zset-max-ziplist-value 64 #value大小小於等於hll-sparse-max-bytes使用稀疏數據結構(sparse),大於hll-sparse-max-bytes使用稠密的數據結構(dense)。
一個比16000大的value是幾乎沒用的,建議的value大概爲3000。若是對CPU要求不高,對空間要求較高的,建議設置到10000左右。 hll-sparse-max-bytes 3000 #Redis將在每100毫秒時使用1毫秒的CPU時間來對redis的hash表進行從新hash,能夠下降內存的使用。當你的使用場景中,有很是嚴格的實時性須要,不可以接受Redis時不時的對請求有2毫秒的延遲的話,把這項配置爲no。
若是沒有這麼嚴格的實時性要求,能夠設置爲yes,以便可以儘量快的釋放內存。 activerehashing yes ##對客戶端輸出緩衝進行限制能夠強迫那些不從服務器讀取數據的客戶端斷開鏈接,用來強制關閉傳輸緩慢的客戶端。 #對於normal client,第一個0表示取消hard limit,第二個0和第三個0表示取消soft limit,normal client默認取消限制,由於若是沒有尋問,他們是不會接收數據的。 client-output-buffer-limit normal 0 0 0 #對於slave client和MONITER client,若是client-output-buffer一旦超過256mb,又或者超過64mb持續60秒,那麼服務器就會當即斷開客戶端鏈接。 client-output-buffer-limit slave 256mb 64mb 60 #對於pubsub client,若是client-output-buffer一旦超過32mb,又或者超過8mb持續60秒,那麼服務器就會當即斷開客戶端鏈接。 client-output-buffer-limit pubsub 32mb 8mb 60 #redis執行任務的頻率爲1s除以hz。 hz 10 #在aof重寫的時候,若是打開了aof-rewrite-incremental-fsync開關,系統會每32MB執行一次fsync。這對於把文件寫入磁盤是有幫助的,能夠避免過大的延遲峯值。 aof-rewrite-incremental-fsync yes
RDB持久化 RDB持久化是指在指定的時間間隔內將內存中的數據集快照寫入磁盤,實際操做過程是fork一個子進程,先將數據集寫入臨時文件,寫入成功後,再替換以前的文件,用二進制壓縮存儲。 即在指定目錄下生成一個dump.rdb文件。Redis 重啓會經過加載dump.rdb文件恢復數據。 經過RDB文件恢復數據 將dump.rdb 文件拷貝到redis的安裝目錄的bin目錄下,重啓redis服務便可。在實際開發中,通常會考慮到物理機硬盤損壞狀況,選擇備份dump.rdb 。能夠從下面的操做演示中能夠體會到。 RDB 的優缺點 優勢: 1 適合大規模的數據恢復。 2 若是業務對數據完整性和一致性要求不高,RDB是很好的選擇。 缺點: 1 數據的完整性和一致性不高,由於RDB可能在最後一次備份時宕機了。 2 備份時佔用內存,由於Redis 在備份時會獨立建立一個子進程,將數據寫入到一個臨時文件(此時內存中的數據是原來的兩倍哦),最後再將臨時文件替換以前的備份文件。 因此Redis 的持久化和數據的恢復要選擇在夜深人靜的時候執行是比較合理的。
AOF持久化 AOF(Append Only File)<二進制文件>比RDB方式有更好的持久化性。因爲在使用AOF持久化方式時,Redis會將每個收到的寫命令都經過Write函數追加到文件最後,相似於MySQL的binlog。
當Redis重啓是會經過從新執行文件中保存的寫命令來在內存中重建整個數據庫的內容。 AOF的徹底持久化方式同時也帶來了另外一個問題,持久化文件會變得愈來愈大。(好比咱們調用INCR test命令100次,文件中就必須保存所有的100條命令,但其實99條都是多餘的。
由於要恢復數據庫的狀態其實文件中保存一條SET test 100就夠了)。爲了合併重寫AOF的持久化文件,Redis提供了bgrewriteaof命令。 收到此命令後Redis將使用與快照相似的方式將內存中的數據以命令的方式保存到臨時文件中,最後替換原來的文件,以此來實現控制AOF文件的合併重寫。
因爲是模擬快照的過程,所以在重寫AOF文件時並無讀取舊的AOF文件,而是將整個內存中的數據庫內容用命令的方式重寫了一個新的AOF文件。 AOF文件出現問題時 使用 redis-check-aof --fix appendonly.aof 修復
Redis調用持久化過程 1. redis調用fork ,如今有父子兩個進程 2. 子進程根據內存中的數據庫快照,往臨時文件中寫入重建數據庫狀態的命令 3.父進程繼續處理client請求,除了把寫命令寫入到原來的aof文件中。同時把收到的寫命令緩存起來。這樣就能保證若是子進程重寫失敗的話並不會出問題。 4.當子進程把快照內容寫入已命令方式寫到臨時文件中後,子進程發信號通知父進程。而後父進程把緩存的寫命令也寫入到臨時文件。 5.如今父進程可使用臨時文件替換老的aof文件,並重命名,後面收到的寫命令也開始往新的aof文件中追加。 Redis事務 事務是一個單獨的隔離操做:事務中的全部命令都會序列化、按順序地執行。事務在執行的過程當中,不會被其餘客戶端發送來的命令請求所打斷。 事務是一個原子操做:事務中的命令要麼所有被執行,要麼所有都不執行。 事務命令 1 DISCARD 取消事務,放棄執行事務塊內的全部命令。 2 EXEC 執行全部事務塊內的命令。 3 MULTI 標記一個事務塊的開始。 4 UNWATCH 取消 WATCH 命令對全部 key 的監視。 5 WATCH key [key ...] 監視一個(或多個) key ,若是在事務執行以前這個(或這些) key 被其餘命令所改動,那麼事務將被打斷。 Redis事務三階段: 開啓:以MULTI開始一個事務 入隊:將多個命令入隊到事務中,接到這些命令並不會當即執行,而是放到等待執行的事務隊列裏面 執行:由EXEC命令觸發事務
Redis事務三大特性:
單獨的隔離操做:事務中的全部命令都會序列化、按順序地執行。事務在執行的過程當中,不會被其餘客戶端發送來的命令請求所打斷。 沒有隔離級別的概念:隊列中的命令沒有提交以前都不會實際的被執行,由於事務提交前任何指令都不會被實際執行,也就不存在」事務內的查詢要看到事務裏的更新,在事務外查詢不能看到」這個讓人萬分頭痛的問題 不保證原子性:redis同一個事務中若是有一條命令執行失敗,其後的命令仍然會被執行,沒有回滾 即Redis對事務是部分支持的,若是是在入隊時報錯,那麼都不會執行;在非入隊時報錯,那麼成功的就會成功執行 Redis監控:鎖的介紹 在MySQL中咱們都知道有行鎖和表鎖的概念,所謂的行鎖也就是把我須要改的那一行給鎖住,不讓其餘的事務去修改;而表鎖就是在修改一張表的時候把整張表都鎖住,不讓其餘的事務修改,因此行鎖的效率比表鎖的概念更高,那麼在redis也存在鎖的概念 樂觀鎖(Optimistic Lock): 顧名思義,就是很樂觀,每次去拿數據的時候都認爲別人不會修改,因此不會上鎖,可是在更新的時候會判斷一下在此期間別人有沒有去更新這個數據,可使用版本號等機制。
樂觀鎖適用於多讀的應用類型,這樣能夠提升吞吐量,樂觀鎖策略:提交版本必須大於記錄當前版本才能執行更新 悲觀鎖(Pessimistic Lock): 顧名思義,就是很悲觀,每次去拿數據的時候都認爲別人會修改,因此每次在拿數據的時候都會上鎖,這樣別人想拿這個數據就會block直到它拿到鎖。
傳統的關係型數據庫裏邊就用到了不少這種鎖機制,好比行鎖,表鎖等,讀鎖,寫鎖等,都是在作操做以前先上鎖
Redis主從複製 info replication 查看主從複製信息 Redis 支持簡單且易用的主從複製(master-slave replication)功能, 該功能可讓從服務器(slave server)成爲主服務器(master server)的精確複製品。 配置一個從服務器很是簡單, 只要在配置文件中增長如下的這一行就能夠了: slaveof 192.168.1.1 6379 另一種方法是調用 SLAVEOF 命令,輸入主服務器的 IP 和端口,而後同步就會開始 127.0.0.1:6379> SLAVEOF 192.168.1.1 10086 OK 從機變主機 SLAVEOF NO ONE Redis全量複製通常發生在Slave初始化階段,這時Slave須要將Master上的全部數據都複製一份。具體步驟以下: 1)從服務器鏈接主服務器,發送SYNC命令; 2)主服務器接收到SYNC命名後,開始執行BGSAVE命令生成RDB文件並使用緩衝區記錄此後執行的全部寫命令; 3)主服務器BGSAVE執行完後,向全部從服務器發送快照文件,並在發送期間繼續記錄被執行的寫命令; 4)從服務器收到快照文件後丟棄全部舊數據,載入收到的快照; 5)主服務器快照發送完畢後開始向從服務器發送緩衝區中的寫命令; 6)從服務器完成對快照的載入,開始接收命令請求,並執行來自主服務器緩衝區的寫命令; 一主二僕: 顧名思義,這種策略的具體實現就是使用一臺機器做爲主機,兩臺機器做爲備機(真正工做可能多臺),主機主要是寫入,備機主要是讀取。須要注意的是,再使用主從複製的時候,是配置備機,主機不動(默認狀態是master,從機須要改變master狀態到slaver)。 配置命令:slaveof + 主機ip + 主機端口, 反客爲主: 顧名思義,他的意思就是說從機代替原來主機的位置變成了新的master,我如今恢復一主二僕的結構,而後將主機退出,按照上一篇講的內容能夠知道主機斷開鏈接以後,他的從機會原地待命,這個時候,若是主機遲遲不能恢復工做,那麼咱們就必須尋求一種方法來是系統可以繼續正常運行,理所固然的是從這些從機之中選擇一個成爲新的主機,而後將其他的從機鏈接到這個新的主機上面,構成一個新的體系。 將從機變成主機使用到的命令式slaveof on one ,將其餘從機鏈接到這個主機使用的命令依然是slaveof 哨兵模式: 哨兵模式說白了就是將反客爲主的一些列動做自動化,他會在後臺有一個監控,監控當前的主機,巡邏主機下面的從機,若是某一時刻主機掛掉了,那麼他會經過一種投票的機制從從機之中選舉一臺做爲新的主機,而且,其他的從機將會鏈接到這個新的主機上面。 1. 首先,在/myredis下面新建一個sentinel.conf文件:touch sentinel.conf,在其中設置監控的主機以及投票策略,其格式爲:sentinel monitor 主機名 主機ip 主機端口 票數n 票數多餘n的從機做爲主機 而後經過redis-sentinel命令執行這個文件,爲主機開啓哨兵. Redis入職機制的缺點: 有延遲,從機越多,延遲多嚴重
數據庫事務的ACID特性 1、原子性(Atomicity) 事務的原子性是指事務中包含的全部操做要麼都作,要麼都不作,保證數據庫是一致的。 例如:A賬戶向B賬戶劃帳1000,則先將A減小1000,再將B增長1000,這兩個動做要麼都提交,要麼都回退,不可能發生一個有效、一個無效的狀況。 2、一致性(Consistency) 一致性是指數據庫在事務操做前和事務處理後,其中的數據必須都知足業務規則約束。 例如:A、B賬戶的總金額在轉帳前和轉賬後必須一致,其中的不一致必須是短暫的,在事務提交前纔會出現的。 再如:約定B賬戶不能多於1000元,則A轉出1000成功,B轉入1000失敗,最終由原子性獲得——整個事務回滾 3、隔離性(Isolation) 隔離性是數據庫容許多個併發事務同時對齊數據進行讀寫和修改的能力,隔離性能夠防止多個事務併發執行時因爲交叉執行而致使數據的不一致。 例如:在A、B之間轉賬時,C同時向A轉賬,若同時進行則A、B之間的一致性不能獲得知足。因此在A、B事務執行過程當中,其餘事務不能訪問(修改)當前相關的數值。 4、持久性(Durability) 持久性表示爲:事務處理結束後,對數據的修改就是永久的,即使系統故障也不會丟失。 在提交以前若是系統故障,則全部信息所有丟失。提交以後數據存放在磁盤中,是永久性的。
事務的控制 事務的開始是隱形聲明的,不用也沒有語句能夠進行操做,默認從對數據的修改開始就開始了當前事務。 對數據庫的設置主要有一下語句: SET TRANSACTION-----設置事務屬性 SET CONSTRANS-------設置約束模式 SAVEPOINT-----------創建存儲點 RELEASE SAVEPOINT---釋放存儲點 ROLLBACK------------回滾 COMMIT--------------提交 1、設置事務屬性 設置事務屬性主要能夠用來完成如下工做: * 指定事務的隔離層 * 規定回滾事務時所使用的存儲空間 * 命名事務 注:SET TRANSACTION必須是事務的第一個語句。並在事務終止後自動失效。 SET TRANSACTION ISOLATION LEVEL READ COMMITED A事務設置爲READ COMMITED,該開始後B事務修改了數據,此時A沒法獲得新數據,B提交以後,A能夠查詢到更新數據。 A不可能錯讀,但可能發生假讀和非重複讀。 在須要併發數很大時應該使用READ COMMITED,對於多用戶併發的性能和響應速度都比較好。 SET TRANSACTION ISOLATION LEVEL SERIALIZABLE 事務和事務之間徹底隔離開,事務以串行的方式執行。不是說必須等一個結束,而是事務一旦開始,在結束以前查詢到的數據永遠是開始時刻的數據。因爲留存的模式會比較多,因此會消耗必定的系統資源。 SET TRANSACTION READ ONLY 當前事務不能有任何修改數據的操做,READ ONLY是SERIALIZABLE的一個子集,基本上屬於最高的安全級。 SET TRANSACTION READ WRITE 在READ的基礎上增長WRITE權限,不經常使用 2、設置約束延期性 在操做過程當中可能須要違反約束向表中插入重複的數據,其實須要設置約束延期性。 設置格式以下: SET CONSTRAINT ALL | <constraint_name> DEFERRED | IMMEDIATE 能夠選擇要延期的約束名,也可使用ALL關鍵字延期全部的約束 DEFERRED表示延期,IMMEDIATE表示應用 注:理論上在COMMIT前須要設置回IMMEDIATE,可是系統能夠隱式自動完成這一操做。 注意:要使用延遲的約束,必須在建立時就進行說明: ALTER TABLE T1 ADD CONSTRAINT <constraint_name> DEFERRABLE INITIALLY IMMEDIATE 後面的DEFERRABLE 指名可使用延遲,INITIALLY 設定了初始值 3、存儲點 因爲事務太大,一次回滾會對系統形成很大的壓力。並且有時候在某一段特定的代碼附近會特別發生錯誤而回滾。這時就須要在但願的地方設置一個存儲點,能夠顯示得操做數據在發生錯誤時回滾到指定的存儲點,而節省沒必要要的開銷。 建立格式以下: SAVEPOINT <savepoint_name> 使用格式以下: ROLLBACK TO [SAVEPOINT] <savepoint_name> 4、結束事務 如下操做爲將事務結束: * 使用COMMIT提交事務,數據被永久保存 * 使用ROLLBACK回滾事務(不包括回滾到存儲點) * 執行DDL時,結束默認COMMIT * 用戶斷開鏈接,此時事務自動COMMIT * 進程意外停止,此時事務自動ROLLBACK 注:事務COMMIT時會生成一個惟一的系統變化號(SCN)保存到事務表
CAP理論 1. 一致性(Consistency):任何一個讀操做老是能讀取到以前完成的寫操做結果,也就是在分佈式環境中,多點的數據是一致的; 2. 可用性(Availability):每個操做老是可以在肯定的時間內返回,也就是系統隨時都是可用的。 3. 分區容忍性(Partition Tolerance): 在出現網絡分區(好比斷網)的狀況下,分離的系統也能正常運行。 因爲一致性、可用性和分區容忍性這三方面只能選擇兩個,因此大多數NoSQL系統都會根據本身的設計理念來進行相應的選擇,但因爲許多NoSQL數據庫都以水平擴展著稱, 因此在CAP的選擇上面,都傾向於堅持分區容忍性,而放棄一致性或者可用性,它們的作法主要是經過消減關係型和事務相關的功能。 redis是一個key-value存儲系統。和Memcached相似,它支持存儲的value類型相對更多,包括string(字符串)、list(鏈表)、set(集合)、zset(sorted set --有序集合)和hash(哈希類型)。 這些數據類型都支持push/pop、add/remove及取交集並集和差集及更豐富的操做,並且這些操做都是原子性的。在此基礎上,redis支持各類不一樣方式的排序。與memcached同樣,爲了保證效率,數據都是緩存在內存中。 區別的是redis會週期性的把更新的數據寫入磁盤或者把修改操做寫入追加的記錄文件,而且在此基礎上實現了master-slave(主從)同步。 Redis 是一個高性能的key-value數據庫。 redis的出現,很大程度補償了memcached這類key/value存儲的不足,在部 分場合能夠對關係數據庫起到很好的補充做用。 它提供了Java,C/C++,C#,PHP,JavaScript,Perl,Object-C,Python,Ruby,Erlang等客戶端,使用很方便。 [1] Redis支持主從同步。數據能夠從主服務器向任意數量的從服務器上同步,從服務器能夠是關聯其餘從服務器的主服務器。 這使得Redis可執行單層樹複製。存盤能夠有意無心的對數據進行寫操做。因爲徹底實現了發佈/訂閱機制,使得從數據庫在任何地方同步樹時,可訂閱一個頻道並接收主服務器完整的消息發佈記錄。同步對讀取操做的可擴展性和數據冗餘頗有幫助。