過去的兩週,小松陸陸續續看完了一門長達十幾個小時的課程 redis入門與精通。java
固然,僅僅課程是不足以精通redis的,不過用來入門和窺見redis的全貌大有幫助,今天,小松就記錄一下過去兩週在redis上的學習心得。python
key 這是最基礎的,Redis是典型的鍵值對數據庫,key能夠經過runoobkey設置,若是設置成功就會返回OK,刪除返回1。mysql
redis 127.0.0.1:6379> SET runoobkey redis
OK
redis 127.0.0.1:6379> DEL runoobkey
(integer) 1
複製代碼
String 這是最基礎的類型,相比起來,mysql的類型是真的多,光一個int都要好幾種。 而redis因爲是key-value結構,他的key基本都是使用的String,而value也大量使用,因此String使用很是頻繁。 最簡單的時候方式是set,get,固然,也支持各類對string的操做。redis
redis 127.0.0.1:6379> SET runoobkey redis
OK
redis 127.0.0.1:6379> GET runoobkey
"redis"
複製代碼
list list你們都不陌生,和數據結構同樣,使用LPush命令在左邊插入數據,RPush在右邊插入數據。 相似的,有LPop,LTrim(截取),LRem(刪除),LRANGE(查看)等操做,redis中字母不區分大小寫。 這是在菜鳥教程中截取的例子。算法
127.0.0.1:6379>LPUSH list1 "foo"
(integer) 1
127.0.0.1:6379> LPUSH list1 "bar"
(integer) 2
127.0.0.1:6379> LRANGE list1 0 -1
1) "bar"
2) "foo"
複製代碼
set set也很簡單,命令包括SAdd,SCard(查看元素個數),SRem,SUion(取並集),SInter(取交集)等。 好比b站裏面的共同關注就是經過SInter獲取。 一個帳號的粉絲存儲在一個Set中,兩個帳號就有兩個Set,只要將兩個Set進行SInter,就能夠知道同時關注這兩個帳號的人了。sql
redis 127.0.0.1:6379> SADD runoobkey redis
(integer) 1
redis 127.0.0.1:6379> SADD runoobkey mongodb
(integer) 1
redis 127.0.0.1:6379> SADD runoobkey mysql
(integer) 1
redis 127.0.0.1:6379> SADD runoobkey mysql
(integer) 0
redis 127.0.0.1:6379> SMEMBERS runoobkey
1) "mysql"
2) "mongodb"
3) "redis"
複製代碼
hash 這就是java中的map或者python中的dict,在redis中,叫作hash,案例和上面相似,就不貼了,無外乎hset,hget,hmset(批量設置),hlen等。mongodb
持久化分爲兩種,持久化簡單說就是要長期保存數據庫,對於長期保存同樣東西,思路就是要麼保存過程,繼而推導出結果,要麼直接保存結果,因此這就是RDB和AOF。數據庫
RDB RDB的原理是,從父進程fork一個子進程,寫入臨時RDB,而後替換原來的快照,成爲正式的RDB,在此期間,父進程,也就是原有的運行進程,正常運行 編程
因此他就是作了一個對結果的備份,放在一個後綴爲rdb格式的文件中而已緩存
當須要恢復的時候,將rdb放在redis的啓動目錄,這樣,啓動redis時,rdb同步寫入redis,就完成了恢復,他有如下特色
優勢: 1. 適合大規模數據恢復。 2. 適合備份數據庫,做爲後備兜底用途。 缺點: 1. 須要必定時間間隔進行操做,由於不能每時每刻都備份,好比每隔1小時備份,那麼一旦宕機,就會損失一小時的數據。 2. fork進程消耗資源。
AOF AOF相比起RDB,是更加經常使用的方式。
原理是將全部的命令記錄下來,寫入一個叫作appendonly.aof的文件中,當手動開啓後,重啓redis就會出現,很簡單,並且因爲保存的是步驟,而不是數據庫自己,因此安全性高,他有三種同步方式,每一次修改都同步,每秒同步,從不一樣步,有如下特色:
優勢: 1. 若是設置每一次修改都同步,很方便,不會有損失。 2. 若是設置每秒同步,最多丟失一秒數據。 3. 每次重啓redis,優先載入aof恢復數據。
缺點: aof的體積大於Rdb文件,並且恢復也比較慢,這個好理解,記錄了那些步驟都要從新執行一遍,天然比rdb直接備份的要慢一些。
因此,根據他們的原理和優缺點,咱們很容易判斷他們的使用範圍。 若是是數據比較重要,可是能夠承受損失,好比微博評論啥的,就用rdb吧。 若是須要更加安全,不能有損失,就用aof。 固然,兩個都用也ok,aof用做平時的恢復,rdb用於緊急的兜底備份。
相似於微信公衆號,信息消費者(subscriber)和信息生產者(Publisher )經過中間的channel進行鏈接,須要subscriber先訂閱,而後Publisher 將信息推入到channel中,這裏的channel本質上是一個鍵。 redis會維護一個字典,每一個channel都是鍵,對應的值是一個鏈表,包含了全部的subscriber,因此當信息被推入channel中,信息就知道了他要去的地方,是那個鏈表,而後逐一分發下去。
雞蛋不能放在一個籃子裏面,凡是涉及到數據庫的,都須要進行備份,只不過各家的方式不同。 redis使用主從複製,一個最簡單的模型是一主二從,使用三臺電腦。
先思考一下,咱們須要解決哪些問題? 基礎功能:
方案:主機纔有權力寫,而從機只能從主機複製內容。
方案:哨兵模式。
我第一次接觸哨兵模式,是在學習計算機系統的時候,所謂哨兵,至關於中世紀的教皇,而主機,是國王。 國王須要接受教皇的冊封,才能成爲真正的國王。
當主機掛掉的時候,哨兵將選擇一個從機,讓他成爲主機,並且,即便原來的主機回來了,他也只能變成從機。 選擇的方式,是投票。 哨兵不僅一個,是奇數個,對於三個服務器,一主二從,這裏三個哨兵比較合適,定時向主機發送消息監控,若是三個哨兵都沒法收到主機的回包,大機率主機就掛掉了,此時哨兵進行投票,得票多的從機成爲主機,以下圖 sentinel爲哨兵,slave爲從機。
投票是一種算法,這裏再也不深刻。 而如何防止哨兵掛掉呢?這就是爲何哨兵不僅一個的緣由,多個哨兵也相互監督。
這樣,這個模型若是不斷擴大,除非大面積斷電,否則即便有一些哨兵或者服務器掛掉了,也能夠正常運行。
黑天鵝仍是來了,大面積斷電了! 此時,就是緩存雪崩,由於斷電,Redis做爲內存數據庫,做爲訪問與數據庫之間的中間緩存,將會完全失效,此時 緩存稱爲雪崩。 方案在思路上沒啥神奇的辦法,只能異地容災,或者提早預熱,好比在11月10號模擬幾億訂單量衝擊淘寶系統,看看能不能抗住。
雪崩畢竟是天災,咱們沒法改變,可是緩存穿透咱們能夠有所做爲 穿透,就是緩存沒起到做用,爲何沒起到做用? 由於在緩存中沒找到數據,好比說,用戶找一個商品信息,可是緩存中找不到,因此會跳轉到數據庫中去找,而若是大量用戶都來發起訪問沒找到的數據,數據庫將會直接暴露,容易受到攻擊,好比下圖,若是一直是否,就會一直查詢DB
主流解決方法是使用過濾器,好比著名的布隆過濾器,篩選出容易形成穿透的訪問信息,剔除掉便可,至關於給緩存打了一個補丁,除了過濾,還能夠分流,降級等等,這些東西,和幾千年前的大禹治水的思路同樣,只是搬到了計算機上,畢竟,智慧,古往今來,都不會變,變的是使用場景。
穿透是找不到,擊穿是受不了,假設緩存中有這個商品信息,可是因爲訪問過於頻繁,使得緩存也受不了,就會崩掉,好比微博某明星談戀愛就崩了,這應該是屬於緩存擊穿案例。 方案也不難,可使用臨界區,只要一部分在在訪問,其餘的就沒法訪問,這是一種互斥鎖的方案,雖然併發少了,可是至少不會崩。
總結:以上就是小松兩週來的一些收穫,天天接近11點下班,也不能懈怠鴨,小松本身也運營一個公衆號,【小松漫步】,專門記錄小松的編程成長,還有大量電子書資源,有興趣能夠去逛逛哦