日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

狂神 redis笔记 docker

發布時間:2023/12/20 编程问答 53 豆豆
生活随笔 收集整理的這篇文章主要介紹了 狂神 redis笔记 docker 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
6379

首先介紹redis默認端口號為6379,為什么嘞,主要粉絲效應!

#redis中文命令手冊
https://www.redis.com.cn/commands.html


docker pull redis
下載redis

如使用非root用戶,則需要在命令前加上sudo命令,否則會報錯

sudo mkdir -p /mydata/redis/conf
sudo touch /mydata/redis/conf/redis.conf
創建redis.conf 配置文件

[root@localhost ~]# docker run -p 6379:6379 --name redis -v /mydata/redis/data:/data -v /mydata/redis/conf/redis.conf:/etc/redis/redis.conf -d redis redis-server /etc/redis/redisnbZX.conf
啟動redis

[root@localhost ~]# docker exec -it redis redis-server -v
Redis server v=6.0.10 sha=00000000:0 malloc=jemalloc-5.1.0 bits=64 build=66898bb7acd47e81
此上代碼為查看redis版本,可以看出我的版本下載的位6.0.10

[root@localhost ~]# docker exec -it redis redis-cli
docker連接redis容器命令↑

127.0.0.1:6379> ping
PONG
輸入ping如顯示pong則啟動測試成功

127.0.0.1:6379> set name xiaoxue
OK
127.0.0.1:6379> get name
“xiaoxue”
127.0.0.1:6379> keys *

  • “name”
  • “a”
    此上為測試redis功能
  • 127.0.0.1:6379> shutdown
    關閉redis

    **

    性能測試

    **
    redis-benchmark是一個壓力測試工具 !
    官方自帶的性能測試工具 !
    redis-benchmark命令參數 !

    上圖參數來自菜鳥教程

    [root@192 bin]# redis-benchmark -h localhost -p 6379 -c 100 -n 100000
    linux下測試性能

    [root@192 bin]# docker exec -it 705c1a53a8bf redis-benchmark -h 127.0.0.1 -p 6379 -c 100 -n 100000
    以上為docker鏡像下調用壓測命令
    上圖為測試過程

    基礎知識

    redis默認有16個數據庫
    默認是第0個

    127.0.0.1:6379> select 3 #切換數據庫
    OK
    127.0.0.1:6379[3]> DBSIZE # 查看DB大小!
    (integer) 0

    127.0.0.1:6379[1]> keys *

  • “name”
    keys * 查看數據庫所以的key
  • 127.0.0.1:6379[1]> flushdb
    OK
    127.0.0.1:6379[1]> keys *
    (empty array)
    flushdb 清除當前數據庫

    127.0.0.1:6379[3]> flushall
    OK
    127.0.0.1:6379[3]> keys *
    (empty array)
    127.0.0.1:6379[3]> select 0
    OK
    127.0.0.1:6379> keys *
    (empty array)
    flushall 清空所有數據庫內容

    Redis是單線程的!
    Redis是很快的,官方表示,Redis是基于內存操作,CPU不是Redis性能瓶頸,Redis的瓶頸是根據機器的內存和網絡帶寬,既然可以使用單線程實現,就使用單線程了!

    Redis 是C語言寫的,官方提供的數據為 100000+ 的QPS ,這個完全不比同樣使用key-value的Memecache差!
    Redis為什么單線程還這么快?
    1、誤區1:高性能的服務器一定是多線程的?
    2、誤區2:多線程(CPU上下文會切換! )一定比單線程效率高!
    CPU>內存>硬盤的速度要有所了解 !
    核心: redis是將所有的數據全部放在內存中的,所以說使用單線程去操作效率就是最高的,多線程(CPU上下文會切換:耗時的操作! ! !),對于內存系統來說,如果沒有上下文切換效率就是最高的!多次讀寫都是在一個CPU上的,在內存情況下,這個就是最佳的方案 !

    五大數據類型
    Redis-Key
    String
    List
    Set
    Hash
    Zset
    三種特殊數據類型
    geospatial
    hyperloglog
    bitmaps

    127.0.0.1:6379> EXISTS name # 判斷當前key是否存在,存在返回1,不存在返回0
    (integer) 1
    127.0.0.1:6379> EXISTS number
    (integer) 0
    127.0.0.1:6379> move name 1 # 移除當前key
    (integer) 1
    EXPIRE name 5 #設置key過期時間,單位是秒,過期后會自動刪除
    (integer) 0
    127.0.0.1:6379> ttl name #查看當前key剩余時間
    (integer) 2
    127.0.0.1:6379> ttl name
    (integer) -2
    127.0.0.1:6379> get name
    “shsha”
    127.0.0.1:6379> type name #查看當前key的類型
    string

    String(字符串)

    127.0.0.1:6379> set xue c
    OK
    127.0.0.1:6379> get xue
    “c”
    127.0.0.1:6379> APPEND xue " big" #追加字符串,如果當前key不存在,該命令相當于set key
    (integer) 5
    127.0.0.1:6379> get xue
    “c big”
    127.0.0.1:6379> STRLEN xue # 獲取字符串長度
    (integer) 5

    127.0.0.1:6379> set mones 0 #初始瀏覽量為0
    OK
    127.0.0.1:6379> get mones
    “0”
    127.0.0.1:6379> incr views #自增1 瀏覽量+1
    (integer) 1
    127.0.0.1:6379> get mones
    “0”
    127.0.0.1:6379> incr views
    (integer) 2
    127.0.0.1:6379> decr views #自減1瀏覽量-1
    (integer) 1
    127.0.0.1:6379> decr views
    (integer) 0
    127.0.0.1:6379> decr views
    (integer) -1
    127.0.0.1:6379> get mones
    “0”
    127.0.0.1:6379> INCRBY mones 10 #可以設置指定增量
    (integer) 10
    127.0.0.1:6379> DECRBY mones 8 #可以設置指定減量
    (integer) 2
    127.0.0.1:6379> get mones
    “hello mones”
    127.0.0.1:6379> GETRANGE mones 0 3 #截取指定字符串[0,3]
    “hell”
    127.0.0.1:6379> GETRANGE mones 0 -1 #獲取全部的字符串,和get key一樣
    “hello mones”
    127.0.0.1:6379> get mones2
    “asdfgh”
    127.0.0.1:6379> SETRANGE mones2 1 nn #替換指定位置開始的字符串
    (integer) 6
    127.0.0.1:6379> get mones2
    “annfgh”

    setex #設置過期時間
    setnx #不存在在設置(分布式鎖中常用)

    127.0.0.1:6379> setex mones3 10 “hi baby” #設置mones3 的值為 hi baby,10秒后過期
    OK
    127.0.0.1:6379> setnx monesluna “redis” #如果monesluna存在,創建失敗
    (integer) 1

    127.0.0.1:6379> mset k1 v1 k2 v2 k3 v3 #批量設置,同時設置多個值
    OK
    127.0.0.1:6379> keys *

  • “k3”
  • “k2”
  • “k1”
    127.0.0.1:6379> mget k1 k2 k3 #批量獲取key值,同時獲取多個值
  • “v1”
  • “v2”
  • “v3”
    127.0.0.1:6379> msetnx k1 v1 k4 v4 #msetnx是一個原子性操作,要么一起成功,要么一起失敗
    (integer) 0
    127.0.0.1:6379> set user:1 {name:zhangsan,age:3}#設置一個user:1對象 值為json字符來保存一個對象!
    OK
    127.0.0.1:6379> get user:1
    “{name:zhangsan,age:3}”
  • #以下為key的巧妙設計: user:{id}:{filed} ,如此設計在Redis中完全ok!
    127.0.0.1:6379> mset user:1:name lisi user:1:age 10
    OK
    127.0.0.1:6379> mget user:1:name user:1:age

  • “lisi”
  • “10”
  • ##getset #先get然后set
    127.0.0.1:6379> getset db redis #如果不存在值,則返回nil
    (nil)
    127.0.0.1:6379> get db
    “redis”
    127.0.0.1:6379> getset db mongodb #如果存在值,則返回原來的值,并設置成新值
    “redis”
    127.0.0.1:6379> get db
    “mongodb”

    小總結:String類似的使用常見:value除了是我們的字符串還可以是我們的數字!
    ●計數器
    ●統計多單位的數量
    ●粉絲數
    ●對象緩存存儲!

    List(列表)

    在redis里,可以把list玩成,棧,隊列,阻塞隊列!
    所以list命令 以l開頭,redis不區分大小寫命令

    127.0.0.1:6379> LPUSH list one #將一個值或多個值,插入到列表頭部(左)
    (integer) 1
    127.0.0.1:6379> LPUSH list two
    (integer) 2
    127.0.0.1:6379> LPUSH list three
    (integer) 3
    127.0.0.1:6379> LRANGE list 0 -1

  • “three”
  • “two”
  • “one”
    127.0.0.1:6379> LRANGE list 0 1
  • “three”
  • “two”
    127.0.0.1:6379> RPUSH list four #將一個或多個值,插入到列表尾部(右)
    (integer) 4
    127.0.0.1:6379> LRANGE list 0 -1
  • “three”
  • “two”
  • “one”
  • “four”
  • 127.0.0.1:6379> Lpop list #移除list第一個元素
    “three”
    127.0.0.1:6379> LRANGE list 0 -1

  • “two”
  • “one”
  • “four”
    127.0.0.1:6379> Rpop list #移除list最后一個元素
    “four”
    127.0.0.1:6379> LRANGE list 0 -1
  • “two”
  • “one”
  • 127.0.0.1:6379> Lindex list 1 #通過下標獲得list中的某一個值
    “one”
    127.0.0.1:6379> Lindex list 0
    “two”
    127.0.0.1:6379> llen list #返回列表的長度
    (integer) 2
    127.0.0.1:6379> lrem list 1 one #移除list集合中指定個數的value,精確匹配
    (integer) 1

    127.0.0.1:6379> Rpush mylist “mones1”
    (integer) 1
    127.0.0.1:6379> Rpush mylist “mones2”
    (integer) 2
    127.0.0.1:6379> Rpush mylist “mones3”
    (integer) 3
    127.0.0.1:6379> Rpush mylist “mones4”
    (integer) 4
    127.0.0.1:6379> Ltrim mylist 1 2 #通過下標截取指定位置的長度,這個list已經被改變,只剩下截取的元素
    OK
    127.0.0.1:6379> LRANGE mylist 0 -1

  • “mones2”
  • “mones3”
  • 127.0.0.1:6379> Rpush mylist “ss”
    (integer) 1
    127.0.0.1:6379> Rpush mylist “dd”
    (integer) 2
    127.0.0.1:6379> Rpush mylist “cc”
    (integer) 3
    127.0.0.1:6379> Rpush mylist “ff”
    (integer) 4
    127.0.0.1:6379> RpopLpush mylist myotherlist #移除列表中的最后一個元素,將他移動到新的列表中
    “ff”
    127.0.0.1:6379> LRANGE mylist 0 -1 #查看原來的列表

  • “ss”
  • “dd”
  • “cc”
    127.0.0.1:6379> LRANGE myotherlist 0 -1 #查看目標列表中,確實存在該值
  • “ff”
  • 127.0.0.1:6379> lRANGE mylist 0 -1

  • “ss”
  • “dd”
  • “cc”
    127.0.0.1:6379> lset mylist 0 haha #將列表中指定下標的值,替換為另外一個值,更新操作,如果列表不存在或沒有該索引,則會報錯(error)
    OK
    127.0.0.1:6379> lRANGE mylist 0 -1
  • “haha”
  • “dd”
  • “cc”
  • Linsert #將某個具體的value插入到列表中某個元素的前面或后面
    127.0.0.1:6379> LRANGE list 0 -1

  • “aa”
  • “bb”
  • “cc”
  • “dd”
    127.0.0.1:6379> LINSERT list before bb hello #linsert before 插入到某元素前面
    (integer) 5
    127.0.0.1:6379> LRANGE list 0 -1
  • “aa”
  • “hello”
  • “bb”
  • “cc”
  • “dd”
    127.0.0.1:6379> LINSERT list after cc mones #linsert before 插入到某元素后面
    (integer) 6
    127.0.0.1:6379> LRANGE list 0 -1
  • “aa”
  • “hello”
  • “bb”
  • “cc”
  • “mones”
  • “dd”
  • list小結
    ●他實際上是一個鏈表,before Node after ,left,right都可以插入值
    ●如果key不存在,創建新的鏈表
    ●如果key存在,新增內容
    ●如果移除了所以值,空鏈表,也代表不存在!
    ●在兩邊插入或者改動值,效率最高!中間元素,相對啦愛說效率會低一些

    消息排隊 !消息隊列 (Lpush Rpop),棧(Lpush Lpop)

    Set(集合)

    set無序不重復 set中的值是不能重復的
    127.0.0.1:6379> sadd myset “hello” #set集合中添加元素
    (integer) 1
    127.0.0.1:6379> sadd myset “mones”
    (integer) 1
    127.0.0.1:6379> sadd myset “luna”
    (integer) 1
    127.0.0.1:6379> Smembers myset #查看指定set的所有值

  • “hello”
  • “luna”
  • “mones”
    127.0.0.1:6379> Sismember myset “hello” #判斷某一個值是不是在set集合中存在返回1
    (integer) 1
    127.0.0.1:6379> Sismember myset sss##判斷某一個值是不是在set集合中存在返回1,不存在返回0
    (integer) 0
    127.0.0.1:6379> scard myset #獲取set集合中的元素個數!
    (integer) 3
    127.0.0.1:6379> srem myset hello #移除set集合中指定元素
    (integer) 1
    127.0.0.1:6379> scard myset
    (integer) 2
    127.0.0.1:6379> smembers myset
  • “luna”
  • 127.0.0.1:6379> SRANDMEMBER myset #隨機抽選出一個元素
    “hahah”
    127.0.0.1:6379> SRANDMEMBER myset
    “mones”
    127.0.0.1:6379> SRANDMEMBER myset 2 #隨機抽選出指定個數的元素

  • “nanan”
  • “mones”
  • 127.0.0.1:6379> smembers myset

  • “nanan”
  • “luna”
  • “hahah”
  • “mones”
    127.0.0.1:6379> spop myset #隨機刪除某一個set集合中的元素
    “hahah”
    127.0.0.1:6379> smembers myset
  • “nanan”
  • “luna”
  • “mones”
  • 127.0.0.1:6379> sadd myset hello
    (integer) 1
    127.0.0.1:6379> sadd myset world
    (integer) 1
    127.0.0.1:6379> sadd myset mones
    (integer) 1
    127.0.0.1:6379> sadd myset luna
    (integer) 1
    127.0.0.1:6379> smove myset myset2 “mones” #將一個指定的值,移動到另外一個set集合
    (integer) 1
    127.0.0.1:6379> smembers myset

  • “hello”
  • “world”
  • “luna”
    127.0.0.1:6379> smembers myset2
  • “mones”
    sdiff 差集 sinter交集 sunion并集
  • Hash(哈希)

    Map集合,key-map 這個值是一個map集合 !

    127.0.0.1:6379> hset maphash key1 mones #set一個具體的key -value
    (integer) 1
    127.0.0.1:6379> hset maphash key2 luna
    (integer) 1
    127.0.0.1:6379> hget maphash key1 #get一個具體的key
    “mones”
    127.0.0.1:6379> hget maphash key2
    “luna”
    127.0.0.1:6379> hmset maphash key1 thanks key2 thanks2 #設置多個key-value
    OK
    127.0.0.1:6379> hmget maphash key1 key2 #獲取多個key-value

  • “thanks”
  • “thanks2”
    127.0.0.1:6379> hdel maphash key1 #刪除hash指定key字段!對應的value值也就消失了
    (integer) 1
    127.0.0.1:6379> hgetall maphash #獲取全部數據
  • “key2”
  • “thanks2”
    127.0.0.1:6379> hlen maphash #獲取hash表的字段數量
    (integer) 1
  • 127.0.0.1:6379> HEXISTS maphash key2 #判斷hash中指定字段是否存在,存在返回1,否則返回0
    (integer) 1
    127.0.0.1:6379> HEXISTS maphash key1
    (integer) 0

    127.0.0.1:6379> hkeys maphash #獲得所有key

  • “key2”
    127.0.0.1:6379> hvals maphash #獲取所有value
  • “thanks2”
  • Zset(有序集合)

    在set的基礎上,增加了一個值,set k1 v1 zset k1 score1 v1
    127.0.0.1:6379> zadd score 500 xiaoxue #zset集合中添加元素
    (integer) 1
    127.0.0.1:6379> zadd score 300 dige
    (integer) 1
    127.0.0.1:6379> zadd score 600 pipi
    (integer) 1
    #ZRANGEBYSCORE key min max
    127.0.0.1:6379> ZRANGEBYSCORE score -inf +inf #顯示全部的用戶 從小到大

  • “dige”
  • “xiaoxue”
  • “pipi”
    127.0.0.1:6379> zrevrange score 0 -1 #顯示全部用戶 從大到小
  • “xiaoxue”
  • “dige”
  • 127.0.0.1:6379> ZRANGEBYSCORE score -inf +inf withscores #顯示全部的用戶并且附帶成績

  • “dige”
  • “300”
  • “xiaoxue”
  • “500”
  • “pipi”
  • “600”
    127.0.0.1:6379> ZRANGEBYSCORE score -inf 550 withscores #顯示score小于550的員工的升序排列
  • “dige”
  • “300”
  • “xiaoxue”
  • “500”
    ##############
    127.0.0.1:6379> zrange score 0 -1 #遍歷有序集合
  • “dige”
  • “xiaoxue”
  • “pipi”
    127.0.0.1:6379> zrem score pipi #移除有序集合中的指定元素
    (integer) 1
    127.0.0.1:6379> zrange score 0 -1
  • “dige”
  • “xiaoxue”
    127.0.0.1:6379> zcard score #獲取有序集合中的個數
    (integer) 2
    127.0.0.1:6379> zadd myset 1 hello 2 world 3 xiaoxue #批量插入
    (integer) 3
    127.0.0.1:6379> zcount myset 1 3 #獲取指定區間的成員數量!
    (integer) 3
    127.0.0.1:6379> zcount myset 1 2
    (integer) 2
  • 其余的一些API,通過我們的學習,剩下的,如果工作中有需要,可以去查看官方文檔!官方文檔是最正確的!
    案例思路:zset 排序 存儲班級成績表,工資表排序
    普通消息 1,重要消息 2,帶權重進行判斷 !
    排行榜應用實現,取Top N測試 !

    三種特殊數據類型

    geospatial 地理位置

    朋友的定位,附近的人,打車距離計算?
    Redis的Geo 在Redis3.2版本就推出了!這個功能可以推算地理位置的信息,兩地之間的舉例,方圓幾里的人!

    可以查詢一些測試數據:http://www.jsons.cn/xiehouyu/
    只有六個命令

    官方文檔:https://www.redis.net.cn/order

    geoadd:添加地理位置的坐標。
    規則:兩級無法直接添加,我們一般會下載城市數據,直接通過java程序一次性導入!
    有效的經度從-180度到180度。
    有效的緯度從-85.05112878度到85.05112878度。
    當坐標位置超出上述指定范圍時,該命令將會返回一個錯誤。

    127.0.0.1:6379> geoadd china:city 22.547 114.08 shenzhen
    (integer) 1
    127.0.0.1:6379> geoadd china:city 31.242 121.18 shanghai
    (integer) 1
    127.0.0.1:6379> geoadd china:city 118.80 32.06 nanjing
    (integer) 1
    127.0.0.1:6379> geoadd china:city 106.55 29.56 chongqing
    (integer) 1
    127.0.0.1:6379> geoadd china:city 125.15 42.93 xian
    (integer) 1
    127.0.0.1:6379> geoadd china:city 114.65 33.60 zhoukou
    (integer) 1

    geopos:獲取地理位置的坐標。
    127.0.0.1:6379> GEOPOS china:city xian chongqing zhoukou

  • “125.1499977707862854”
  • “42.93000069610238256”
  • “106.5499994158744812”
  • “29.56000053864853072”
  • “114.65000241994857788”
  • “33.59999880983598786”
    127.0.0.1:6379> GEOPOS china:city nanjing
  • “118.80000203847885132”
  • “32.06000108754685129”
  • geodist:計算兩個位置之間的距離。
    單位:
    ● m 表示單位為米
    ● km 表示單位為千米
    ● mi 表示單位為英里
    ● ft 表示單位為英尺

    127.0.0.1:6379> GEODIST china:city chongqing zhoukou
    “888935.4795”
    127.0.0.1:6379> GEODIST china:city nanjing xian
    “1331555.6271”
    127.0.0.1:6379> GEODIST china:city nanjing xian km
    “1331.5556”

    georadius:根據用戶給定的經緯度坐標來獲取指定范圍內的地理位置集合。附近的人
    所有數據都應該錄入:china:city,才會讓結果更加清晰!
    127.0.0.1:6379> GEORADIUS china:city 110 30 1000 km #以110 30 這個經緯度為中心方圓1000km內的城市

  • “chongqing”
  • “shenzhen”
  • “zhoukou”
  • “nanjing”
    127.0.0.1:6379> GEORADIUS china:city 110 30 500 km #以110 30 這個經緯度為中心方圓500km內的城市
  • “chongqing”
    127.0.0.1:6379> GEORADIUS china:city 110 30 500 km withdist #以110 30 為中心方圓500km的城市及其相距的距離
  • “chongqing”
  • “336.6174”
    127.0.0.1:6379> GEORADIUS china:city 110 30 500 km withcoord #以110 30 為中心方圓500km的城市及其坐標
  • “chongqing”
  • “106.5499994158744812”
  • “29.56000053864853072”
    127.0.0.1:6379> GEORADIUS china:city 110 30 1000 km withdist withcoord count 1 #以110 30 為中心方圓1000km的城市及其相距距離和坐標,只能顯示一條
  • “chongqing”
  • “336.6174”
  • “106.5499994158744812”
  • “29.56000053864853072”
    127.0.0.1:6379> GEORADIUS china:city 110 30 1000 km withdist withcoord count 2
    #以110 30 為中心方圓1000km的城市及其相距距離和坐標,只能顯示兩條
  • “chongqing”
  • “336.6174”
  • “106.5499994158744812”
  • “29.56000053864853072”
  • “zhoukou”
  • “594.4614”
  • “114.65000241994857788”
  • “33.59999880983598786”
    127.0.0.1:6379> GEORADIUS china:city 110 30 1000 km withdist withcoord count 3
  • “chongqing”
  • “336.6174”
  • “106.5499994158744812”
  • “29.56000053864853072”
  • “zhoukou”
  • “594.4614”
  • “114.65000241994857788”
  • “33.59999880983598786”
  • “nanjing”
  • “869.1553”
  • “118.80000203847885132”
  • “32.06000108754685129”
  • georadiusbymember:根據儲存在位置集合里面的某個地點獲取指定范圍內的地理位置集合。
    #找出位于指定元素范圍內的其它元素
    127.0.0.1:6379> GEORADIUSBYMEMBER china:city nanjing 1000 km #找出位于nanjing 1000km的其它城市

  • “zhoukou”
  • “nanjing”
  • “shanghai”
    127.0.0.1:6379> GEORADIUSBYMEMBER china:city zhoukou 500 km
  • “zhoukou”
  • “nanjing”
  • geohash:返回一個或多個位置對象的 geohash 值。
    將二維的經緯度轉換為一維的字符串,如果兩個字符串越接近,那么距離越近
    127.0.0.1:6379> geohash china:city chongqing zhoukou

  • “wm7b0t5r6z0”
  • “wtcx0utw4t0”
  • GEO的底層實現原理其實就是Zset!我們可以使用Zset命令來操作geo !
    127.0.0.1:6379> zrange china:city 0 -1 #查看地圖中全部的元素

  • “chongqing”
  • “shenzhen”
  • “shanghai”
  • “zhoukou”
  • “nanjing”
  • “xian”
    127.0.0.1:6379> zrem china:city xian #刪除地圖中指定元素
    (integer) 1
    127.0.0.1:6379> zrange china:city 0 -1
  • “chongqing”
  • “shenzhen”
  • “shanghai”
  • “zhoukou”
  • “nanjing”
  • hyperloglog

    什么是基數?
    A{1,2,3,4,5,6,5,4}
    B{1,3,5,7}
    基數(不重復打的元素) = 3,可以接受誤差

    簡介
    Redis 2.8.9版本就更新了Hyperloglog數據結構!
    Redis Hyperloglog基數統計的算法
    優點:占用的內存是固定的,2^64不同的元素的技術,只需要12KB內存!如果從內存角度來比較的話Hyperloglog首選!

    網頁的UV(一個人訪問一個網站多次,但是還是算作一個人!)
    傳統的方式,set保存用戶的id,然后就可以統計set中的元素數量作為標準判斷!
    這個方式如果保存大量的用戶id,就會比較麻煩!我們的目的是為了計數,而不是為了保存用戶id;
    0.81%錯誤率!統計UV任務,可以忽略不計的!
    測試使用
    127.0.0.1:6379> PFadd mykey a b c d e f g h i j #創建第一組元素mykey
    (integer) 1
    127.0.0.1:6379> PFCOUNT mykey #統計mykey元素的基數數量
    (integer) 10
    127.0.0.1:6379> PFadd mykey2 a b c d e b c n f #創建第一組元素mykey
    (integer) 1
    127.0.0.1:6379> PFCOUNT mykey2
    (integer) 7
    127.0.0.1:6379> PFMERGE mykey3 mykey mykey2 #合并mykey mykey2 => mykey3 并集
    OK
    127.0.0.1:6379> PFCOUNT mykey3 #查看并集的數量
    (integer) 11

    如果允許容錯,那么一定可以使用Hyperloglog !
    如果不允許容錯,就使用set或者自己的數據類型即可 !

    bitmap

    位存儲
    統計用戶信息,活躍,不活躍 !登錄 未登錄 ! 打卡 365天打卡 ! 兩個狀態的, 都可以使用 Bitmaps !
    Bitmaps 位圖 數據結構 ! 都是操作二進制位來進行記錄,就只有0和1兩個狀態 !
    365天 = 365bit 1字節=8bit
    使用bitmaps來記錄 周一到周日的打卡 !
    周一:1 周二 : 0 周三: 0 …
    127.0.0.1:6379> setbit sign 0 1
    (integer) 0
    127.0.0.1:6379> setbit sign 1 0
    (integer) 0
    127.0.0.1:6379> setbit sign 2 0
    (integer) 0
    127.0.0.1:6379> setbit sign 3 1
    (integer) 0
    127.0.0.1:6379> setbit sign 4 1
    (integer) 0
    127.0.0.1:6379> setbit sign 5 0
    (integer) 0
    127.0.0.1:6379> setbit sign 6 0
    (integer) 0
    查看某一天是否打卡
    127.0.0.1:6379> getbit sign 4
    (integer) 1
    127.0.0.1:6379> getbit sign 5
    (integer) 0
    統計打卡的天數
    127.0.0.1:6379> bitcount sign #統計這周的打卡記錄,就可以看到是否全勤
    (integer) 3

    事務

    Redis 事務本質: 一組命令的集合! 一個事務中的所有命令都會被序列化,在事務執行過程中,會按照順序執行!
    一次性、順序性、排他性!執行一些列的命令

    Redis事務沒有隔離級別的概念!
    所有命令在事務中,并沒有直接執行!只有發起執行命令的時候才會執行 !Exec
    Redis單條命令是保證原子性的,但是事務不保證原子性!

    redis的事務:
    ●開啟事務(multi)
    ●命令入隊(…)
    ●執行事務(exec)

    正常執行事務
    127.0.0.1:6379> multi 開啟事務
    OK
    127.0.0.1:6379> set k1 v1
    QUEUED
    127.0.0.1:6379> set k2 v2
    QUEUED
    127.0.0.1:6379> get k2
    QUEUED
    127.0.0.1:6379> get k3
    QUEUED
    127.0.0.1:6379> exec 執行事務

  • OK
  • OK
  • “v2”
  • (nil)
  • 放棄事務
    127.0.0.1:6379> multi 開啟事務
    OK
    127.0.0.1:6379> set a1 b1
    QUEUED
    127.0.0.1:6379> set a2 b2
    QUEUED
    127.0.0.1:6379> set a3 b3
    QUEUED
    127.0.0.1:6379> DISCARD 取消事務
    OK
    127.0.0.1:6379> get a3 事務隊列中的命令都不會被執行!
    (nil)
    127.0.0.1:6379> get a1
    (nil)

    編譯型異常(代碼有問題! 命令有錯 !),事務中所有的命令都不會被執行!
    127.0.0.1:6379> multi
    OK
    127.0.0.1:6379> set k1 v1
    QUEUED
    127.0.0.1:6379> set k2 v2
    QUEUED
    127.0.0.1:6379> getset k3 v3
    QUEUED
    127.0.0.1:6379> getset k4 錯誤的命令
    (error) ERR wrong number of arguments for ‘getset’ command
    127.0.0.1:6379> getset k5 v5
    QUEUED
    127.0.0.1:6379> exec 執行事務報錯
    (error) EXECABORT Transaction discarded because of previous errors.
    127.0.0.1:6379> get k5 所以命令都不會執行
    (nil)

    運行時異常(1/0),如果事務隊列中存在與發行,那么執行命令的時候,其它命令是可以正常執行的,錯誤命令拋出異常
    127.0.0.1:6379> set k1 “v1”
    OK
    127.0.0.1:6379> multi
    OK
    127.0.0.1:6379> incr k1 會執行的時候失敗
    QUEUED
    127.0.0.1:6379> set k2 v2
    QUEUED
    127.0.0.1:6379> set k3 v3
    QUEUED
    127.0.0.1:6379> get k2
    QUEUED
    127.0.0.1:6379> exec 雖然第一條命令報錯了,但是依舊正常執行成功了!

  • (error) ERR value is not an integer or out of range
  • OK
  • OK
  • “v2”
    127.0.0.1:6379> get k3
    “v3”
    127.0.0.1:6379> get k1
    “v1”
  • 監控!Watch (面試場問)
    悲觀鎖:
    ●很悲觀,認為什么時候都會出問題,無論做什么都會加鎖!
    樂觀鎖:
    ●很樂觀,認為什么時候都不會出問題,所以不會上鎖!更新數據的時候去判斷一下,在此期間是否有人修改過這個數據
    ●獲取version
    ●更新的時候比較version

    Redis監視測試
    watch 監視對象當前值, 如果事務執行之間值被其它線程改變,則執行失敗,此時需要unwatch,然后重新watch
    正常執行成功
    127.0.0.1:6379> set money 100
    OK
    127.0.0.1:6379> set out 0
    OK
    127.0.0.1:6379> watch money 監視money對象
    OK
    127.0.0.1:6379> multi 事務正常結束,數據期間沒有發生變動,這個時候就正常執行成功
    OK
    127.0.0.1:6379> DECRBY money 20
    QUEUED
    127.0.0.1:6379> INCRBY out 20
    QUEUED
    127.0.0.1:6379> exec

  • (integer) 80
  • (integer) 20
  • 測試多線程修改值,使用watch可以當做redis的樂觀鎖操作
    127.0.0.1:6379> watch money 監視money對象
    OK
    127.0.0.1:6379> multi
    OK
    127.0.0.1:6379> DECRBY money 20
    QUEUED
    127.0.0.1:6379> INCRBY out 20
    QUEUED
    127.0.0.1:6379> exec 執行之前,另外一個線程修改了值,這個時候,會導致事務執行失敗!
    (nil)

    什么是Jedis 是Redis官方推薦的java連接開發工具!使用java操作Redis中間件!如果你要使用java操作redis,那么一定要對jedis十分的熟悉!

    慢慢來會很快!

    首先maven中導入地址

    <dependencies><!-- https://mvnrepository.com/artifact/redis.clients/jedis --><dependency><groupId>redis.clients</groupId><artifactId>jedis</artifactId><version>3.2.0</version></dependency><!-- https://mvnrepository.com/artifact/com.alibaba/fastjson --><dependency><groupId>com.alibaba</groupId><artifactId>fastjson</artifactId><version>1.2.75</version></dependency></dependencies>

    ●連接數據庫
    ●操作命令
    ●斷開連接!

    public static void main(String[] args) {
    //1. new Jedis 對象即可
    Jedis jedis = new Jedis(“127.0.0.1”,6379);
    //jedis所以的命令就是我們之前學習的所有命令!所以之前的指令學習很重要!
    System.out.println(jedis.ping());
    }

    輸出:

    常用API
    String get set
    List push rem
    Set add
    Hash hset
    Zset zadd

    SpringBoot操作數據: spring-data,jpa,jdbc mongodb redis !
    SpringData 也是和SpringBoot齊名的項目 !
    說明: 在SpringBoot2.0 以后,原來使用的jedis 被替換成了lettuce!
    jedis:采用的直連,多個線程操作的話,是不安全的,如果想要避免不安全的,使用jedis pool連接池 ! 更像BIO 模式
    lettuce:采用netty,實例可以在多個線程中進行共享,不存在線程不安全的情況!可以減少線程數據了,更像NIO 模式

    整合測試一下
    1.導入依賴

    org.springframework.boot
    spring-boot-starter-data-redis

    2.配置連接
    配置redis
    spring.redis.host=127.0.0.1
    spring.redis.port=6379
    3.測試!
    @Autowired
    private RedisTemplate redisTemplate;
    @Test
    void contextLoads() {

    //redisTemplate//opsForValue 操作字符串 類似String//opsForList 操作list 類似List//opsForSet//opsForHash//opsForZset//opsForGeo//opsForHyperLogLog//除了基本的操作,我們常用的方法都可以直接通過redisTemplate操作,比如事務,和基本的CRUD//獲取redis的連接對象

    // RedisConnection connection = redisTemplate.getConnectionFactory().getConnection();
    // connection.flushDb();;
    // connection.flushAll();

    redisTemplate.opsForValue().set("mykey","xiaoxue");System.out.println(redisTemplate.opsForValue().get("mykey")); }


    需要序列化pojo類中的對象,實現serializable接口,才能執行成功

    可以通過編寫RedisUtill類來簡化代碼書寫

    所以的redis操作,其實對于java開發人員來說,十分的簡單,更重要的是理解redis的思想和每一種數據結構的用處和作用場景!

    Redis.conf詳解

    啟動的時候,就通過配置文件來啟動!


    網絡
    bin 127.0.0.1 #綁定的ip
    protected-mode yes #保護模式
    port 6379 #端口設置

    通用GENERAL
    demonize yes # 以守護進程的方式運行,默認是no,我們需要自己開啟為yes
    pidfile /var/run/redis_6379.pid #如果以后臺的方式運行,我們就需要指定一個pid文件!

    快照
    持久化,在規定的時間內,執行了多少次操作,則會持久化到文件,rdb、aof

    redis是內存數據庫,如果沒有持久化,那么數據斷電即失 !

    #如果900秒內,如果至少有一個1個key進行了修改,我們即進行持久化操作
    save 900 1
    #如果300s內,如果至少10個key進行了修改,我們即進行持久化操作
    save 300 10
    #如果60s內, 如果至少10000個key進行了操作,我們即進行持久化操作
    save 60 10000
    #我們之后學習持久化,會自己定義這個測試!

    stop-writes-on-bgsave-error yes #持久化如果出錯,是否還需要繼續工作!

    rdbcompression yes #是否壓縮rdb文件,需要消耗一些cpu資源!

    rdbchecksum yes #保存rdb文件的時候,進行錯誤的檢查校驗

    dir ./ # rdb 文件保存的目錄

    REPLICATION復制,我們后面講解主從復制的時候再進行講解

    SECURITY安全

    可以在這里設置redis的密碼,默認是沒有密碼!
    127.0.0.1:6379> ping
    PONG
    127.0.0.1:6379> clear
    127.0.0.1:6379> config get requirepass # 獲取redis的密碼

  • “requirepass”
  • “”
    127.0.0.1:6379> config set requirepass “123456”# 設置redis的密碼
    OK
    127.0.0.1:6379> config get requirepass**# 發現所有的命令都沒有權限了**
    (error) NOAUTH Authentication required.
    127.0.0.1:6379> auth 123456 # 使用密碼登錄!
    ok
    127.0.0.1:6379> config get requirepass
  • “requirepass”
  • “123456”
  • 限制CLIENTS
    maxclients 10000 設置能連接上redis的最大客戶端的數量
    maxmemory redis 配置最大的內存容量
    maxmemory-policy noeviction 內存到達上限之后的處理策略
    #移除一些過期的key
    #報錯
    #…

    maxmemory-policy 六種方式
    1、volatile-lru:只對設置了過期時間的key進行LRU(默認值)
    2、allkeys-lru : 刪除lru算法的key
    3、volatile-random:隨機刪除即將過期key
    4、allkeys-random:隨機刪除
    5、volatile-ttl : 刪除即將過期的
    6、noeviction : 永不過期,返回錯誤

    APPEND ONLY模式 aof配置
    appendonly no # 默認時不開啟aof模式的,默認是使用rdb方式持久化的,在大部分所有情況下,rdb完全夠用!
    qppendfilename “appendonly.aof” # 持久化的文件的名字

    appendfsync always # 每次修改都會sync。消耗性能

    appendfsync everysec # 每秒執行一次synv,可能會丟失這ls的數據!

    appendfsynv no #不執行sync,這個時候操作系統自己同步數據,速度最快!

    具體的配置,在Redis持久化詳細講解

    Redis持久化

    面試和工作,持久化都是重點!

    Redis是內存數據庫,如果不將內存中的數據庫狀態保存到磁盤,那么一旦服務器進程退出,服務器中的數據庫狀態也會小時。所以Redis提供了持久化功能!
    RDB (Redis DataBase)
    在主從復制中,rdb就是備用了!從機上面!

    在指定的時間間隔內將內存中的數據集快照寫入磁盤,也就是行話講的Snapshot快照,它恢復時是將快照文件直接讀到內存里。

    Redis會單獨創建(fork)一個子進程來進行持久化,會先將數據寫入到一個臨時文件中,待持久化過程都結束了,再用這個臨時文件替換上次持久化好的文件。整個過程中,主進程是不進行任何IO操作的。這就確保了極高的性能。如果需要進行大規模數據的恢復,且對于數據恢復的完整性不是非常敏感,那RDB方式要比AOF方式更加的高效,RDB的缺點就是最后一次持久化后的數據可能丟失。我們默認的就是RDB,一般情況下不需要修改這個配置!

    有時候在生產環境我們會將這個文件進行備份 !

    rdb保存的文件時dump.rdb 都是在我們的配置文件快照中進行配置的!

    觸發機制
    1.save的規則滿足的情況下,會自動觸發rdb規則
    2.執行flushall命令,也會觸發我們的rdb規則
    3.推出redis,也會產生rdb文件 !
    備份就自動生成一個dump.rdb

    如果恢復rdb文件!
    1.只需要將rdb文件放在我們的redis啟動目錄就可以了,reids啟動的時候會自動檢查dump.rdb恢復其中的數據!
    2.查看需要存放的位置
    127.0.0.1:6379>config get dir

  • “dir”
  • “/usr/local/bin” #如果在這個目錄下存在dump.rdb文件,啟動就會自動恢復其中的數據
    幾乎他自己默認的配置就夠用了,但是我們還是需要學習
    優點
    1.適合大規模的數據恢復!
    2.對數據的完整性要求不高!
    缺點
    1.需要一定的時間間隔進程操作!如果redis意外宕機了,這個最后一次修改數據就沒有了
    2.fork進程的時候,會占用一定的內存空間
  • AOF(Append Only File)
    將所有的命令都記錄下來,history,恢復的時候就把這個文件全部執行一遍 !



    以日志的形式來記錄每個寫操作,將Redis執行過的所有指令記錄下來(該操作不記錄),只許追加文件但不可以改寫文件,redis啟動之初會讀取該文件重新構建數據,換言之,redis重啟的話就根據日志文件的內容將寫指令從前到后執行一次以完成數據的恢復工作

    *Aof保存的是appendonly.aof 文件 *

    append

    默認是不開啟的,我們需要手動進行配置!我們只需要將appendonly改為yes就開啟了aof!
    重啟redis,就生效了!
    如果這個aof文件有錯誤,這時候redis是啟動不起來的,我們需要修復這個aof文件
    redis給我們提供給了一個工具 redis-check-aof

    如果文件修復成功,重啟就可以直接恢復了

    重寫規則說明
    aof默認就是文件的無限追加,文件會越來越大!

    如果aof文件大于64m,太大了!fork一個新的進程來講我們的文件進行重寫!

    優點和缺點

    appendonly no # 默認時不開啟aof模式的,默認是使用rdb方式持久化的,在大部分所有情況下,rdb完全夠用!
    qppendfilename “appendonly.aof” # 持久化的文件的名字

    appendfsync always # 每次修改都會sync。消耗性能
    appendfsync everysec # 每秒執行一次synv,可能會丟失這ls的數據!
    appendfsynv no #不執行sync,這個時候操作系統自己同步數據,速度最快!

    優點:
    1.每一次修改都同步,文件的完整性會更好!
    2.每秒同步一次,可能會丟失一秒的數據
    3.從不同步,效率最高的!
    缺點:
    1.相對于數據文件來說,aof遠遠大于rdb,修復速度也比rdb慢!
    2.Aof運行效率也要比rdb慢,所以我們redis默認的配置就是rdb持久化!

    Redis發布訂閱

    Redis發布訂閱(pub/sub)是一種消息通信模式:發送者(pub)發送消息,訂閱者(sub)接收消息。
    Redis客戶端可以訂閱任意數量的頻道。
    訂閱/發布消息圖:
    第一個:消息發送者,第二個:頻道 第三個:消息訂閱者

    下圖展示了頻道channel1,以及訂閱這個頻道的三個客戶端— —
    client2、client5和client之間的關系:

    當有消息通過PUBLISH命令發送給頻道channel1時,這個消息就會被發送給訂閱它的三個客戶端:

    命令

    這些命令被廣泛用于構建即時通信應用,比如網絡聊天室(chatroom)和實時廣播,實時提醒等。

    測試
    訂閱端
    127.0.0.1:6379> subscribe yuxiaoxue
    Reading messages… (press Ctrl-C to quit)

  • “subscribe”
  • “yuxiaoxue”
  • (integer) 1
    等待讀取推送的信息
  • “message” # 消息
  • “yuxiaoxue” #哪個頻道
  • “hello beautiful girl” # 消息的具體內容
  • “message”
  • “yuxiaoxue”
  • “hello redis”
    發送端
    127.0.0.1:6379> publish yuxiaoxue “hello beautiful girl” # 發布者發布信息到頻道!
    (integer) 1
    127.0.0.1:6379> publish yuxiaoxue “hello redis” # 發布者發布信息到頻道!
    (integer) 1
  • 原理

    使用場景:
    1.實時消息系統!
    2.實時聊天!(頻道當做聊天室,將信息回顯給所有人即可!)
    3.訂閱,關注系統都是可以的!
    稍微復雜的場景我們就會使用 消息中間件MQ()

    Redis主從復制

    概念
    主從復制,是指將一臺Redis服務器的數據,復制到其他的Redis服務器,前者稱為主節點(master/leader),后者稱為從節點(slave/follwer);數據的復制是單向的,只能由主節點到從節點,Master以寫為主,Slave以讀為主。

    默認情況下,每臺Redis都是主節點;且一個主節點可以有多個從節點(或沒有從節點),但一個從節點只能有一個主節點。

    主從復制的作用主要包括:

    1.數據冗余:主從復制實現了數據的熱備份,是持久化之外的一種數據冗余方式。
    2.故障恢復:當主節點出現問題時,可以由從節點提供服務,實現快速的故障恢復;實際上是一種服務的冗余。
    3.負載均衡:在主從復制的基礎上,配合讀寫分離,可以由主機誒單提供寫服務,由從節點提供讀服務(即寫Redis數據時應用連接主節點,讀Redis數據時應用連接從節點),分擔服務器負載:尤其是在寫少讀多的場景下,通過多個從節點分擔讀負載,可以大大提高Redis服務器的并發量。
    4.高可用基石:除了上述作用以外,主從復制還是哨兵和集群能夠實施的基礎,因此說主從復制是Redis高可用的基礎。

    一般來說,要將Redis運用于工程項目中,只使用一臺Redis是萬萬不能的(宕機),原因如下:
    1.從結構上,單個Redsi服務器會發生單點故障,并且一臺服務器需要處理所有的負載均衡,壓力較大;
    2.從容量上,單個Redis服務器內存容量有限,就算一臺Redis服務器內存容量為256G,也不能將所有的內存作Redis存儲內存,一般來說,單臺Redis最大使用內存不應該超過20G

    電商網站上的商品,一般都是一次上傳,無數次瀏覽的,說專業點也就是“多讀少寫”。
    對于這種場景,我們可以使用如下這種架構:

    主從復制,讀寫分離!80%的情況下都是在進行讀操作!減緩服務器的壓力!架構中經常使用!一主二從!
    只要在公司中,主從復制就是就是必須要使用的,因為在真實的項目中不可能單機使用Redis!

    環境配置
    只配置從庫,不用配置主庫!

    127.0.0.1:6379> info replication #查看當前庫的信息

    Replication

    role:master 角色 master
    connected_slaves:0 #沒有從機
    master_repl_offset:0
    repl_backlog_active:0
    repl_backlog_size:1048576
    repl_backlog_first_byte_offset:0
    repl_backlog_histlen:0

    復制3個配置文件,然后修改對應的信息
    1.端口
    2.pid名字
    3.log文件名字
    4.dump.rdb名字
    修改完畢之后,啟動我們的3個redis服務器,可以通過進程信息查看!

    一主二從
    默認情況下,每臺Redis服務器都是主節點;我們一般情況下只用配置從機就好了!
    認老大!一主(79)二從(80、81)


    如果兩個都配置完,就有兩個從機

    真實的主從配置應該在配置文件中配置,這樣的話是永久的,我們這里使用的是命令,暫時的!

    細節

    主機可以寫,從機不能寫只能讀!主機中的所有信息和數據,都會被從機自動保存 !
    主機寫:

    從機只能讀取內容

    測試:主機斷開連接,從機依舊連接到主機的,但是沒有寫操作,這個時候,主機如果回來了,從機依舊可以直接獲取到主機寫的信息!
    如果是命令行,來配置的主從,如果重啟了,就會變回主機!只要變回從機,立馬就會從主機中獲取值!

    復制原理

    如果沒有老大了,這個時候能不能選擇一個老大出來呢?手動!

    謀朝篡位
    如果主機斷開了連接,我們可以用 SLAVEOF NO ONE命令讓自己變成主機!其它的節點就可以手動連接到最新的這個主節點(手動) !如果這個時候老大修復了,只能重新配置

    哨兵模式
    (自動選取老大的模式)

    概念

    主從切換技術的方法是:當主服務器宕機后,需要手動把一臺從服務器切換為主服務器,這就需要人工干預,費時費力,還會造成一段時間內服務不可用。這不是一種推薦的方式,更多時候,我們優先考慮哨兵模式。Redis從2.8開始正式提供了Sentinel(哨兵)架構來解決這個問題。

    謀朝篡位的自動版,能夠后臺監控主機是否故障,如果故障了根據投票數自動將從庫轉換為主庫

    哨兵模式是一種特殊的模式,首先Redis提供了哨兵的命令,哨兵是一個獨立的進程,作為進程,它會獨立運行。其原理是哨兵通過發送命令,等待Redis服務器響應,從而監控運行的多個Redis實例。

    這里的哨兵有兩個作用
    ●通過發送命令,讓Redis服務器返回監控其運行狀態,包括主服務器和從服務器。
    ●當哨兵檢測到master宕機,會自動將Slave切換成master,然后通過發布訂閱模式通知其它的從服務器,修改配置文件,讓他們切換主機。

    然而一個哨兵進程對Redis服務器進行監控,可能會出現問題,為此,我們可以使用多個哨兵進行監控,各個哨兵之間還會進行監控,這樣就形成了多哨兵模式。

    假設主服務器宕機,哨兵1先檢測到這個結果,系統并不會馬上進行failover過程,僅僅是哨兵1主觀的認為服務器不可用,這個現象成為主觀下線。當后面的哨兵也檢測到主服務器不可用,并且數量打到一定值時,那么哨兵之間就會進行一次投票,投票的結果由一個哨兵發起,進行failover【故障轉移】操作。切換成功后,就會通過發布訂閱模式,讓各個哨兵把自己監控的從服務器實現切換主機,這個過程成為客觀下線

    測試
    我們目前的狀態是一主二從
    1、配置值哨兵配置文件sentinel.conf

    后面的這個數字1,代表主機掛了,slave投票看讓誰接替成為主機,票數最多的,就會成為主機!
    2、啟動哨兵 !

    如果Master(主機)節點斷開了,這個時候就會從從機中隨機選擇一個服務器!(這里面有一個投票算法!)

    哨兵日志

    如果主機此時回來了,只能歸并到新的主機下,當做從機,這就是哨兵模式的規則!

    哨兵模式
    優點:
    1、哨兵集群,基于主從復制模式,所以的主從配置優點,它全有
    2、主從可以切換,故障可以轉換,系統的可用性就會更好
    3、哨兵模式就是主從模式的升級,手動到自動,更加健壯!
    缺點:
    1、Redis不好在線擴容的,集群容量一旦達到上線,在線擴容就十分麻煩!
    2、實現哨兵模式的配置其實是很麻煩的,里面有很多選擇!

    哨兵模式的全部配置

    社會目前程序員飽和(初級和中級)、高級程序員重金難求!(提升自己)

    Redis緩存穿透和雪崩

    緩存穿透 查不到

    緩存擊穿 量太大,緩存過期

    布隆過濾器

    緩存空對象
    當存儲層不命中后,即是返回的空對象也將其緩存起來,同時會設置一個過期時間,之后再訪問這個數據將會從緩存中獲取,保護了后端數據源;

    一、緩存處理流程

    前臺請求,后臺先從緩存中取數據,取到直接返回結果,取不到時從數據庫中取,數據庫取到更新緩存,并返回結果,數據庫也沒取到,那直接返回空結果。

    二、緩存穿透(查不到導致)

    描述:緩存穿透是指緩存和數據庫中都沒有的數據,而用戶不斷發起請求,如發起為id為“-1”的數據或id為特別大不存在的數據。這時的用戶很可能是攻擊者,攻擊會導致數據庫壓力過大。

    解決方案:

    接口層增加校驗,如用戶鑒權校驗,id做基礎校驗,id<=0的直接攔截;
    從緩存取不到的數據,在數據庫中也沒有取到,這時也可以將key-value對寫為key-null,緩存有效時間可以設置短點,如30秒(設置太長會導致正常情況也沒法使用)。這樣可以防止攻擊用戶反復用同一個id暴力攻擊

    三、緩存擊穿(量太大,緩存過期)

    概述

    緩存擊穿是指緩存中沒有但數據庫中有的數據(一般是緩存時間到期),這時由于并發用戶特別多,同時讀緩存沒讀到數據,又同時去數據庫去取數據,引起數據庫壓力瞬間增大,造成過大壓力

    解決方案

    1.設置熱點數據永遠不過期。
    2.加互斥鎖
    分布式鎖:使用分布式鎖,保證對于每個key同時只有一個線程去查詢后端服務,其他線程沒有獲得分布式鎖的權限,因此只需要等待即可。這種方式將高并發的壓力轉移到了分布式鎖,因此對分布式鎖的考驗很大。

    互斥鎖參考代碼如下:

    說明:1)緩存中有數據,直接走上述代碼13行后就返回結果了2)緩存中沒有數據,第1個進入的線程,獲取鎖并從數據庫去取數據,沒釋放鎖之前,其他并行進入的線程會等待100ms,再重新去緩存取數據。這樣就防止都去數據庫重復取數據,重復往緩存中更新數據情況出現。3)當然這是簡化處理,理論上如果能根據key值加鎖就更好了,就是線程A從數據庫取key1的數據并不妨礙線程B取key2的數據,上面代碼明顯做不到這點。

    四、緩存雪崩


    描述:緩存雪崩是指緩存中數據大批量到過期時間,而查詢數據量巨大,引起數據庫壓力過大甚至down機。和緩存擊穿不同的是,緩存擊穿指并發查同一條數據,緩存雪崩是不同數據都過期了,很多數據都查不到從而查數據庫。

    解決方案:
    緩存數據的過期時間設置隨機,防止同一時間大量數據過期現象發生。
    如果緩存數據庫是分布式部署,將熱點數據均勻分布在不同搞得緩存數據庫中。
    設置熱點數據永遠不過期。

    小結

    聲明:此博客是在聽講狂神Redis課程總結,然后自己整理所得,僅供參考!!!如想學習,歡迎b站搜索 ‘遇見狂神說’*

    總結

    以上是生活随笔為你收集整理的狂神 redis笔记 docker的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

    91精品国产99久久久久久久 | 久草视频视频在线播放 | av在线激情 | 日韩国产精品久久久久久亚洲 | 亚洲专区路线二 | 婷婷五天天在线视频 | 在线观看久久久久久 | 丁香5月婷婷 | 麻豆视频在线免费看 | 91亚洲精品久久久蜜桃 | 日韩一区在线播放 | 国产拍揄自揄精品视频麻豆 | 麻花豆传媒一二三产区 | 在线观看av小说 | 久久夜色精品国产欧美一区麻豆 | 国产精品一区免费在线观看 | 久久伊人婷婷 | 国产日韩视频在线播放 | 精品国产免费一区二区三区五区 | 一区二区av | 99久久www免费| 天天干,天天操,天天射 | 最新中文字幕在线播放 | 国产精品黄色影片导航在线观看 | 精品人妖videos欧美人妖 | 精品福利在线观看 | 欧美一区二区三区激情视频 | 欧美日韩国产一区二区三区在线观看 | 国产超碰在线观看 | 4hu视频| 免费看片日韩 | 97视频中文字幕 | 国产成人综合在线观看 | 91最新在线 | 在线观看中文字幕亚洲 | 精品欧美日韩 | 久草在线看片 | 久久久99精品免费观看app | 国产尤物在线视频 | 日日天天| 国产不卡一 | 久久免费的视频 | 1000部18岁以下禁看视频 | 丁香婷婷激情国产高清秒播 | 国产毛片久久 | 国产日产精品一区二区三区四区 | 18女毛片 | 久久婷婷影视 | 久久综合久色欧美综合狠狠 | 一区二区视频免费在线观看 | 一区二区三区www | 国产探花视频在线播放 | 97成人精品区在线播放 | 天天干天天草 | 天天操天天色天天 | 中文字幕在线日本 | 久久一区二区三区国产精品 | 精品国产日本 | 久久超 | 久草手机视频 | 久久草 | 日韩三级视频 | 婷婷精品国产一区二区三区日韩 | 91av小视频 | 欧美日韩国产在线观看 | 黄色小说免费观看 | 国产亚洲精品久久久久动 | 91麻豆精品国产 | 香蕉网在线 | 美女黄网久久 | 波多野结衣在线视频一区 | 深夜免费福利在线 | 日韩精品中文字幕有码 | 黄色毛片在线 | 一区二区三区av在线 | 黄色免费大片 | 日本公妇在线观看 | 天天舔天天射天天操 | 久久精品99精品国产香蕉 | 狠狠干2018 | 国产日产亚洲精华av | 午夜久久久久久久久 | 欧美另类老妇 | 成 人 黄 色 视频 免费观看 | 在线观看蜜桃视频 | 97成人精品| 久久综合导航 | 一级特黄aaa大片在线观看 | 色婷婷久久久综合中文字幕 | 国产精品v欧美精品 | 国产免费人成xvideos视频 | 三级黄色大片在线观看 | 丁香婷婷深情五月亚洲 | 在线精品亚洲一区二区 | 久久精品aaa | www国产亚洲| 日本中文字幕电影在线免费观看 | 天天躁日日躁狠狠躁av中文 | 人人天天夜夜 | 97精品国产97久久久久久久久久久久 | 久久久久久久av | 人人澡超碰碰97碰碰碰软件 | 亚洲国产精品99久久久久久久久 | 黄网站免费大全入口 | 99久久精品免费看国产一区二区三区 | 日韩精品免费一区二区三区 | 精品久久久久久亚洲 | 99热这里精品 | 超碰在线国产 | 日韩伦理片hd | 亚洲精品xx| 国产色就色 | 久久久久久亚洲精品 | 日韩综合一区二区三区 | 91视视频在线直接观看在线看网页在线看 | 天天添夜夜操 | 午夜av在线免费 | 国产精品久久一卡二卡 | 免费aa大片 | 一本到视频在线观看 | 丁香高清视频在线看看 | 国产成人精品久久久久蜜臀 | 在线观看网站av | 人九九精品 | 亚洲综合视频在线 | 97精品国产91久久久久久 | 日韩丝袜在线观看 | 亚洲免费精彩视频 | 亚州精品在线视频 | 热久精品| 亚洲精品免费在线 | 开心激情五月婷婷 | 免费人成在线观看 | 亚洲精品乱码久久久久久 | 亚洲精品国产成人 | 国产一区二区在线免费观看 | 国产999免费视频 | 久久久国产精品网站 | 久久国产精品免费 | 国产精品久久久久三级 | 九九九在线观看 | 超碰av在线播放 | av网站在线观看免费 | 亚洲 欧美 另类人妖 | 成人性生交大片免费看中文网站 | 一区二区三区高清 | 在线观看的a站 | 日韩欧美精品免费 | 久久精品a| 日韩午夜视频在线观看 | 日韩欧美在线视频一区二区三区 | 久久久久久久国产精品影院 | 欧美日韩一区二区在线观看 | 国产精品一区二区久久国产 | 精品久久久久久综合 | 免费国产亚洲视频 | 欧美成人亚洲成人 | 成人午夜av电影 | 日韩一区二区三区观看 | 91精品久久久久久综合乱菊 | 婷婷日| www.天天干 | 亚洲免费在线播放视频 | 国产99在线免费 | 国产亚洲在线视频 | 懂色av一区二区在线播放 | 国产精品久久久久久久久久久久午夜 | 国产成人61精品免费看片 | 粉嫩一二三区 | 国产精品亚洲片夜色在线 | 91精品免费在线 | 亚洲精品在线观看av | 日韩精品久久久久久久电影竹菊 | 亚洲免费成人av电影 | 国产一二三四在线视频 | 狠狠色狠狠色综合日日小说 | 成人激情开心网 | 国产精品黄网站在线观看 | 在线观看av麻豆 | 人人爽人人av | 中文久久精品 | 最新精品国产 | 日韩免费不卡视频 | 久久精品一区二区三区中文字幕 | 亚洲综合情 | 丁香资源影视免费观看 | 久久国产精品系列 | 日韩在线视频网站 | 日韩a在线观看 | 亚洲国产成人精品在线 | 亚洲精品综合久久 | av女优中文字幕在线观看 | 免费日韩三级 | 成人黄色在线看 | 久久高清免费观看 | 偷拍精偷拍精品欧洲亚洲网站 | 国产精品9区 | 涩涩网站在线观看 | 一级黄色电影网站 | 在线播放视频一区 | 精品在线看| 国产成人精品一区在线 | 在线观看免费版高清版 | 999成人国产 | 五月婷婷在线观看 | 国产精品片 | www视频在线观看 | 久久美女精品 | 黄色av电影网 | 久久久久成人精品 | 欧美激情视频一区二区三区免费 | 97av影院| 中文国产在线观看 | 国产精品国产三级国产aⅴ9色 | 91九色视频在线观看 | 亚洲国产美女久久久久 | 成人av一区二区在线观看 | 久久一精品 | 狠狠色丁香婷婷综合基地 | 欧美一级日韩三级 | 99精品视频一区 | 精品欧美一区二区精品久久 | 色狠狠婷婷 | 91视频黄色 | 国产精品美女久久久网av | 97超碰精品 | 久久久久久久久影院 | 亚洲国产精品电影 | 久草网在线 | 在线免费看黄色 | 天天色棕合合合合合合 | 久热久草 | 免费观看xxxx9999片 | 天堂av在线网站 | 热久久国产| 日韩精品欧美专区 | 亚洲精品乱码久久久久久高潮 | 日韩有码中文字幕在线 | 国内久久久 | 亚洲欧洲国产日韩精品 | 国产破处在线视频 | 韩国精品一区二区三区六区色诱 | 2021国产精品视频 | 成人试看120秒 | 亚洲国产婷婷 | 欧美视频在线观看免费网址 | 91手机在线看片 | 国产精品久久久久av免费 | 国产一区二区中文字幕 | 日韩高清成人 | 国产精品久久9 | 日韩av电影免费观看 | 天天干天天搞天天射 | 久久精品美女 | 91精品在线麻豆 | 在线免费91| 国产精品va视频 | 波多野结衣一区二区三区中文字幕 | 日本护士撒尿xxxx18 | 婷婷色吧| 久久亚洲婷婷 | 久久久久亚洲a | 国产精品久久久久久久久毛片 | 久久理伦片 | 精品欧美一区二区在线观看 | japanesefreesex中国少妇 | 中文字幕免费国产精品 | 99精品国产99久久久久久福利 | 国内视频在线 | 国产精品123| www.黄色片.com | 国产精品日韩在线观看 | 黄色片网站大全 | 狠狠躁日日躁狂躁夜夜躁av | 狠狠久久伊人 | 亚洲最快最全在线视频 | 欧洲一区二区三区精品 | 久久刺激视频 | 精品国产视频在线观看 | 国产亚洲精品成人av久久ww | 伊人婷婷网 | 中文字幕有码在线观看 | 中字幕视频在线永久在线观看免费 | 欧美精品一区二区蜜臀亚洲 | 麻豆传媒视频在线播放 | 国产午夜激情视频 | 久久久精品国产一区二区三区 | 日韩激情久久 | 色综合欧洲| 欧美日韩视频免费 | 国产精品久久99精品毛片三a | 91麻豆精品国产自产 | 最近久乱中文字幕 | 国产日韩在线视频 | 成年人视频在线观看免费 | 日韩美女一级片 | 国产不卡视频在线 | 久久婷亚洲五月一区天天躁 | 最新av中文字幕 | 白丝av在线| 一区二区三区免费看 | 久久久久久久久久久免费 | 日本aaa在线观看 | 最近久乱中文字幕 | 亚洲成人精品久久久 | 在线成人性视频 | 国产一级二级在线观看 | 久久天天综合网 | 国产精品一区二区在线观看免费 | 国产一二区在线观看 | aa一级片| 精品一区二区综合 | 国产一区二区手机在线观看 | 久草久热 | 精品国产一区二区三区久久久久久 | 九色福利视频 | 色多多污污在线观看 | 精品国产伦一区二区三区观看方式 | 97成人资源站 | 日本三级中文字幕在线观看 | 日韩理论在线 | www五月天| 免费h视频 | 久久精品久久国产 | 色www免费视频 | 国产精品精品久久久 | 奇米影视8888在线观看大全免费 | 激情丁香5月 | 99在线视频网站 | 日韩免费高清 | 91av视频播放 | 一个色综合网站 | www久久久久| 国产精品毛片久久蜜 | 99精品偷拍视频一区二区三区 | 日本亚洲国产 | 国产精品午夜久久 | 日韩精品一区二区三区在线视频 | 色综合久久中文综合久久牛 | 色多多在线观看 | 999毛片 | 国产电影黄色av | 99久久国产免费,99久久国产免费大片 | 精品国产一区二区三区久久影院 | 国产男女爽爽爽免费视频 | 高清一区二区 | 久久五月天婷婷 | 久久精久久精 | 日韩久久午夜一级啪啪 | 日韩成人免费观看 | 五月天婷婷狠狠 | 一区二区久久久久 | 国模精品在线 | 国产高清在线看 | 国产97视频 | 在线看成人av | 最近中文字幕在线 | 777xxx欧美 | 久久激情电影 | 国产免费叼嘿网站免费 | 在线中文字幕av观看 | 久久精品99精品国产香蕉 | 不卡视频一区二区三区 | 欧美另类交在线观看 | 天天操欧美 | 亚洲视频免费在线 | 亚洲伊人成综合网 | 日本公乱妇视频 | 成 人 免费 黄 色 视频 | 中文字幕免费高清在线观看 | 黄色毛片在线观看 | 国产精品视频全国免费观看 | 91福利小视频 | 色噜噜在线观看视频 | 91亚洲永久精品 | 欧美性生活免费看 | 色婷av| 亚洲欧美一区二区三区孕妇写真 | 国产精品久久久久毛片大屁完整版 | 黄色在线免费观看网址 | 国产精品麻豆果冻传媒在线播放 | 97精品国产97久久久久久春色 | 国产黄色在线网站 | 丁香资源影视免费观看 | 91人人插| 午夜骚影| 成人免费看视频 | 精品高清视频 | 国产999 | 丝袜美女视频网站 | 精品国产一区二区三区在线 | 色婷婷国产精品 | 成 人 免费 黄 色 视频 | 91九色综合| 精品一区免费 | 国产成人久久久77777 | 2024国产在线| 午夜精品久久久久久久99 | 9i看片成人免费看片 | 最新中文在线视频 | 99热最新网址 | jizz欧美性9 国产一区高清在线观看 | 黄视频网站大全 | 日韩中文字幕免费电影 | 亚洲一区二区精品视频 | 国产 一区二区三区 在线 | 亚洲欧美日韩精品久久奇米一区 | 亚洲一二区精品 | 91精品在线播放 | 久久精品之 | 国产精品99久久久久久武松影视 | 国产最新视频在线观看 | 欧美日韩亚洲精品在线 | 手机成人免费视频 | 久久久麻豆精品一区二区 | 黄色国产成人 | 欧美日韩国语 | 最新av网站在线观看 | 人人爽人人干 | www久久99 | 亚洲影院色 | 国产中文字幕视频在线观看 | 黄色av免费看 | 国产剧情在线一区 | 国产精品久久久久999 | 精品99久久 | 偷拍精偷拍精品欧洲亚洲网站 | 狠狠干夜夜爽 | 国产精品18久久久久久久久久久久 | 怡春院av | 色婷婷精品大在线视频 | 免费成人在线观看视频 | 国产区精品视频 | av高清网站在线观看 | 不卡电影一区二区三区 | 国产精品一区二区三区四区在线观看 | 日本精品二区 | 国产精品淫 | 亚洲精品国偷拍自产在线观看 | 一区二区三区免费在线观看 | 伊人久操 | 久久久国产一区二区三区 | 亚洲免费观看在线视频 | 国产成年人av | 久久草在线视频国产 | 日韩电影一区二区在线观看 | 国产精品第72页 | 久久综合加勒比 | 久久伦理网 | 91九色成人| 免费aa大片 | 99中文字幕 | 97香蕉久久超级碰碰高清版 | 久久国产a | 国产福利一区二区三区视频 | 在线观看免费av片 | 国产精品99久久久久久人免费 | 精品国产aⅴ一区二区三区 在线直播av | 狠狠干网站 | 国产黄色免费观看 | 99精品黄色片免费大全 | 亚洲一区二区三区在线看 | 亚洲视频电影在线 | 久久99精品久久久久久三级 | 又黄又刺激视频 | 欧美在线一二 | 欧美精品在线一区二区 | 免费观看黄 | 久久国产精品99久久久久久丝袜 | 久久综合色8888 | 欧美日韩亚洲在线观看 | 伊人射| 天天操天天谢 | 少妇bbbb搡bbbb桶 | 国产精品第54页 | 久久福利 | 国产a网站 | 欧美天堂视频在线 | 黄色官网在线观看 | 岛国一区在线 | 一级黄色片毛片 | 成人国产精品免费观看 | www.狠狠插.com | 91视频 - 114av| 欧美精品在线观看一区 | 波多野结衣一区二区 | 三级黄色理论片 | 91av视频免费在线观看 | 成人丁香花| 黄色av成人在线 | 69国产在线观看 | 国产一区二区视频在线 | 国产小视频免费观看 | 久久99国产精品二区护士 | 在线观看免费 | 欧美日韩性视频 | 国产在线 一区二区三区 | 成人av在线直播 | 国产精品尤物 | 91av资源网 | 午夜视频在线瓜伦 | 毛片网站在线观看 | 黄色精品视频 | 国产成人精品久久亚洲高清不卡 | 国产精品一区二区白浆 | 波多野结衣一区 | 色综合久久精品 | 九九热在线观看视频 | 97超碰免费在线 | 精品久久久久久久久久久久 | 在线观看91网站 | 国产一区在线观看免费 | 精品国产免费看 | 亚洲精品国产精品99久久 | 亚洲精品免费播放 | 中国一区二区视频 | 亚洲国产伊人 | 毛片随便看 | 色婷婷伊人 | 日韩视频免费在线 | 少妇性色午夜淫片aaaze | 亚洲成人欧美 | 久久久夜色 | 人人澡人摸人人添学生av | 日韩影视大全 | 色婷婷综合五月 | 国产午夜三级一区二区三桃花影视 | 9999在线| 久草视频免费在线观看 | 免费黄色激情视频 | 国产精品久久久久久久久久久免费 | 91看片淫黄大片一级在线观看 | 又长又大又黑又粗欧美 | 在线观看一级片 | 四川bbb搡bbb爽爽视频 | 国产精品系列在线播放 | 日韩av午夜在线观看 | 亚洲不卡123 | 国产精品久久二区 | 婷婷在线观看视频 | 看污网站 | 亚洲四虎 | 美女中文字幕 | av福利在线看 | 亚洲精品视频偷拍 | 久久久国产影视 | 久久国产高清视频 | 欧美精品中文字幕亚洲专区 | 国产午夜三级 | 日韩三级视频在线观看 | 国产精品精品国产色婷婷 | 欧美精品在线观看免费 | 亚洲影视九九影院在线观看 | av福利超碰网站 | 永久免费的啪啪网站免费观看浪潮 | 日韩精品2区 | 这里有精品在线视频 | 欧美三级在线播放 | 777奇米四色 | 综合国产在线 | 中文字幕日韩av | 成人国产精品免费 | 欧美精品网站 | 三级在线视频观看 | 人人澡人人添人人爽一区二区 | 亚洲婷婷综合色高清在线 | 一级黄色av| 中文字幕一区在线 | 国产成人a亚洲精品v | 欧美极品一区二区三区 | 91大神在线观看视频 | 国产精品毛片一区二区 | 91激情视频在线观看 | 黄色网免费 | 国产视频2| 日本中文字幕在线一区 | 成人一级免费视频 | 久草免费在线 | 中文亚洲欧美日韩 | 日韩激情网 | 亚洲精品视频偷拍 | 久久免费视频在线观看30 | 国产中文字幕在线视频 | 最近中文字幕mv | 日韩大片在线免费观看 | 超碰官网| 国产亚洲精品成人av久久影院 | 免费一级黄色 | 久久激五月天综合精品 | 黄色av播放 | 天天操综 | 日韩欧美网站 | 欧美成人手机版 | 久久久国产成人 | 天堂在线一区二区 | 97精品国产97久久久久久 | 国产91精品一区二区麻豆网站 | 欧亚日韩精品一区二区在线 | aa级黄色大片 | 最新免费av在线 | 久久福利小视频 | 91成人破解版 | 丁香婷婷综合激情五月色 | 日韩av片免费在线观看 | 亚洲综合成人婷婷小说 | 国产精品成人自产拍在线观看 | 亚洲精品免费看 | 亚洲禁18久人片 | 日免费视频 | 日本精品一区二区在线观看 | 欧美日本一二三 | 久久99这里只有精品 | 国产专区视频在线 | 91免费网址 | 97电影在线观看 | av性网站| 久久久首页 | 国内精品视频久久 | 91网站在线视频 | 福利一区在线视频 | 麻豆影视在线观看 | 亚洲蜜桃在线 | 九九九在线观看 | 麻豆影视网 | 成人在线免费看视频 | 日韩经典一区二区三区 | 久久人人爽爽人人爽人人片av | 国产麻豆精品久久一二三 | 天天操操| 视频在线观看国产 | 99国产精品免费网站 | 国产精品永久免费在线 | av电影在线播放 | 亚洲 欧美 综合 在线 精品 | 91精品婷婷国产综合久久蝌蚪 | 久久久久久久久久网站 | 99精品久久99久久久久 | 天天综合入口 | 一区二区三区福利 | 亚洲成av人片在线观看香蕉 | 中文字幕高清视频 | 超碰在线观看97 | 国产亚洲aⅴaaaaaa毛片 | 最近2019好看的中文字幕免费 | 久久久天天操 | 亚洲精品国久久99热 | 天天操福利视频 | 欧美一级裸体视频 | 国产精品刺激对白麻豆99 | 亚洲国产免费网站 | 日日躁你夜夜躁你av蜜 | 丁香花在线视频观看免费 | 最新av网址在线 | 日韩电影在线观看一区二区 | 国产精成人品免费观看 | 国产在线观看不卡 | 国产丝袜一区二区三区 | 在线免费精品视频 | 91免费网址 | 国产精品久久久久久久久久久免费看 | 亚洲精品国产综合久久 | 91精品国产成人 | 亚洲欧洲国产视频 | 欧美精品一区二区三区一线天视频 | 手机在线观看国产精品 | avcom在线| 日韩欧美一区二区在线观看 | 99视频| 亚洲在线精品视频 | 成人在线小视频 | 日韩精品免费在线观看视频 | 色天堂在线视频 | 久草在线中文视频 | 深夜成人av| 亚洲国产精品成人女人久久 | 天天天干天天天操 | 91亚洲综合 | 在线观看韩日电影免费 | 国产视频综合在线 | 人人爱爱人人 | 日本精品视频免费 | 国产老妇av | 欧美精品一区二区三区四区在线 | 中文字幕一区二区三区视频 | 精品国产亚洲一区二区麻豆 | 国产无套精品久久久久久 | 91精品高清 | 欧美激情视频一二区 | 国产精品自产拍在线观看中文 | 久久只精品99品免费久23小说 | 99久久婷婷国产一区二区三区 | 婷婷色狠狠 | 久久久久久久久福利 | 久久综合给合久久狠狠色 | 久久久综合香蕉尹人综合网 | 久久久影视 | 波多野结衣在线观看视频 | 久草视频2| 婷婷六月天丁香 | 国产色在线 | 日韩av一区二区三区在线观看 | 在线三级av | 亚洲精品一区中文字幕乱码 | 精品国产乱码久久久久久1区2匹 | 一区二区三区不卡在线 | 1024手机看片国产 | 免费无遮挡动漫网站 | 在线观看av免费 | www夜夜操 | 五月婷婷久久丁香 | 视频在线观看日韩 | 天天操天操 | 日韩欧美在线一区二区 | 婷婷视频在线 | 国产精品久久久久久久久久尿 | 亚洲人成在| 在线播放亚洲激情 | 国产日韩精品在线 | 国产一级一片免费播放放 | 成人免费视频网址 | 欧美一区二区视频97 | 色av男人的天堂免费在线 | 最近日本韩国中文字幕 | 久久国产成人午夜av影院潦草 | 欧美久久久久久久久中文字幕 | 亚洲国产精品第一区二区 | 国产精品一区二区你懂的 | 久久亚洲成人网 | 丁香六月天婷婷 | 黄色av网站在线观看 | 丁香六月婷婷综合 | 欧美日韩二三区 | 亚洲午夜久久久久久久久电影网 | 日韩精品免费在线观看视频 | 亚洲精品中文字幕视频 | 午夜的福利 | 97在线免费视频 | 69av免费视频 | 精品电影一区二区 | 午夜免费在线观看 | 黄色一级动作片 | 天天干视频在线 | 中文字幕 二区 | 国产v欧美| a级成人毛片 | 在线草| 精品久久久久久亚洲综合网 | 99高清视频有精品视频 | 在线观看 国产 | 国产人成免费视频 | 极品美女被弄高潮视频网站 | 免费看成年人 | 精品一区二区久久久久久久网站 | 免费能看的av | 亚洲一区视频免费观看 | 天堂网中文在线 | 久久久91精品国产一区二区精品 | 国产精品一区二区你懂的 | 久草热久草视频 | 国产一区二区电影在线观看 | 毛片的网址| 亚洲国产免费看 | 九九久久在线看 | 天天操天天爽天天干 | 夜夜爽88888免费视频4848 | 日韩一区二区三区免费视频 | 日本高清中文字幕有码在线 | 国产精品mv | 亚洲成a人片综合在线 | 久久久精品日本 | 97在线视频网站 | 狠狠色狠狠色综合系列 | 久久乱码卡一卡2卡三卡四 五月婷婷久 | 欧美久久久久久久久久久 | 超碰97国产精品人人cao | 黄色a级片在线观看 | 欧美一区日韩一区 | 日本精品视频一区二区 | 日韩一区二区三 | 久99久精品 | 91理论片午午伦夜理片久久 | 国产精品久久久久久久久久久免费 | 日日干夜夜草 | 91精品视频在线免费观看 | 91精品1区2区 | 欧美经典久久 | 欧美成人69av | 午夜在线国产 | 综合激情久久 | 狠狠婷婷 | 成人免费视频播放 | 中文字幕在线观看第一区 | 国产麻豆精品一区 | 亚洲日本成人网 | 黄色美女免费网站 | 丰满少妇一级 | 香蕉视频日本 | 成人国产精品久久久春色 | 97超碰中文字幕 | 色综合中文字幕 | 日韩极品在线 | 欧美日韩精品在线观看 | 国产精品久久久久久久久久久久午夜 | 99热最新精品 | 色综合www | 中文字幕一区二区三区视频 | 国产九九九视频 | 99精品视频一区二区 | 色综合久久中文字幕综合网 | 国产在线播放一区二区三区 | av一级在线观看 | 亚洲天堂视频在线 | 九九九热精品免费视频观看 | 国产三级视频 | 亚洲日韩精品欧美一区二区 | a级一a一级在线观看 | 久草五月 | 免费视频一二三区 | av电影一区二区三区 | 91久色蝌蚪 | 最近2019中文免费高清视频观看www99 | 欧美日韩在线免费观看视频 | av黄色国产 | 日韩视频精品在线 | 午夜视频在线观看一区 | 97干com | 欧美a级免费视频 | 国产精品视频在线观看 | 亚洲黄色精品 | 日日夜夜网站 | 久热久草 | av一区二区三区在线 | 国产 日韩 欧美 中文 在线播放 | 99免费在线视频 | 麻豆果冻剧传媒在线播放 | 在线国产福利 | 成人免费在线播放视频 | 日批视频国产 | 国产高清视频免费在线观看 | av免费观看高清 | 在线看片a | 96av视频 | 国产成人精品久久久久蜜臀 | 五月婷丁香网 | 高清不卡一区二区三区 | 国产精品一区二区麻豆 | 麻豆一二 | 国产精品白丝jk白祙 | 精品在线亚洲视频 | 91麻豆精品国产91久久久无需广告 | 最近乱久中文字幕 | 国产精品 欧美 日韩 | 亚洲成人av在线电影 | 天天干一干 | 在线不卡视频 | 国产一级二级视频 | 毛片网站观看 | 色橹橹欧美在线观看视频高清 | 久久久麻豆精品一区二区 | 91精品在线观看视频 | 欧美黄网站 | 在线免费观看羞羞视频 | 免费色黄| 精品一区二区影视 | 国产剧情在线一区 | 亚洲综合在线五月 | 国产一级特黄毛片在线毛片 | 久久免费播放视频 | 久久婷婷一区二区三区 | 免费在线观看av网站 | 国精产品一二三线999 | 婷婷成人亚洲综合国产xv88 | 国内少妇自拍视频一区 | 激情视频在线观看网址 | 正在播放日韩 | 国产视频日本 | 日韩精品在线视频免费观看 | 911国产在线观看 | 夜夜干天天操 | 在线直播av | 99久热在线精品视频观看 | 天天干天天操天天搞 | 精品一区二区在线看 | av在线免费观看不卡 | 天天色影院 | 国产亚洲精品美女 | 91麻豆精品国产自产在线 | 美女久久精品 | 97精品国自产拍在线观看 | 在线观看黄网站 | 超碰97.com | 免费欧美高清视频 | 免费一级毛毛片 | 久香蕉 | 超碰伊人网| 久久人人精| 亚洲一区二区三区四区在线视频 | 国产在线91精品 | 国产精品一二 | 国际精品网 | 天天干天天拍天天操天天拍 | 人人超碰免费 | 欧美日韩一区二区在线观看 | 国产在线观看h | 亚洲伊人av | 日本在线观看一区 | 久久看片网站 | 天天插天天干天天操 | 在线看片一区 | 首页av在线 | 狠狠狠狠狠狠天天爱 | 99久久日韩精品视频免费在线观看 | 99久久er热在这里只有精品15 | 人人草在线观看 | 成人羞羞视频在线观看免费 | 日本一区二区不卡高清 | 日日狠狠| 97理论片| 一区二区精品视频 | 天天插狠狠干 | 热精品| 国产在线久久久 | 又黄又爽的视频在线观看网站 | 中文字幕在线日亚洲9 | 91亚洲精品久久久久图片蜜桃 | 亚洲成人av一区二区 | 国产成人久久久77777 | 日韩av网址在线 | 探花视频免费在线观看 | 天天草天天操 | 亚洲国产中文在线 | 特级毛片网站 | 久久精品欧美一区二区三区麻豆 | 欧美一级特黄aaaaaa大片在线观看 | av在线直接看 | 中文字幕第一页在线视频 | 激情综合色图 | 成人日批视频 | 国产一区在线视频观看 | 少妇av片| 天天干天天怕 | 黄色av电影在线观看 | 最近中文字幕第一页 | 一区二区三区电影大全 | 欧美91精品久久久久国产性生爱 | 一级黄色片在线免费观看 | 欧美在线一级片 | 一区二区理论片 | 日本中文在线播放 | 91丨九色丨国产丨porny精品 | 视频在线国产 | 精品视频在线播放 | 国产丝袜一区二区三区 | 日韩电影一区二区三区在线观看 | 全久久久久久久久久久电影 | 日韩激情在线 | 亚洲精品在线观看视频 | 日日碰狠狠添天天爽超碰97久久 | 中文字幕高清有码 | 久久久久久国产精品亚洲78 | 国产黄色资源 | 在线视频日韩欧美 | 久久久久久久久久久久久久av | 国产精品a久久 | 欧美激情在线看 | 91综合色 | 国产精品一区二区三区视频免费 | 精品一二三四视频 | 国产精品久久久久久久久岛 | 欧美孕妇视频 | 久久视频这里有精品 | 麻豆一区二区 | 亚洲另类视频在线 | 成人国产在线 | 色婷婷视频在线 | 天天操福利视频 | 亚洲精品伦理在线 | 亚洲91中文字幕无线码三区 | 亚洲九九影院 | 婷婷五综合 | 国产精品一区二区三区在线免费观看 | 日韩特级片 | 在线观看国产日韩 | 国产三级香港三韩国三级 | a级国产毛片| 成人一级片免费看 | 人人射人人爱 | 视频在线观看亚洲 | 成人国产精品一区二区 | 黄色免费电影网站 | 国产一区二区三区午夜 | 黄色福利| 国产精品一区在线观看你懂的 | 国产精品久久久久久久久久不蜜月 | 免费国产黄线在线观看视频 | 91成人免费看片 | 在线观看国产一区二区 | 久久九九免费视频 |