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

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

学一点Redis基础

發(fā)布時間:2023/12/14 数据库 59 豆豆
生活随笔 收集整理的這篇文章主要介紹了 学一点Redis基础 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

文章目錄

  • 學(xué)一點(diǎn)Redis基礎(chǔ)
    • **Redis介紹**
    • **安裝**
    • **配置文件詳解**
    • **數(shù)據(jù)類型**
      • **字符串類型(string)**
        • **==位圖操作bitmap==**
      • **列表數(shù)據(jù)類型(List)**
      • **==Hash散列數(shù)據(jù)類型==**
      • **集合數(shù)據(jù)類型(set)**
      • **==有序集合sortedset==**
      • **五大數(shù)據(jù)類型及應(yīng)用場景**
    • **==數(shù)據(jù)持久化==**
    • **==Redis主從復(fù)制==**
    • **==官方高可用方案Sentinel==**
    • **==分布式鎖==**
    • **博客項(xiàng)目解決高并發(fā)問題**
    • **Redis事務(wù)**
    • **pipeline補(bǔ)充**
    • **Redis常見問題匯總**

學(xué)一點(diǎn)Redis基礎(chǔ)

Redis介紹

  • 特點(diǎn)及優(yōu)點(diǎn)
1、開源的,使用C編寫,基于內(nèi)存且支持持久化 2、高性能的Key-Value的NoSQL數(shù)據(jù)庫 3、支持?jǐn)?shù)據(jù)類型豐富,字符串strings,散列hashes,列表lists,集合sets,有序集合sorted sets 等等 4、支持多種編程語言(C C++ Python Java PHP ...5、基于內(nèi)存存儲,經(jīng)常當(dāng)做緩存型數(shù)據(jù)庫使用,常用信息緩存在Redis數(shù)據(jù)庫中
  • 與其他數(shù)據(jù)庫對比
1、MySQL : 關(guān)系型數(shù)據(jù)庫,表格,基于磁盤,慢 2、MongoDB:鍵值對文檔型數(shù)據(jù)庫,值為JSON文檔,基于磁盤,慢,存儲數(shù)據(jù)類型單一 3、Redis的誕生是為了解決什么問題??# 解決硬盤IO帶來的性能瓶頸
  • 應(yīng)用場景
1、使用Redis來緩存一些經(jīng)常被用到、或者需要耗費(fèi)大量資源的內(nèi)容,通過這些內(nèi)容放到redis里面,程序可以快速讀取這些內(nèi)容 2、一個網(wǎng)站,如果某個頁面經(jīng)常會被訪問到,或者創(chuàng)建頁面時消耗的資源比較多,比如需要多次訪問數(shù)據(jù)庫、生成時間比較長等,我們可以使用redis將這個頁面緩存起來,減輕網(wǎng)站負(fù)擔(dān),降低網(wǎng)站的延遲,比如說網(wǎng)站首頁等 # redis的誕生是為了解決負(fù)載問題
  • redis版本
1、最新版本:5.0 2、常用版本:2.42.62.83.0(里程碑)3.23.44.0(教學(xué)環(huán)境版本)5.0 3、圖形界面管理工具( # 寫的一般 )RedisDesktopManager
  • Redis附加功能
1、持久化將內(nèi)存中數(shù)據(jù)保存到磁盤中,保證數(shù)據(jù)安全,方便進(jìn)行數(shù)據(jù)備份和恢復(fù) 2、過期鍵功能為鍵設(shè)置一個過期時間,讓它在指定時間內(nèi)自動刪除<節(jié)省內(nèi)存空間># 音樂播放器,日播放排名,過期自動刪除 3、事務(wù)功能原子的執(zhí)行多個操作 4、主從復(fù)制 5、Sentinel哨兵

安裝

  • Ubuntu
# 安裝 sudo apt-get install redis-server # 服務(wù)端啟動 sudo /etc/init.d/redis-server status | start | stop | restart # 客戶端連接 redis-cli -h IP地址 -p 6379 -a 密碼
  • Windows
1、下載安裝包https://github.com/ServiceStack/redis-windows/blob/master/downloads/redis-64.3.0.503.zip 2、解壓 3、啟動服務(wù)端雙擊解壓后的 redis-server.exe 4、客戶端連接雙擊解壓后的 redis-cli.exe# Windows下產(chǎn)生的問題:關(guān)閉終端后服務(wù)終止 # 解決方案:將Redis服務(wù)安裝到本地服務(wù) 1、重命名 redis.windows.conf 為 redis.conf,作為redis服務(wù)的配置文件 2、cmd命令行,進(jìn)入到redis-server.exe所在目錄 3、執(zhí)行:redis-server --service-install redis.conf --loglevel verbose 4、計(jì)算機(jī)-管理-服務(wù)-Redis-啟動# 卸載 到 redis-server.exe 所在路徑執(zhí)行: 1、redis-server --service-uninstall 2、sc delete Redis

配置文件詳解

  • 配置文件所在路徑
1、Ubuntu/etc/redis/redis.confmysql的配置文件在哪里? : /etc/mysql/mysql.conf.d/mysqld.cnf2、windows 下載解壓后的redis文件夾中redis.windows.conf redis.conf
  • 設(shè)置連接密碼
1、requirepass 密碼 2、重啟服務(wù)sudo /etc/init.d/redis-server restart 3、客戶端連接redis-cli -h 127.0.0.1 -p 6379 -a 123456127.0.0.1:6379>ping
  • 允許遠(yuǎn)程連接
1、注釋掉本地IP地址綁定69: # bind 127.0.0.1 ::1 2、關(guān)閉保護(hù)模式(把yes改為no)88: protected-mode no 3、重啟服務(wù)sudo /etc/init.d/redis-server restart
  • 遠(yuǎn)程連接測試

    Windows連接Ubuntu的Redis服務(wù)

# cmd命令行 1、e: 2、cd Redis3.0 3、redis-cli -h x.x.x.x -a 123456 4、x.x.x.x:6379>ping

數(shù)據(jù)類型

  • 通用命令 適用于所有數(shù)據(jù)類型
二進(jìn)制存儲 # 切換庫(number的值在0-15之間,db0 ~ db15) select number # 查看鍵 keys 表達(dá)式 # keys * # 數(shù)據(jù)類型 TYPE key # 鍵是否存在 exists key # 刪除鍵 del key # 鍵重命名 rename key newkey # 清除當(dāng)前庫中所有數(shù)據(jù)(慎用) flushdb # 清除所有庫中所有數(shù)據(jù)(慎用) flushall

字符串類型(string)

  • 特點(diǎn)
1、字符串、數(shù)字,都會轉(zhuǎn)為字符串來存儲 2、以二進(jìn)制的方式存儲在內(nèi)存中

字符串常用命令-必須掌握

# 1. 設(shè)置一個key-value set key value # 2. 獲取key的值 get key # 3. key不存在時再進(jìn)行設(shè)置(nx) set key value nx # not exists # 4. 設(shè)置過期時間(ex) set key value ex seconds# 5. 同時設(shè)置多個key-value mset key1 value1 key2 value2 key3 value3 # 6. 同時獲取多個key-value mget key1 key2 key3

字符串常用命令-作為了解

# 1.獲取長度 strlen key # 2.獲取指定范圍切片內(nèi)容 getrange key start stop # 3.從索引值開始,value替換原內(nèi)容 setrange key index value # 4.追加拼接value的值 append key value

數(shù)值操作-字符串類型數(shù)字(必須掌握)

# 整數(shù)操作 INCRBY key 步長 DECRBY key 步長 INCR key : +1操作 DECR key : -1操作 # 應(yīng)用場景: 抖音上有人關(guān)注你了,是不是可以用INCR呢,如果取消關(guān)注了是不是可以用DECR # 浮點(diǎn)數(shù)操作: 自動先轉(zhuǎn)為數(shù)字類型,然后再進(jìn)行相加減,不能使用append incrbyfloat key step

鍵的命名規(guī)范

? mset wang:email wangweichao@tedu.cn

127.0.0.1:6379> mset wang:email wangweichao@tedu.cn guo:email guods@tedu.cn OK 127.0.0.1:6379> mget wang:email guo:email 1) "wangweichao@tedu.cn" 2) "guods@tedu.cn" 127.0.0.1:6379>

string命令匯總

# 字符串操作 1set key value 2set key value nx 3、get key 3、mset key1 value1 key2 value2 4、mget key1 key2 key3 5set key value nx ex seconds 6、strlen key # 返回舊值并設(shè)置新值(如果鍵不存在,就創(chuàng)建并賦值) 7、getset key value # 數(shù)字操作 7、incrby key 步長 8、decrby key 步長 9、incr key 10、decr key 11、incrbyfloat key number#(可為正數(shù)或負(fù)數(shù)) # 設(shè)置過期時間的兩種方式 # 方式一 1set key value ex 3 # 方式二 1set key value 2、expire key 5 # 秒 3、pexpire key 5 # 毫秒 # 查看存活時間 ttl key # 刪除過期 persist key
  • string數(shù)據(jù)類型注意
# key值取值原則 1、key值不宜過長,消耗內(nèi)存,且在數(shù)據(jù)中查找這類鍵值的計(jì)算成本高 2、不宜過短,可讀性較差 # 值 1、一個字符串類型的值最多能存儲512M內(nèi)容

練習(xí)

1、查看 db0 庫中所有的鍵# select 0# keys * 2、設(shè)置鍵 trill:username 對應(yīng)的值為 user001,并查看# set trill:username user001 3、獲取 trill:username 值的長度# strlen trill:username 4、一次性設(shè)置 trill:password 、trill:gender、trill:fansnumber 并查看(值自定義)# mset trill:password 123 trill:gender M trill:fansnumber 500 5、查看鍵 trill:score 是否存在# exists trill:score 6、增加10個粉絲# incrby trill:fansnumber 10 7、增加2個粉絲(一個一個加)# incr trill:fansnumber# incr trill:fansnumber 8、有3個粉絲取消關(guān)注你了# decrby trill:fansnumber 3 9、又有1個粉絲取消關(guān)注你了# decr trill:fansnumber 10、思考、思考、思考...,清除當(dāng)前庫# flushdb 11、一萬個思考之后,清除所有庫# flushall

位圖操作bitmap

定義

1、位圖不是真正的數(shù)據(jù)類型,它是定義在字符串類型中 2、一個字符串類型的值最多能存儲512M字節(jié)的內(nèi)容,位上限:2^32 # 1MB = 1024KB # 1KB = 1024Byte(字節(jié)) # 1Byte = 8bit(位)

強(qiáng)勢點(diǎn)

可以實(shí)時的進(jìn)行統(tǒng)計(jì),極其節(jié)省空間。 官方在模擬128百萬用戶的模擬環(huán)境下,在一臺MacBookPro上,典型的統(tǒng)計(jì)如“日用戶數(shù)”的時間消耗小于50ms, 占用16MB內(nèi)存

設(shè)置某一位上的值(setbit)

# 設(shè)置某一位上的值(offset是偏移量,從0開始) setbit key offset value # 獲取某一位上的值 GETBIT key offset # 統(tǒng)計(jì)鍵所對應(yīng)的值中有多少個 1 2^32 BITCOUNT key

示例

# 默認(rèn)擴(kuò)展位以0填充 127.0.0.1:6379> set mykey ab OK 127.0.0.1:6379> get mykey "ab" 127.0.0.1:6379> SETBIT mykey 0 1 (integer) 0 127.0.0.1:6379> get mykey "\xe1b" 127.0.0.1:6379>

獲取某一位上的值

GETBIT key offset

127.0.0.1:6379> GETBIT mykey 3 (integer) 0 127.0.0.1:6379> GETBIT mykey 0 (integer) 1 127.0.0.1:6379>

bitcount

統(tǒng)計(jì)鍵所對應(yīng)的值中有多少個 1

127.0.0.1:6379> SETBIT user001 1 1 (integer) 0 127.0.0.1:6379> SETBIT user001 30 1 (integer) 0 127.0.0.1:6379> bitcount user001 (integer) 2 127.0.0.1:6379>

應(yīng)用場景案例

# 網(wǎng)站用戶的上線次數(shù)統(tǒng)計(jì)(尋找活躍用戶)用戶名為key,上線的天作為offset,上線設(shè)置為1 # 示例用戶名為 user1:login 的用戶,今年第1天上線,第30天上線SETBIT user1:login 0 1 SETBIT user1:login 29 1BITCOUNT user1:login

代碼實(shí)現(xiàn)

import redisr = redis.Redis(host='127.0.0.1',port=6379,db=0)# user001: 一年中第5天和200天登錄 r.setbit('user:001',4,1) r.setbit('user:001',199,1) # user002: 一年中第100天和第300天登錄 r.setbit('user:002',99,1) r.setbit('user:002',299,1) # user:003: 登錄了100次以上 for i in range(1,366,2):r.setbit('user:003',i,1) # user:004: 登錄了100次以上 for i in range(1,366,3):r.setbit('user:004',i,1)user_list = r.keys('user:*')# 存放活躍用戶列表 active_users = [] # 存放不活躍用戶列表 no_active_users = []for user in user_list:login_count = r.bitcount(user)if login_count >= 100:active_users.append((user,login_count))else:no_active_users.append((user,login_count))print('活躍用戶:',active_users) print('不活躍用戶:',no_active_users)

列表數(shù)據(jù)類型(List)

  • 特點(diǎn)
1、元素是字符串類型 2、列表頭尾增刪快,中間增刪慢,增刪元素是常態(tài) 3、元素可重復(fù) 4、最多可包含2^32 -1個元素 5、索引同python列表
  • 列表常用命令
# 增 1、從列表頭部壓入元素LPUSH key value1 value2 2、從列表尾部壓入元素RPUSH key value1 value2 3、從列表src尾部彈出1個元素,壓入到列表dst的頭部RPOPLPUSH src dst 4、在列表指定元素后/前插入元素LINSERT key after|before value newvalue# 查 5、查看列表中元素LRANGE key start stop# 查看列表中所有元素: LRANGE key 0 -1 6、獲取列表長度LLEN key# 刪 7、從列表頭部彈出1個元素LPOP key 8、從列表尾部彈出1個元素RPOP key 9、列表頭部,阻塞彈出,列表為空時阻塞BLPOP key timeout 10、列表尾部,阻塞彈出,列表為空時阻塞BRPOP key timeout# 關(guān)于BLPOP 和 BRPOP1、如果彈出的列表不存在或者為空,就會阻塞2、超時時間設(shè)置為0,就是永久阻塞,直到有數(shù)據(jù)可以彈出3、如果多個客戶端阻塞再同一個列表上,使用First In First Service原則,先到先服務(wù) 11、刪除指定元素LREM key count valuecount>0:表示從頭部開始向表尾搜索,移除與value相等的元素,數(shù)量為countcount<0:表示從尾部開始向表頭搜索,移除與value相等的元素,數(shù)量為countcount=0:移除表中所有與value相等的值 12、保留指定范圍內(nèi)的元素LTRIM key start stopLTRIM mylist1 0 2 # 只保留前3條# 應(yīng)用場景: 保存微博評論最后500條LTRIM weibo:comments 0 499# 改 13、LSET key index newvalue

練習(xí)

1、查看所有的鍵# keys * 2、向列表 spider:urls 中以RPUSH放入如下幾個元素:01_baidu.com、02_taobao.com、03_sina.com、04_jd.com、05_xxx.com# RPUSH spider:urls 01_xxx 02_xxx 03_xxx 3、查看列表中所有元素# LRANGE spider:urls 0 -1 4、查看列表長度# LLEN spider:urls 5、將列表中01_baidu.com 改為 01_tmall.com# LSET spider:urls 0 01_tmall.com 6、在列表中04_jd.com之后再加1個元素 02_taobao.com# LINSERT spider:urls after 04_jd.com 02_taobao.com 7、彈出列表中的最后一個元素# RPOP spider:urls 8、刪除列表中所有的 02_taobao.com# LREM spider:urls 0 02_taobao.com 9、剔除列表中的其他元素,只剩前3# LTRIM spider:urls 0 2

Hash散列數(shù)據(jù)類型

  • 定義
1、由field和關(guān)聯(lián)的value組成的鍵值對 2、field和value是字符串類型 3、一個hash中最多包含2^32-1個鍵值對 字符串類型
usernamelya
age25
genderF
score100
hobbyrap
哈希適合存儲對象類型的數(shù)據(jù)
keyfiledvalue
nameLucy
age18
usernamegenderF
score100
hobbyrap
  • 優(yōu)點(diǎn)
1、節(jié)約內(nèi)存空間 2、每創(chuàng)建一個鍵,它都會為這個鍵儲存一些附加的管理信息(比如這個鍵的類型,這個鍵最后一次被訪問的時間等) 3、鍵越多,redis數(shù)據(jù)庫在儲存附件管理信息方面耗費(fèi)內(nèi)存越多,花在管理數(shù)據(jù)庫鍵上的CPU也會越多
  • 缺點(diǎn)(不適合hash情況)
1、使用二進(jìn)制位操作命令:SETBIT、GETBIT、BITCOUNT等,如果想使用這些操作,只能用字符串鍵 2、使用過期鍵功能:鍵過期功能只能對鍵進(jìn)行過期操作,而不能對散列的字段進(jìn)行過期操作
  • 基本命令操作
# 1、設(shè)置單個字段 HSET key field value HSETNX key field value # 2、設(shè)置多個字段 HMSET key field value field value # 3、返回字段個數(shù) HLEN key # 4、判斷字段是否存在(不存在返回0) HEXISTS key field # 5、返回字段值 HGET key field # 6、返回多個字段值 HMGET key field filed # 7、返回所有的鍵值對 HGETALL key # 8、返回所有字段名 HKEYS key # 9、返回所有值 HVALS key # 10、刪除指定字段 HDEL key field # 11、在字段對應(yīng)值上進(jìn)行整數(shù)增量運(yùn)算 HINCRBY key filed increment # 12、在字段對應(yīng)值上進(jìn)行浮點(diǎn)數(shù)增量運(yùn)算 HINCRBYFLOAT key field increment

Hash與python交互

# 1、更新一條數(shù)據(jù)的屬性,沒有則新建 hset(name, key, value) # 2、讀取這條數(shù)據(jù)的指定屬性, 返回字符串類型 hget(name, key) # 3、批量更新數(shù)據(jù)(沒有則新建)屬性,參數(shù)為字典 hmset(name, mapping) # 4、批量讀取數(shù)據(jù)(沒有則新建)屬性 hmget(name, keys) # 5、獲取這條數(shù)據(jù)的所有屬性和對應(yīng)的值,返回字典類型 hgetall(name) # 6、獲取這條數(shù)據(jù)的所有屬性名,返回列表類型 hkeys(name) # 7、刪除這條數(shù)據(jù)的指定屬性 hdel(name, *keys)

Python代碼hash散列

'''設(shè)置1個字段,更改1個字段,設(shè)置多個字段,獲取相關(guān)信息''' import redisr = redis.Redis(host='127.0.0.1',port=6379,db=0) # 設(shè)置 r.hset('user1','name','bujingyun') # 更新 r.hset('user1','name','kongci') # 取數(shù)據(jù) print(r.hget('user1','name')) # 一次設(shè)置多個field和value user_dict = {'password':'123456','gender':'F','height':'165' } r.hmset('user1',user_dict) # 獲取所有數(shù)據(jù),字典 print(r.hgetall('user1'))# 獲取所有fields和所有values print(r.hkeys('user1')) print(r.hvals('user1'))

應(yīng)用場景:微博好友關(guān)注

1、用戶ID為key,Field為好友ID,Value為關(guān)注時間key field valueuser:10000 user:606 20190520user:605 20190521 2、用戶維度統(tǒng)計(jì)統(tǒng)計(jì)數(shù)包括:關(guān)注數(shù)、粉絲數(shù)、喜歡商品數(shù)、發(fā)帖數(shù)用戶為key,不同維度為field,value為統(tǒng)計(jì)數(shù)比如關(guān)注了5人HSET user:10000 fans 5HINCRBY user:10000 fans 1

應(yīng)用場景: redis+mysql+hash組合使用

  • 原理

    用戶想要查詢個人信息 1、到redis緩存中查詢個人信息 2、redis中查詢不到,到mysql查詢,并緩存到redis 3、再次查詢個人信息
  • 代碼實(shí)現(xiàn)

    import redis import pymysql# 1. 先到redis中查詢 # 2. redis中沒有,到mysql查詢,緩存到redis(設(shè)置過期時間) # 3. 再查詢1次 r = redis.Redis(host='192.168.153.148',port=6379,db=0) username = input('請輸入用戶名:')result = r.hgetall(username) if result:print(result) else:# redis中沒有緩存,需要到mysql中查詢db = pymysql.connect(host='192.168.153.148',user='tiger',password='123456',database='userdb',charset='utf8')cursor = db.cursor()sele = 'select age,gender from user where username=%s'cursor.execute(sele,[username])# userinfo: (('guoxiaonao',36,'M'),)userinfo = cursor.fetchall()if not userinfo:print('用戶不存在')else:# 打印輸出print('mysql',userinfo)# 緩存到redisuser_dict = {'age':userinfo[0][0],'gender':userinfo[0][1]}r.hmset(username,user_dict)# 設(shè)置過期時間r.expire(username,30)

mysql數(shù)據(jù)庫中數(shù)據(jù)更新信息后同步到redis緩存

用戶修改個人信息時,要將數(shù)據(jù)同步到redis緩存

import redis import pymysqlclass Update(object):def __init__(self):self.db = pymysql.connect('127.0.0.1', 'root', '123456','userdb', charset='utf8')self.cursor = self.db.cursor()self.r = redis.Redis(host='127.0.0.1', port=6379, db=0)# 更新mysql表記錄def update_mysql(self,score,username):upd = 'update user set score=%s where name=%s'try:self.cursor.execute(upd,[score,username])self.db.commit()return Trueexcept Exception as e:self.db.rollback()print('Failed',e)# 同步到redis數(shù)據(jù)庫def update_redis(self,username,score):result = self.r.hgetall(username)# 存在,更新score字段的值# 不存在,緩存整個用戶信息if result:self.r.hset(username,'score',score)else:# 到mysql中查詢最新數(shù)據(jù),緩存到redis中self.select_mysql(username)#def select_mysql(self,username):sel = 'select age,gender,score from user where name=%s'self.cursor.execute(sel,[username])result = self.cursor.fetchall()# 緩存到redis數(shù)據(jù)庫user_dict = {'age' : result[0][0],'gender' : result[0][1],'score' : result[0][2]}self.r.hmset(username,user_dict)self.r.expire(username,60)def main(self):username = input('請輸入用戶名:')new_score = input('請輸入新成績:')if self.update_mysql(new_score,username):self.update_redis(username,new_score)else:print('更改信息失敗')if __name__ == '__main__':syn = Update()syn.main()

集合數(shù)據(jù)類型(set)

  • 特點(diǎn)
1、無序、去重 2、元素是字符串類型 3、最多包含2^32-1個元素
  • 基本命令
# 1、增加一個或者多個元素,自動去重 SADD key member1 member2 # 2、查看集合中所有元素 SMEMBERS key # 3、刪除一個或者多個元素,元素不存在自動忽略 SREM key member1 member2 # 4、元素是否存在 SISMEMBER key member # 5、隨機(jī)返回集合中指定個數(shù)的元素,默認(rèn)為1個 SRANDMEMBER key [count] # 6、彈出成員 SPOP key [count] # 7、返回集合中元素的個數(shù),不會遍歷整個集合,只是存儲在鍵當(dāng)中了 SCARD key # 8、把元素從源集合移動到目標(biāo)集合 SMOVE source destination member# 9、差集(number1 1 2 3 number2 1 2 4 結(jié)果為3) SDIFF key1 key2 # 10、差集保存到另一個集合中 SDIFFSTORE destination key1 key2# 11、交集 SINTER key1 key2 SINTERSTORE destination key1 key2# 11、并集 SUNION key1 key2 SUNIONSTORE destination key1 key2

案例: 新浪微博的共同關(guān)注

# 需求: 當(dāng)用戶訪問另一個用戶的時候,會顯示出兩個用戶共同關(guān)注過哪些相同的用戶 # 設(shè)計(jì): 將每個用戶關(guān)注的用戶放在集合中,求交集即可 # 實(shí)現(xiàn):user001 = {'peiqi','qiaozhi','danni'}user002 = {'peiqi','qiaozhi','lingyang'}user001和user002的共同關(guān)注為:SINTER user001 user002結(jié)果為: {'peiqi','qiaozhi'}

python操作set

# 1、給name對應(yīng)的集合中添加元素 sadd(name,values) r.sadd("set_name","tom") r.sadd("set_name","tom","jim")# 2、獲取name對應(yīng)的集合的所有成員: python集合 smembers(name) r.smembers('set_name')# 3、獲取name對應(yīng)的集合中的元素個數(shù) scard(name) r.scard("set_name")# 4、檢查value是否是name對應(yīng)的集合內(nèi)的元素:True|False sismember(name, value) r.sismember('set_name','tom')# 5、隨機(jī)刪除并返回指定集合的一個元素 spop(name) member = r.spop('set_name')# 6、刪除集合中的某個元素 srem(name, value) r.srem("set_name", "tom")# 7、獲取多個name對應(yīng)集合的交集 sinter(keys, *args)r.sadd("set_name","a","b") r.sadd("set_name1","b","c") r.sadd("set_name2","b","c","d")print(r.sinter("set_name","set_name1","set_name2")) #輸出:{b'b'}# 8、獲取多個name對應(yīng)的集合的并集: python集合 sunion(keys, *args) r.sunion("set_name","set_name1","set_name2")

python代碼實(shí)現(xiàn)微博關(guān)注

import redisr = redis.Redis(host='127.0.0.1',port=6379,db=0)# user1關(guān)注的人 r.sadd('user1:focus','peiqi','qiaozhi','danni') # user2關(guān)注的人 r.sadd('user2:focus','peiqi','qiaozhi','lingyang') # 共同關(guān)注: 求交集 {b'qiaozhi', b'peiqi'} focus_set = r.sinter('user1:focus','user2:focus')# 創(chuàng)建空集合,存放最終結(jié)果 result = set()for focus in focus_set:result.add(focus.decode())print(result)

有序集合sortedset

  • 特點(diǎn)
1、有序、去重 2、元素是字符串類型 3、每個元素都關(guān)聯(lián)著一個浮點(diǎn)數(shù)分值(score),并按照分值從小到大的順序排列集合中的元素(分值可以相同) 4、最多包含2^32-1元素
  • 示例

    一個保存了水果價(jià)格的有序集合

分值2.04.06.08.010.0
元素西瓜葡萄芒果香蕉蘋果

? 一個保存了員工薪水的有序集合

分值600080001000012000
元素lucytomjimjack

? 一個保存了正在閱讀某些技術(shù)書的人數(shù)

分值300400555666777
元素核心編程阿凡提本拉登阿姆斯特朗比爾蓋茨
  • 有序集合常用命令
# 在有序集合中添加一個成員 zadd key score member # 查看指定區(qū)間元素(升序) zrange key start stop [withscores] # 查看指定區(qū)間元素(降序) ZREVRANGE key start stop [withscores] # 查看指定元素的分值 ZSCORE key member# 返回指定區(qū)間元素 # offset : 跳過多少個元素 # count : 返回幾個 # 小括號 : 開區(qū)間 zrangebyscore fruits (2.0 8.0 zrangebyscore key min max [withscores] [limit offset count] # 每頁顯示10個成員,顯示第5頁的成員信息: # limit 40 10 # MySQL: 每頁顯示10條記錄,顯示第5頁的記錄 # limit 40,10 # limit 2,3 顯示: 第3 4 5條記錄# 刪除成員 zrem key member # 增加或者減少分值 zincrby key increment member # 返回元素排名 zrank key member # 返回元素逆序排名 zrevrank key member # 刪除指定區(qū)間內(nèi)的元素 zremrangebyscore key min max # 返回集合中元素個數(shù) zcard key # 返回指定范圍中元素的個數(shù) zcount key min max zcount salary 6000 8000 zcount salary (6000 8000# 6000<salary<=8000 zcount salary (6000 (8000#6000<salary<8000 # 并集 zunionstore destination numkeys key [weights 權(quán)重值] [AGGREGATE SUM|MIN|MAX] # zunionstore salary3 2 salary salary2 weights 1 0.5 AGGREGATE MAX # 2代表集合數(shù)量,weights之后 權(quán)重1給salary,權(quán)重0.5給salary2集合,算完權(quán)重之后執(zhí)行聚合AGGREGATE# 交集:和并集類似,只取相同的元素 ZINTERSTORE destination numkeys key1 key2 ZINTERSTORE destination numkeys key1 key2 WEIGHTS weight AGGREGATE SUM(默認(rèn))|MIN|MAX

python操作sorted set

import redisr = redis.Redis(host='127.0.0.1',port=6379,db=0) # 注意第二個參數(shù)為字典 # 命令行:ZADD salary 6000 tom 8000 jim r.zadd('salary',{'tom':6000,'jim':8000,'jack':12000}) # 結(jié)果為列表中存放元組[(),(),()] print(r.zrange('salary',0,-1,withscores=True)) print(r.zrevrange('salary',0,-1,withscores=True)) # start:起始值,num:顯示條數(shù) print(r.zrangebyscore('salary',6000,12000,start=1,num=2,withscores=True)) # 刪除 r.zrem('salary','tom') print(r.zrange('salary',0,-1,withscores=True)) # 增加分值 r.zincrby('salary',5000,'jack') print(r.zrange('salary',0,-1,withscores=True)) # 返回元素排名 print(r.zrank('salary','jack')) print(r.zrevrank('salary','jack')) # 刪除指定區(qū)間內(nèi)的元素 r.zremrangebyscore('salary',6000,8000) print(r.zrange('salary',0,-1,withscores=True)) # 統(tǒng)計(jì)元素個數(shù) print(r.zcard('salary')) # 返回指定范圍內(nèi)元素個數(shù) print(r.zcount('salary',6000,20000)) # 并集 r.zadd('salary2',{'jack':17000,'lucy':8000}) r.zunionstore('salary3',('salary','salary2'),aggregate='max') print(r.zrange('salary3',0,-1,withscores=True)) # 交集 r.zinterstore('salary4',('salary','salary2'),aggregate='max') print(r.zrange('salary4',0,-1,withscores=True))

案例1:網(wǎng)易音樂排行榜

1、每首歌的歌名作為元素 2、每首歌的播放次數(shù)作為分值 3、使用ZREVRANGE來獲取播放次數(shù)最多的歌曲

代碼實(shí)現(xiàn)

import redisr = redis.Redis(host='127.0.0.1',port=6379,db=0)# 有序集合中添加了8首歌曲 r.zadd('ranking',{'song1':1,'song2':1,'song3':1,'song4':1}) r.zadd('ranking',{'song5':1,'song6':1,'song7':1,'song8':1}) # 指定成員增加分值 r.zincrby('ranking',50,'song3') r.zincrby('ranking',60,'song4') r.zincrby('ranking',70,'song8') # 獲取前3名: [('song8',71),(),()] rlist = r.zrevrange('ranking',0,2,withscores=True)i = 1 for name in rlist:print('第{}名:{} 播放次數(shù):{}'.format(i,name[0].decode(),int(name[1])))i += 1# 第1名:song8 播放次數(shù):71# 第2名:song4 播放次數(shù):61# 第3名:song3 播放次數(shù):51

案例2: 京東商品暢銷榜

# 第1天 ZADD mobile-001 5000 'huawei' 4000 'oppo' 3000 'iphone' # 第2天 ZADD mobile-002 5200 'huawei' 4300 'oppo' 3230 'iphone' # 第3天 ZADD mobile-003 5500 'huawei' 4660 'oppo' 3580 'iphone' 問題:如何獲取三款手機(jī)的銷量排名? ZUNIONSTORE mobile-001:003 mobile-001 mobile-002 mobile-003 # 可否? # 正確 方法1: ZRANGE mobile-003 0 -1 WITHSCORES 方法2: ZUNIONSTORE mobile-001:003 3 mobile-001 mobile-002 mobile-003 AGGREGATE MAX

python代碼實(shí)現(xiàn)

import redisr = redis.Redis(host='127.0.0.1',port=6379,db=0)day01_dict = {'huawei':5000,'oppo':4000,'iphone':3000 } day02_dict = {'huawei':5200,'oppo':4300,'iphone':3230 } day03_dict = {'huawei':5500,'oppo':4400,'iphone':3600 }r.zadd('mobile-001',day01_dict) r.zadd('mobile-002',day02_dict) r.zadd('mobile-003',day03_dict)# 并集,第二個參數(shù)為元組 r.zunionstore('mobile-001:003',('mobile-001','mobile-002','mobile-003'),aggregate='max' ) # 逆序:[(),(),()] rlist = r.zrevrange('mobile-001:003',0,2,withscores=True)for r in rlist:print('{}-{}'.format(r[0].decode(),int(r[1])))

五大數(shù)據(jù)類型及應(yīng)用場景

類型特點(diǎn)使用場景
string簡單key-value類型,value可為字符串和數(shù)字常規(guī)計(jì)數(shù)(微博數(shù), 粉絲數(shù)等功能)
hash是一個string類型的field和value的映射表,hash特別適合用于存儲對象存儲部分可能需要變更的數(shù)據(jù)(比如用戶信息)
list有序可重復(fù)列表關(guān)注列表,粉絲列表,消息隊(duì)列等
set無序不可重復(fù)列表存儲并計(jì)算關(guān)系(如微博,關(guān)注人或粉絲存放在集合,可通過交集、并集、差集等操作實(shí)現(xiàn)如共同關(guān)注、共同喜好等功能)
sorted set每個元素帶有分值的集合各種排行榜
#增 SET MSET LPUSH RPUSH HSET HMSET SADD ZADD #刪 LPOP RPOP BLPOP BRPOP LREM LTRIM HDEL SPOP SRANDMEMBER SREM ZREM ZREMRANGEBYSCORE #改 STRRANGE KEY OFFSET VALUE LSET KEY INDEX VALUE HSET LEY FIELD VALUE #查 MGET GET STRLEN GETRANGE LRANGE LLEN HGET GMGET HGETALL HKEYS HVALS HLEN SETMEMBERS SCARD ZRANGE ZREVRANGE ZSCORE KEY MEMBER ZCARD

數(shù)據(jù)持久化

持久化定義

將數(shù)據(jù)從掉電易失的內(nèi)存放到永久存儲的設(shè)備上

為什么需要持久化

因?yàn)樗械臄?shù)據(jù)都在內(nèi)存上,所以必須得持久化
  • 數(shù)據(jù)持久化分類之 - RDB模式(默認(rèn)開啟)

默認(rèn)模式

1、保存真實(shí)的數(shù)據(jù) 2、將服務(wù)器包含的所有數(shù)據(jù)庫數(shù)據(jù)以二進(jìn)制文件的形式保存到硬盤里面 3、默認(rèn)文件名 :/var/lib/redis/dump.rdb

創(chuàng)建rdb文件的兩種方式

**方式一:**服務(wù)器執(zhí)行客戶端發(fā)送的SAVE或者BGSAVE命令

127.0.0.1:6379> SAVE OK # 特點(diǎn) 1、執(zhí)行SAVE命令過程中,redis服務(wù)器將被阻塞,無法處理客戶端發(fā)送的命令請求,在SAVE命令執(zhí)行完畢后,服務(wù)器才會重新開始處理客戶端發(fā)送的命令請求 2、如果RDB文件已經(jīng)存在,那么服務(wù)器將自動使用新的RDB文件代替舊的RDB文件 # 工作中定時持久化保存一個文件127.0.0.1:6379> BGSAVE Background saving started # 執(zhí)行過程如下 1、客戶端 發(fā)送 BGSAVE 給服務(wù)器 2、服務(wù)器馬上返回 Background saving started 給客戶端 3、服務(wù)器 fork() 子進(jìn)程做這件事情 4、服務(wù)器繼續(xù)提供服務(wù) 5、子進(jìn)程創(chuàng)建完RDB文件后再告知Redis服務(wù)器# 配置文件相關(guān)操作 /etc/redis/redis.conf 263: dir /var/lib/redis # 表示rdb文件存放路徑 253: dbfilename dump.rdb # 文件名# 兩個命令比較 SAVE比BGSAVE快,因?yàn)樾枰獎?chuàng)建子進(jìn)程,消耗額外的內(nèi)存# 補(bǔ)充:可以通過查看日志文件來查看redis都做了哪些操作 # 日志文件:配置文件中搜索 logfile logfile /var/log/redis/redis-server.log

方式二:設(shè)置配置文件條件滿足時自動保存(使用最多)

# 命令行示例 redis>save 300 10表示如果距離上一次創(chuàng)建RDB文件已經(jīng)過去了300秒,并且服務(wù)器的所有數(shù)據(jù)庫總共已經(jīng)發(fā)生了不少于10次修改,那么自動執(zhí)行BGSAVE命令 redis>save 60 10000表示如果距離上一次創(chuàng)建rdb文件已經(jīng)過去60秒,并且服務(wù)器所有數(shù)據(jù)庫總共已經(jīng)發(fā)生了不少于10000次修改,那么執(zhí)行bgsave命令# redis配置文件默認(rèn) 218: save 900 1 219: save 300 10 220: save 60 100001、只要三個條件中的任意一個被滿足時,服務(wù)器就會自動執(zhí)行BGSAVE2、每次創(chuàng)建RDB文件之后,服務(wù)器為實(shí)現(xiàn)自動持久化而設(shè)置的時間計(jì)數(shù)器和次數(shù)計(jì)數(shù)器就會被清零,并重新開始計(jì)數(shù),所以多個保存條件的效果不會疊加
  • 數(shù)據(jù)持久化分類之 - AOF(AppendOnlyFile,默認(rèn)未開啟)

特點(diǎn)

1、存儲的是命令,而不是真實(shí)數(shù)據(jù) 2、默認(rèn)不開啟 # 開啟方式(修改配置文件) 1/etc/redis/redis.conf672: appendonly yes # 把 no 改為 yes676: appendfilename "appendonly.aof" 2、重啟服務(wù)sudo /etc/init.d/redis-server restart

RDB缺點(diǎn)

1、創(chuàng)建RDB文件需要將服務(wù)器所有的數(shù)據(jù)庫的數(shù)據(jù)都保存起來,這是一個非常消耗資源和時間的操作,所以服務(wù)器需要隔一段時間才創(chuàng)建一個新的RDB文件,也就是說,創(chuàng)建RDB文件不能執(zhí)行的過于頻繁,否則會嚴(yán)重影響服務(wù)器的性能 2、可能丟失數(shù)據(jù)

AOF持久化原理及優(yōu)點(diǎn)

# 原理1、每當(dāng)有修改數(shù)據(jù)庫的命令被執(zhí)行時,服務(wù)器就會將執(zhí)行的命令寫入到AOF文件的末尾2、因?yàn)锳OF文件里面存儲了服務(wù)器執(zhí)行過的所有數(shù)據(jù)庫修改的命令,所以給定一個AOF文件,服務(wù)器只要重新執(zhí)行一遍AOF文件里面包含的所有命令,就可以達(dá)到還原數(shù)據(jù)庫的目的# 優(yōu)點(diǎn)用戶可以根據(jù)自己的需要對AOF持久化進(jìn)行調(diào)整,讓Redis在遭遇意外停機(jī)時不丟失任何數(shù)據(jù),或者只丟失一秒鐘的數(shù)據(jù),這比RDB持久化丟失的數(shù)據(jù)要少的多

安全性問題考慮

# 因?yàn)?/span>雖然服務(wù)器執(zhí)行一個修改數(shù)據(jù)庫的命令,就會把執(zhí)行的命令寫入到AOF文件,但這并不意味著AOF文件持久化不會丟失任何數(shù)據(jù),在目前常見的操作系統(tǒng)中,執(zhí)行系統(tǒng)調(diào)用write函數(shù),將一些內(nèi)容寫入到某個文件里面時,為了提高效率,系統(tǒng)通常不會直接將內(nèi)容寫入硬盤里面,而是將內(nèi)容放入一個內(nèi)存緩存區(qū)(buffer)里面,等到緩沖區(qū)被填滿時才將存儲在緩沖區(qū)里面的內(nèi)容真正寫入到硬盤里# 所以1、AOF持久化:當(dāng)一條命令真正的被寫入到硬盤里面時,這條命令才不會因?yàn)橥C(jī)而意外丟失2、AOF持久化在遭遇停機(jī)時丟失命令的數(shù)量,取決于命令被寫入到硬盤的時間3、越早將命令寫入到硬盤,發(fā)生意外停機(jī)時丟失的數(shù)據(jù)就越少,反之亦然

策略 - 配置文件

# 打開配置文件:/etc/redis/redis.conf,找到相關(guān)策略如下 1701: alwarys服務(wù)器每寫入一條命令,就將緩沖區(qū)里面的命令寫入到硬盤里面,服務(wù)器就算意外停機(jī),也不會丟失任何已經(jīng)成功執(zhí)行的命令數(shù)據(jù) 2702: everysec(# 默認(rèn))服務(wù)器每一秒將緩沖區(qū)里面的命令寫入到硬盤里面,這種模式下,服務(wù)器即使遭遇意外停機(jī),最多只丟失1秒的數(shù)據(jù) 3703: no服務(wù)器不主動將命令寫入硬盤,由操作系統(tǒng)決定何時將緩沖區(qū)里面的命令寫入到硬盤里面,丟失命令數(shù)量不確定# 運(yùn)行速度比較 always:速度慢 everysec和no都很快,默認(rèn)值為everysec

AOF文件中是否會產(chǎn)生很多的冗余命令?

為了讓AOF文件的大小控制在合理范圍,避免胡亂增長,redis提供了AOF重寫功能,通過這個功能,服務(wù)器可以產(chǎn)生一個新的AOF文件-- 新的AOF文件記錄的數(shù)據(jù)庫數(shù)據(jù)和原由的AOF文件記錄的數(shù)據(jù)庫數(shù)據(jù)完全一樣-- 新的AOF文件會使用盡可能少的命令來記錄數(shù)據(jù)庫數(shù)據(jù),因此新的AOF文件的提及通常會小很多-- AOF重寫期間,服務(wù)器不會被阻塞,可以正常處理客戶端發(fā)送的命令請求

示例

原有AOF文件重寫后的AOF文件
select 0SELECT 0
sadd myset peiqiSADD myset peiqi qiaozhi danni lingyang
sadd myset qiaozhiSET msg ‘hello tarena’
sadd myset danniRPUSH mylist 2 3 5
sadd myset lingyang
INCR number
INCR number
DEL number
SET message ‘hello world’
SET message ‘hello tarena’
RPUSH mylist 1 2 3
RPUSH mylist 5
LPOP mylist

AOF文件重寫方法觸發(fā)

1、客戶端向服務(wù)器發(fā)送BGREWRITEAOF命令127.0.0.1:6379> BGREWRITEAOFBackground append only file rewriting started2、修改配置文件讓服務(wù)器自動執(zhí)行BGREWRITEAOF命令auto-aof-rewrite-percentage 100auto-aof-rewrite-min-size 64mb# 解釋1、只有當(dāng)AOF文件的增量大于100%時才進(jìn)行重寫,也就是大一倍的時候才觸發(fā)# 第一次重寫新增:64M# 第二次重寫新增:128M# 第三次重寫新增:256M(新增128M)

RDB和AOF持久化對比

RDB持久化AOF持久化
全量備份,一次保存整個數(shù)據(jù)庫增量備份,一次保存一個修改數(shù)據(jù)庫的命令
保存的間隔較長保存的間隔默認(rèn)為一秒鐘
數(shù)據(jù)還原速度快數(shù)據(jù)還原速度一般,冗余命令多,還原速度慢
執(zhí)行SAVE命令時會阻塞服務(wù)器,但手動或者自動觸發(fā)的BGSAVE不會阻塞服務(wù)器無論是平時還是進(jìn)行AOF重寫時,都不會阻塞服務(wù)器

數(shù)據(jù)恢復(fù)(無需手動操作)

既有dump.rdb,又有appendonly.aof,恢復(fù)時找誰? 先找appendonly.aof

配置文件常用配置總結(jié)

# 設(shè)置密碼 1、requirepass password # 開啟遠(yuǎn)程連接 2、bind 127.0.0.1 ::1 注釋掉 3、protected-mode no 把默認(rèn)的 yes 改為 no # rdb持久化-默認(rèn)配置 4、dbfilename 'dump.rdb' 5dir /var/lib/redis # rdb持久化-自動觸發(fā)(條件) 6、save 900 1 7、save 300 10 8、save 60 10000 # aof持久化開啟 9、appendonly yes 10、appendfilename 'appendonly.aof' # aof持久化策略 11、appendfsync always 12、appendfsync everysec # 默認(rèn) 13、appendfsync no # aof重寫觸發(fā) 14、auto-aof-rewrite-percentage 100 15、auto-aof-rewrite-min-size 64mb # 設(shè)置為從服務(wù)器 16、salveof <master-ip> <master-port>

Redis相關(guān)文件存放路徑

1、配置文件: /etc/redis/redis.conf 2、備份文件: /var/lib/redis/*.rdb|*.aof 3、日志文件: /var/log/redis/redis-server.log 4、啟動文件: /etc/init.d/redis-server # /etc/下存放配置文件 # /etc/init.d/下存放服務(wù)啟動文件

Redis主從復(fù)制

  • 定義
1、一個Redis服務(wù)可以有多個該服務(wù)的復(fù)制品,這個Redis服務(wù)成為master,其他復(fù)制品成為slaves 2、master會一直將自己的數(shù)據(jù)更新同步給slaves,保持主從同步 3、只有master可以執(zhí)行寫命令,slave只能執(zhí)行讀命令
  • 作用
分擔(dān)了讀的壓力(高并發(fā))
  • 原理
從服務(wù)器執(zhí)行客戶端發(fā)送的讀命令,比如GET、LRANGE、SMEMMBERS、HGET、ZRANGE等等,客戶端可以連接slaves執(zhí)行讀請求,來降低master的讀壓力
  • 兩種實(shí)現(xiàn)方式

    方式一(Linux命令行實(shí)現(xiàn)1)

    redis-server --slaveof

# 從服務(wù)端 redis-server --port 6300 --slaveof 127.0.0.1 6379 # 從客戶端 redis-cli -p 6300 127.0.0.1:6300> keys * # 發(fā)現(xiàn)是復(fù)制了原6379端口的redis中數(shù)據(jù) 127.0.0.1:6300> set mykey 123 (error) READONLY You can't write against a read only slave. 127.0.0.1:6300> # 從服務(wù)器只能讀數(shù)據(jù),不能寫數(shù)據(jù)

方式一(Redis命令行實(shí)現(xiàn)2)

# 兩條命令 1>slaveof IP PORT 2>slaveof no one

示例

# 服務(wù)端啟動 redis-server --port 6301 # 客戶端連接 tarena@tedu:~$ redis-cli -p 6301 127.0.0.1:6301> keys * 1) "myset" 2) "mylist" 127.0.0.1:6301> set mykey 123 OK # 切換為從 127.0.0.1:6301> slaveof 127.0.0.1 6379 OK 127.0.0.1:6301> set newkey 456 (error) READONLY You can't write against a read only slave. 127.0.0.1:6301> keys * 1) "myset" 2) "mylist" # 再切換為主 127.0.0.1:6301> slaveof no one OK 127.0.0.1:6301> set name hello OK

方式二(修改配置文件)

# 每個redis服務(wù),都有1個和他對應(yīng)的配置文件 # 兩個redis服務(wù)16379 -> /etc/redis/redis.conf26300 -> /home/tarena/redis_6300.conf# 修改配置文件 vi redis_6300.conf slaveof 127.0.0.1 6379 port 6300 # 啟動redis服務(wù) redis-server redis_6300.conf # 客戶端連接測試 redis-cli -p 6300 127.0.0.1:6300> hset user:1 username guods (error) READONLY You can't write against a read only slave.

問題總結(jié):master掛了怎么辦?

1、一個Master可以有多個Slaves 2、Slave下線,只是讀請求的處理性能下降 3、Master下線,寫請求無法執(zhí)行 4、其中一臺Slave使用SLAVEOF no one命令成為Master,其他Slaves執(zhí)行SLAVEOF命令指向這個新的Master,從它這里同步數(shù)據(jù) # 以上過程是手動的,能夠?qū)崿F(xiàn)自動,這就需要Sentinel哨兵,實(shí)現(xiàn)故障轉(zhuǎn)移Failover操作

演示

1、啟動端口6400redis,設(shè)置為6379的slaveredis-server --port 6400redis-cli -p 6400redis>slaveof 127.0.0.1 6379 2、啟動端口6401redis,設(shè)置為6379的slaveredis-server --port 6401redis-cli -p 6401redis>slaveof 127.0.0.1 6379 3、關(guān)閉6379redissudo /etc/init.d/redis-server stop 4、把6400redis設(shè)置為masterredis-cli -p 6401redis>slaveof no one 5、把6401的redis設(shè)置為6400redis的salveredis-cli -p 6401redis>slaveof 127.0.0.1 6400 # 這是手動操作,效率低,而且需要時間,有沒有自動的???

官方高可用方案Sentinel

Redis之哨兵 - sentinel

1、Sentinel會不斷檢查Master和Slaves是否正常 2、每一個Sentinel可以監(jiān)控任意多個Master和該Master下的Slaves

案例演示

? **1、**環(huán)境搭建

# 共3臺redis的服務(wù)器,如果是不同機(jī)器端口號可以是一樣的 1、啟動6379的redis服務(wù)器sudo /etc/init.d/redis-server start 2、啟動6380的redis服務(wù)器,設(shè)置為6379的從redis-server --port 6380tarena@tedu:~$ redis-cli -p 6380127.0.0.1:6380> slaveof 127.0.0.1 6379OK 3、啟動6381的redis服務(wù)器,設(shè)置為6379的從redis-server --port 6381tarena@tedu:~$ redis-cli -p 6381127.0.0.1:6381> slaveof 127.0.0.1 6379

? **2、**安裝并搭建sentinel哨兵

# 1、安裝redis-sentinel sudo apt install redis-sentinel 驗(yàn)證: sudo /etc/init.d/redis-sentinel stop # 2、新建配置文件sentinel.conf port 26379 Sentinel monitor tedu 127.0.0.1 6379 1# 3、啟動sentinel 方式一: redis-sentinel sentinel.conf 方式二: redis-server sentinel.conf --sentinel#4、將master的redis服務(wù)終止,查看從是否會提升為主 sudo /etc/init.d/redis-server stop # 發(fā)現(xiàn)提升6381為master,其他兩個為從 # 在6381上設(shè)置新值,6380查看 127.0.0.1:6381> set name tedu OK# 啟動6379,觀察日志,發(fā)現(xiàn)變?yōu)榱?381的從 主從+哨兵基本就夠用了

sentinel.conf解釋

# sentinel監(jiān)聽端口,默認(rèn)是26379,可以修改 port 26379 # 告訴sentinel去監(jiān)聽地址為ip:port的一個master,這里的master-name可以自定義,quorum是一個數(shù)字,指明當(dāng)有多少個sentinel認(rèn)為一個master失效時,master才算真正失效 sentinel monitor <master-name> <ip> <redis-port> <quorum>

生產(chǎn)環(huán)境中設(shè)置哨兵sentinel

1、安裝sentinelsudo apt-get install redis-sentinel 2、創(chuàng)建配置文件 sentinel.confport 26379Sentinel monitor 名字 IP PORT 投票數(shù) 3、啟動sentinel開始監(jiān)控redis-sentinel sentinel.conf

分布式鎖

高并發(fā)產(chǎn)生的問題?

1、購票: 多個用戶搶到同一張票? 2、購物: 庫存只剩1,被多個用戶成功買到? ... ...

怎么辦?

在不同進(jìn)程需要互斥地訪問共享資源時,分布式鎖是一種非常有用的技術(shù)手段

原理

1、多個客戶端先到redis數(shù)據(jù)庫中獲取一把鎖,得到鎖的用戶才可以操作數(shù)據(jù)庫 2、此用戶操作完成后釋放鎖,下一個成功獲取鎖的用戶再繼續(xù)操作數(shù)據(jù)庫

實(shí)現(xiàn)

set key value nx ex 3 # 見圖: 分布式鎖原理.png

博客項(xiàng)目解決高并發(fā)問題

1、在數(shù)據(jù)庫中創(chuàng)建庫 blog,指定字符編碼utf8

mysql -uroot -p123456 mysql>create database wiki charset utf8;

2、同步數(shù)據(jù)庫,并在user_profile中插入表記錄

1、python3 manage.py makemigrations 2、python3 manage.py migrate 3、insert into user_profile values ('guoxiaonao','guoxiaonao','guoxiaonao@tedu.cn','123456','aaaaaaaa','bbbbbbbb','cccccccc');

3、啟動django項(xiàng)目,并找到django路由測試 test函數(shù)

1、python3 manage.py runserver 2、查看項(xiàng)目的 urls.py 路由,打開firefox瀏覽器輸入地址:http://127.0.0.1:8000/test/ # 返回結(jié)果: {"code": 200}

4、在數(shù)據(jù)庫表中創(chuàng)建測試字段score

1、user/models.py添加:score = models.IntegerField(verbose_name=u'分?jǐn)?shù)',null=True,default=0) 2、同步到數(shù)據(jù)庫python3 manage.py makemigrations userpython3 manage.py migrate user 3、到數(shù)據(jù)庫中確認(rèn)查看

3、在wiki/views.py中補(bǔ)充 test函數(shù),對數(shù)據(jù)庫中score字段進(jìn)行 +1 操作

from user.models import UserProfile def test(request):u = UserProfile.objects.get(username='guoxiaonao')u.score += 1u.save()return JsonResponse('HI HI HI')

4、啟多個服務(wù)端,模擬30個并發(fā)請求

(1)多臺服務(wù)器啟動項(xiàng)目

python3 manage.py runserver 127.0.0.1:8000 python3 manage.py runserver 127.0.0.1:8001

(2)在tools中新建py文件 test_api.py,模擬30個并發(fā)請求

import threading import requests import randomdef getRequest():url='http://127.0.0.1:8000/test/'url2='http://127.0.0.1:8001/test/'get_url = random.choice([url, url2])requests.get(get_url)ts = [] for i in range(30):t=threading.Thread(target=getRequest,args=())ts.append(t)if __name__ == '__main__':for t in ts:t.start()for t in ts:t.join()

(3) python3 test_api.py

(4) 在數(shù)據(jù)庫中查看 score 字段的值

并沒有+30,而且沒有規(guī)律,每次加的次數(shù)都不同,如何解決???

解決方案:redis分布式鎖

def test(request):# 解決方法二:redis分布式鎖import redispool = redis.ConnectionPool(host='localhost', port=6379, db=0)r = redis.Redis(connection_pool=pool)while True:try:with r.lock('guoxiaonao', blocking_timeout=3) as lock:u = UserProfile.objects.get(username='guoxiaonao')u.score += 1u.save()breakexcept Exception as e:print('lock is failed')return JsonResponse({'code':200,'data':{}})

Redis事務(wù)

特點(diǎn)

1. 單獨(dú)的隔離操作:事務(wù)中的所有命令會被序列化、按順序執(zhí)行,在執(zhí)行的過程中不會被其他客戶端發(fā)送來的命令打斷 2. 不保證原子性:redis中的一個事務(wù)中如果存在命令執(zhí)行失敗,那么其他命令依然會被執(zhí)行,沒有回滾機(jī)制

事務(wù)命令

1、MULTI # 開啟事務(wù) 2、命令1 # 執(zhí)行命令 3、命令2 ... ... 4、EXEC # 提交到數(shù)據(jù)庫執(zhí)行 4、DISCARD # 取消事務(wù)

使用步驟

# 開啟事務(wù) 127.0.0.1:6379> MULTI OK # 命令1入隊(duì)列 127.0.0.1:6379> INCR n1 QUEUED # 命令2入隊(duì)列 127.0.0.1:6379> INCR n2 QUEUED # 提交到數(shù)據(jù)庫執(zhí)行 127.0.0.1:6379> EXEC 1) (integer) 1 2) (integer) 1

事務(wù)中命令錯誤處理

# 1、命令語法錯誤,命令入隊(duì)失敗,直接自動discard退出這個事務(wù)這個在命令在執(zhí)行調(diào)用之前會發(fā)生錯誤。例如,這個命令可能有語法錯誤(錯誤的參數(shù)數(shù)量,錯誤的命令名)處理方案:客戶端發(fā)生了第一個錯誤情況,在exec執(zhí)行之前發(fā)生的。通過檢查隊(duì)列命令返回值:如果這個命令回答這個隊(duì)列的命令是正確的,否者redis會返回一個錯誤。如果那里發(fā)生了一個隊(duì)列命令錯誤,大部分客戶端將會退出并丟棄這個事務(wù)# 2、命令語法沒錯,但類型操作有誤,則事務(wù)執(zhí)行調(diào)用之后失敗,無法進(jìn)行事務(wù)回滾從我們施行了一個由于錯誤的value的ke y操作(例如對著String類型的value施行了List命令操作)處理方案:發(fā)生在EXEC之后的是沒有特殊方式去處理的:即使某些命令在事務(wù)中失敗,所有的其他命令都將會被執(zhí)行。 127.0.0.1:6379> MULTI OK 127.0.0.1:6379> set num 10 QUEUED 127.0.0.1:6379> LPOP num QUEUED 127.0.0.1:6379> exec 1) OK 2) (error) WRONGTYPE Operation against a key holding the wrong kind of value 127.0.0.1:6379> get num "10" 127.0.0.1:6379>

為什么redis不支持事務(wù)回滾

  • 觀點(diǎn)
1、Redis的內(nèi)部極其簡單和快速,來源于它不需要回滾功能 2、在生產(chǎn)環(huán)境中,通常回滾并不能解決來自編程的錯誤。舉個例子,你本來想+1,卻+2了,又或者+在錯誤的類型上,回滾并不能解決。由于無法提供一個避免程序員自己的錯誤,而這種錯誤在產(chǎn)品中并不會出現(xiàn),所以選擇一個簡單和快速的方法去支持事務(wù)

pipeline補(bǔ)充

python使用pipeline()與execute()批量進(jìn)行批量操作

示例

import redis# 創(chuàng)建連接池并連接到redis pool = redis.ConnectionPool(host = '192.168.153.150',db=0,port=6379) r = redis.Redis(connection_pool=pool)# 第一組 pipe = r.pipeline() pipe.set('fans',50) pipe.incr('fans') pipe.incrby('fans',100) pipe.execute()# 第二組 pipe.get('fans') pipe.get('pwd') # [b'151', b'123'] result = pipe.execute() print(result)

Redis常見問題匯總

  • Redis優(yōu)點(diǎn)
1、讀寫速度快. 數(shù)據(jù)存放在內(nèi)存中 2、支持?jǐn)?shù)據(jù)類型豐富,string,hash,list,set,sorted 3、支持事務(wù) 4、可以用于緩存,消息隊(duì)列,按key設(shè)置過期時間,到期后自動刪除 5、支持?jǐn)?shù)據(jù)持久化(將內(nèi)存數(shù)據(jù)持久化到磁盤),支持AOF和RDB兩種持久化方式,從而進(jìn)行數(shù)據(jù)恢復(fù)操作,可以有效地防止數(shù)據(jù)丟失 5、支持主從(master-slave)復(fù)制來實(shí)現(xiàn)數(shù)據(jù)備份,主機(jī)會自動將數(shù)據(jù)同步到從機(jī)
  • 來介紹一下redis中的數(shù)據(jù)類型

    類型特點(diǎn)使用場景
    string簡單key-value類型,value可為字符串和數(shù)字常規(guī)計(jì)數(shù)(微博數(shù), 粉絲數(shù)等功能)
    hash是一個string類型的field和value的映射表,hash特別適合用于存儲對象存儲部分可能需要變更的數(shù)據(jù)(比如用戶信息)
    list有序可重復(fù)列表關(guān)注列表,粉絲列表,消息隊(duì)列等
    set無序不可重復(fù)列表存儲并計(jì)算關(guān)系(如微博,關(guān)注人或粉絲存放在集合,可通過交集、并集、差集等操作實(shí)現(xiàn)如共同關(guān)注、共同喜好等功能)
    sorted set每個元素帶有分值的集合各種排行榜
  • redis中的持久化方案

# RDB 快照形式,定期把內(nèi)存中的數(shù)據(jù)保存到磁盤。Redis默認(rèn)支持的持久化方案。速度快但是服務(wù)器斷電的時候會丟失部分?jǐn)?shù)據(jù)# AOF 把所有對redis數(shù)據(jù)庫增刪改操作的命令保存到文件中。數(shù)據(jù)庫恢復(fù)時把所有的命令執(zhí)行一遍即可。 # 兩種持久化方案同時開啟使用AOF文件來恢復(fù)數(shù)據(jù)庫.能保證數(shù)據(jù)的完整性,但是速度慢。
  • 使用過Redis分布式鎖么,它是什么回事?

    1、從redis2.8開始,set命令集成了兩個參數(shù),nx和ex,先拿nx來爭搶鎖,搶到之后,再用ex參數(shù)給鎖加一個過期時間防止鎖無法釋放,造成死鎖set username AAA nx ex 3 2、redis分布式鎖原理見圖
  • 緩存穿透

# 原理 緩存和數(shù)據(jù)庫都沒有的數(shù)據(jù),而用戶反復(fù)發(fā)起請求, 如 假的用戶ID# 場景 比如發(fā)起為id為“-1”的數(shù)據(jù)或id為特別大不存在的數(shù)據(jù)。這時的用戶很可能是攻擊者,攻擊會導(dǎo)致數(shù)據(jù)庫壓力過大# 解決方案:1、請求校驗(yàn),接口層增加校驗(yàn),如對id做基礎(chǔ)校驗(yàn),id<=0的直接攔截2、都無法取到數(shù)據(jù)時也可以將key-value對寫為key-null,緩存有效時間比如30秒左右,這樣可以防止攻擊用戶反復(fù)用同一個id暴力攻擊
  • 緩存擊穿

    # 原理 緩存沒有,數(shù)據(jù)庫有,一般是緩存時間到期, 順勢并發(fā)太大#解決方案 1、熱點(diǎn)數(shù)據(jù)不過期 2、上鎖: 重新設(shè)計(jì)緩存的使用方式,當(dāng)我們通過key去查詢數(shù)據(jù)時,首先查詢緩存,如果沒有,就通過分布式鎖進(jìn)行加鎖,取得鎖的進(jìn)程查DB并設(shè)置緩存,然后解鎖;其他進(jìn)程如果發(fā)現(xiàn)有鎖就等待,然后等解鎖后返回緩存數(shù)據(jù)或者再次查詢DB
  • 緩存雪崩

    # 原理 緩存中大批量數(shù)據(jù)過期,導(dǎo)致瞬時大批量不同請求注入DB# 解決方案 解決方案 1、緩存設(shè)置隨機(jī)時間(避免緩存設(shè)置相近的有效期;為有效期增加隨機(jī)值) 2、熱點(diǎn)數(shù)據(jù)不過期

總結(jié)

以上是生活随笔為你收集整理的学一点Redis基础的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。

国产免费作爱视频 | 日韩超碰| 天天色欧美 | 国产无遮挡猛进猛出免费软件 | 国产成人一区二区啪在线观看 | 中文字幕在线播放日韩 | 天天射射天天 | 欧美日韩中文在线观看 | 精品成人久久 | 日韩中文字幕免费看 | 久久av网| www.天天色| 日韩成年视频 | 日日爽天天 | 精品二区久久 | 日韩综合在线观看 | 久久成人综合视频 | 欧洲av不卡 | 亚洲欧洲中文日韩久久av乱码 | 亚洲在线视频观看 | 久久人人爽人人爽 | 国产精品成人自产拍在线观看 | 人人澡人人爱 | 99免费在线观看视频 | 中文字幕区 | 狠狠狠狠狠狠操 | 免费特级黄毛片 | av在线亚洲天堂 | 久久视频国产 | 久久久国产毛片 | 天天天综合| 国产精品每日更新 | 国产真实精品久久二三区 | 国产精品18久久久久久久久 | 亚洲精品中文在线资源 | 亚洲精品国产拍在线 | 又色又爽又激情的59视频 | 天天艹天天爽 | 九九一级片| 欧美一区在线看 | 99久久er热在这里只有精品15 | 久久久久日本精品一区二区三区 | 在线看成人片 | 国产亚洲精品久久久久久大师 | 在线观看你懂的网址 | 成人精品电影 | 日韩网站在线免费观看 | 波多野结衣日韩 | 美女视频是黄的免费观看 | 婷婷六月久久 | 美腿丝袜一区二区三区 | 欧美成人精品三级在线观看播放 | 九色porny真实丨国产18 | 国色天香av | 91在线精品一区二区 | 久久国产一区二区 | 操操日 | 91久久丝袜国产露脸动漫 | 国产欧美久久久精品影院 | 欧美一级视频免费 | 91精品国产三级a在线观看 | 免费高清影视 | 亚洲97在线 | 成人性生交视频 | 激情综合网五月婷婷 | 成人免费视频网 | 美女av免费| 中文字幕亚洲在线观看 | 欧美性久久久久久 | 麻豆国产网站 | 天天曰天天射 | 国产xvideos免费视频播放 | 777久久久| 日韩动态视频 | 国产美女精品久久久 | 在线观看一区二区视频 | 在线观看免费视频 | 香蕉在线视频播放网站 | 在线一区电影 | 在线视频app| 国产精品成人久久久久 | 精品在线免费视频 | 亚州精品视频 | www.久久色| 在线一区av | 国产激情免费 | 欧美日韩色婷婷 | 欧美日韩一级在线 | 国产高清一区二区 | 狠狠狠色丁香综合久久天下网 | 人人插人人爱 | 日韩在线观看视频中文字幕 | 永久精品视频 | 婷婷久月 | 中文字幕丰满人伦在线 | 人人爽人人爽人人片av | 天天操狠狠操夜夜操 | 日本精品视频在线 | 天天射天天艹 | 在线va视频 | 欧美一区二区在线免费观看 | 欧美另类高潮 | 天天鲁一鲁摸一摸爽一爽 | 久热国产视频 | 成人97视频一区二区 | 日韩欧美高清在线观看 | 亚洲一区精品二人人爽久久 | 91精品电影| 在线观看日韩免费视频 | 欧美国产一区在线 | 国产久视频| 在线观看日本高清mv视频 | 狠狠精品 | 三日本三级少妇三级99 | 国产三级午夜理伦三级 | 国产在线污 | 国产欧美日韩精品一区二区免费 | 免费av影视 | 欧美va天堂va视频va在线 | 国产精品精品久久久久久 | 国产精品video爽爽爽爽 | 国产亚洲小视频 | 婷婷六月天综合 | 欧美日韩亚洲一 | 久久精品国产精品亚洲精品 | 狠狠干夜夜操 | av在线观 | 91精品国产欧美一区二区成人 | 国内视频一区二区 | 一区二区激情视频 | 韩日av一区二区 | 18做爰免费视频网站 | 成人亚洲综合 | 操操操综合 | 久久久久久久网 | 在线av资源 | av在线短片| 欧美做受高潮1 | 国产美女视频一区 | 狠狠色综合网站久久久久久久 | 成人va天堂| 久产久精国产品 | 久久这里只有精品视频首页 | 香蕉视频一级 | 欧美三级在线播放 | 中文字幕欧美日韩va免费视频 | 日韩久久精品一区 | 午夜精品99久久免费 | 日日爽日日操 | 日韩成人免费在线电影 | 三级毛片视频 | 亚洲国产精品一区二区久久,亚洲午夜 | 亚洲丝袜一区二区 | www日韩在线| 精品亚洲午夜久久久久91 | 日韩中午字幕 | 一区中文字幕在线观看 | 国产精品一二三 | 天天射天天射 | 久久久久久久看片 | 国产精品一区二区免费看 | www.福利视频 | 国产亚洲欧美精品久久久久久 | 24小时日本在线www免费的 | 日韩精品一区二区三区水蜜桃 | 免费日韩一区 | 中文字幕日韩无 | 深夜福利视频在线观看 | 婷婷丁香激情 | 日韩av线观看 | 精品国偷自产国产一区 | 亚洲国产99 | 99在线免费观看 | 国产精品久久久久一区二区 | 久久五月天综合 | 国产99久久精品一区二区永久免费 | 在线免费观看国产 | 日韩中文字幕国产精品 | 日韩中文在线视频 | 免费成人黄色av | 丁香激情综合久久伊人久久 | 九九热在线观看视频 | 久操97| 欧美高清成人 | 日韩激情中文字幕 | av久久在线| 在线免费视频你懂的 | 日韩a在线播放 | 在线中文字幕av观看 | 天天爽天天碰狠狠添 | 天天爽人人爽夜夜爽 | 免费亚洲黄色 | 国产精品国产自产拍高清av | 国产成人精品一区二区三区网站观看 | 在线看岛国av| 精品人人人 | 久久久久这里只有精品 | 2022中文字幕在线观看 | 久久久久久国产精品美女 | 国产精品18久久久久久久久久久久 | 国产91影院| 97在线观看免费高清 | 美女视频黄是免费的 | 国产白浆视频 | 国产色在线视频 | 精品国产黄色片 | 久久伊99综合婷婷久久伊 | 中国一级片在线播放 | a视频在线看 | 一区二区三区在线观看免费视频 | 国产精品18毛片一区二区 | 黄色三级久久 | 香蕉视频最新网址 | 国产一级免费片 | 天堂在线一区 | 亚洲一级电影在线观看 | 免费看黄在线网站 | 国产精品一级视频 | 欧美日韩国产一区二区三区在线观看 | 亚洲精品xxxx| 欧美另类高清 | 最近中文字幕mv免费高清在线 | 国产精品九九久久99视频 | 亚洲经典中文字幕 | 天天干天天干 | 国产福利一区二区三区在线观看 | 国产精品久久久久久久久久99 | 日韩av一区二区在线影视 | 精品久久国产精品 | 精品女同一区二区三区在线观看 | 日韩中文字幕在线看 | 五月天久久 | 又黄又爽又色无遮挡免费 | 日韩中文字 | 免费三级影片 | 91精品播放| 中文在线字幕免费观看 | 97人人模人人爽人人喊网 | 狠狠躁日日躁 | 成人av免费在线播放 | 国产一级在线播放 | 午夜精品久久久久久久99婷婷 | 国产 欧美 日产久久 | 久久久久激情视频 | 伊人影院av| 在线视频亚洲 | 精品国产伦一区二区三区观看方式 | 在线91av| 日韩,精品电影 | 国产亚洲综合精品 | 欧美午夜精品久久久久 | 中中文字幕av | 国产精品久久久久久一区二区 | av在线电影免费观看 | 狠狠躁日日躁狂躁夜夜躁 | 最新av在线播放 | 精品国产自在精品国产精野外直播 | 91精品国产麻豆国产自产影视 | 日日夜操 | 欧美国产日韩一区二区 | 亚洲综合小说 | 91在线看片 | 日韩视频 一区 | www.亚洲| 日韩精品久久久久久中文字幕8 | 久久久精品日本 | 香蕉视频在线免费看 | 国产精品久久久久久久久久久久午夜片 | 亚洲成人家庭影院 | 亚洲欧美综合精品久久成人 | 在线视频 精品 | 怡红院av久久久久久久 | 一区二区三区日韩视频在线观看 | 国产999精品久久久影片官网 | 高清一区二区 | 在线观看一区二区精品 | 国产专区精品 | 亚洲高清网站 | 欧美日韩国产二区三区 | 黄色免费在线看 | 日韩欧美有码在线 | 99热免费在线| 久久伊人精品一区二区三区 | 99久久99久久免费精品蜜臀 | 欧美午夜理伦三级在线观看 | 在线观看免费一级片 | 色婷婷免费视频 | 成人影片在线播放 | 国产一级淫片在线观看 | 97干com| 亚洲成人家庭影院 | 精品久久久久久国产91 | 国产99久久久久 | 91成熟丰满女人少妇 | 久久久精品网站 | 精品麻豆入口免费 | 久久成人午夜视频 | 天天爱天天操天天爽 | 91精品在线播放 | 国产你懂的在线 | 97天堂网| 最近中文字幕大全中文字幕免费 | 在线看国产一区 | 日韩一级片大全 | 天天射天天干 | 黄色小说免费在线观看 | 欧美日韩在线观看一区二区三区 | av黄色免费在线观看 | 国产又粗又猛又黄又爽 | 国产免费久久久久 | 亚洲视频久久久久 | 天天色成人 | 久久97久久97精品免视看 | 亚洲精品资源 | 国产成人91 | 欧美精品一区二区在线观看 | 婷婷av电影 | 天天操狠狠操夜夜操 | 成人黄色影片在线 | 九九涩涩av台湾日本热热 | 欧美日韩在线电影 | 国产一区二区在线免费 | 国产精品私人影院 | 日韩欧美在线观看一区二区三区 | 国产一区在线视频观看 | 欧美性色19p| 国产女做a爱免费视频 | 久久福利精品 | 久久久国产精品成人免费 | 亚洲精品乱码白浆高清久久久久久 | 日韩av影视 | 精品美女在线观看 | 九九av| 国产尤物在线 | 四虎在线免费视频 | 三级黄色片子 | 日韩偷拍精品 | 国产999精品久久久久久麻豆 | 亚洲一级片在线观看 | 九九国产精品视频 | 久草热视频 | 精品久久久久久久久久久院品网 | 99视频久| 国产最新视频在线 | 91久久久久久久一区二区 | 免费在线播放黄色 | 91在线视频播放 | 日韩二区三区在线 | 久久激情视频 久久 | 色婷婷狠狠 | 黄色字幕网 | 超碰最新网址 | 97在线免费观看 | 久久久精品免费观看 | 亚洲免费av观看 | 中文字幕乱码亚洲精品一区 | 国产91综合一区在线观看 | 特及黄色片 | 最新av免费在线 | 亚洲午夜精品一区二区三区电影院 | 首页中文字幕 | av在线免费播放网站 | 91久久久久久国产精品 | 热久久视久久精品18亚洲精品 | 久艹在线播放 | 天天操夜| 日韩久久精品 | 狠狠狠狠狠狠狠狠 | 色婷婷福利 | 黄色一级大片在线观看 | 天天天干夜夜夜操 | 99麻豆久久久国产精品免费 | 国产一区视频在线观看免费 | 久久久久国产成人免费精品免费 | 国产精品久久久久久五月尺 | 欧美疯狂性受xxxxx另类 | 狠狠狠狠狠色综合 | 在线 国产一区 | 中文国产字幕在线观看 | 一级性视频 | 一区二区三区免费网站 | 国产视频99 | 色视频成人在线观看免 | av三级av | 色五月情 | 亚洲专区欧美专区 | 在线 国产 亚洲 欧美 | 天天综合入口 | 亚洲精品久久在线 | 最新中文字幕 | www99久久| 成人精品在线 | 国产欧美在线一区二区三区 | 国产精品久久久久久久久久久久午夜 | 狠狠狠狠狠狠狠狠 | 欧美性做爰猛烈叫床潮 | 日韩在线视频二区 | 91丨九色丨蝌蚪丰满 | 免费观看av网站 | 亚洲天堂香蕉 | 色婷久久 | 国产在线日本 | 国产一级淫片免费看 | 国模一区二区三区四区 | 免费av网站观看 | 久久精品视频中文字幕 | av大全免费在线观看 | 中文字幕 二区 | 黄色成年 | 97视频在线免费观看 | 日韩激情第一页 | 99久久精品久久久久久清纯 | 99久久影视| 国产精品不卡一区 | 在线播放精品一区二区三区 | 高清av免费观看 | 国产一区二区三区四区大秀 | 中文字幕av在线免费 | 国产成人精品亚洲a | 国精产品999国精产品视频 | 综合网天天色 | 日韩美在线| 欧美日韩在线精品一区二区 | 亚洲五月综合 | 激情五月在线 | 国产一区二区精品久久91 | 亚洲人成网站精品片在线观看 | 精品a视频 | 日韩精品观看 | 国产精品一区二区三区在线免费观看 | 热久久免费国产视频 | 亚洲精品乱码久久久久久写真 | 99精品国产一区二区三区不卡 | 午夜精品久久久久久久99 | 99久久夜色精品国产亚洲 | 中文字幕在线观看一区二区三区 | 国产一级免费在线观看 | 中文字幕日韩精品有码视频 | 99精品毛片 | 天天操网站 | 免费黄色特级片 | 中文视频在线看 | 天天操比| 成人动漫一区二区 | 久久久久区 | 成人午夜电影免费在线观看 | 免费看色视频 | 99国内精品久久久久久久 | 久久精品国产免费观看 | 五月天激情在线 | 国产精品门事件 | 日韩在线视 | 婷婷六月综合亚洲 | 亚洲天堂在线观看完整版 | 精品9999 | 在线观看中文字幕第一页 | 精品福利国产 | 久久精彩免费视频 | 国产成人精品一区二区三区网站观看 | 国产精品日韩在线 | 菠萝菠萝在线精品视频 | 色综合久久88色综合天天 | 成人a视频在线观看 | 综合伊人久久 | 午夜视频在线观看一区二区三区 | 不卡的av中文字幕 | 日韩中文字幕视频在线观看 | 波多野结衣久久资源 | 五月婷婷六月丁香 | 午夜国产一区二区 | 国产精品免费小视频 | 欧美成人影音 | 久久九精品 | 日韩黄色影院 | 国产精品免费久久久久 | 亚洲人久久 | 91精品国产亚洲 | 91桃色在线播放 | 一级片免费观看 | 人人看看人人 | 色婷婷97| 国产精品久久久久久久av大片 | 波多野结衣电影一区 | 免费av视屏 | 91香蕉视频720p | 悠悠av资源片 | 久久免费视频这里只有精品 | 五月婷婷六月丁香 | 中文字幕 91| 992tv人人草| 国产亚洲综合在线 | 日韩专区在线观看 | 国产精品一区二区三区在线 | 午夜资源站 | 麻豆高清免费国产一区 | 久久激情片 | 波多野结衣理论片 | 国产精品ⅴa有声小说 | 日韩中字在线 | 麻豆视频一区二区 | 97在线观看免费观看 | 黄av资源 | 免费网站黄色 | 免费在线播放av电影 | 蜜臀aⅴ精品一区二区三区 久久视屏网 | 六月婷操 | 中文字幕成人在线 | 久久高视频 | 91九色成人蝌蚪首页 | 91麻豆网 | 天天射天天拍 | 日日夜夜网 | 91麻豆精品国产自产在线游戏 | 欧美久久久久久久久中文字幕 | 久久久久伦理电影 | 国产免费影院 | 国产在线高清 | 五月开心激情 | 狠狠夜夜| av黄网站| 国际av在线| 亚洲精品久久激情国产片 | 成人免费看电影 | 色婷婷成人网 | 色一级片 | 日韩在线观看高清 | 国产色区| 久久国产精品99国产 | 欧美日韩裸体免费视频 | 欧美激情精品久久久久久变态 | 久草精品视频 | 在线视频欧美精品 | 亚洲黄色一级电影 | 黄色在线观看网站 | 中文字幕亚洲高清 | 亚洲精品女 | 国产手机在线视频 | 免费人成在线观看网站 | 亚洲精品乱码久久久久 | 夜夜骑天天操 | 久久久久久久av | 97电影在线观看 | 亚洲黄色在线免费观看 | 国产精品大尺度 | 日韩在线理论 | 国产精品99久久99久久久二8 | 国产成人99久久亚洲综合精品 | 麻豆视频国产在线观看 | 久久激情视频 久久 | 精品久久久久久久久久久久久久久久久久 | 国产精品美 | 在线观看成人福利 | 亚洲人成在线电影 | 精品在线免费视频 | 色噜噜在线观看视频 | 在线天堂中文在线资源网 | 久久精品中文字幕一区二区三区 | 激情视频一区二区三区 | 69绿帽绿奴3pvideos | 国产午夜影院 | 二区中文字幕 | 麻豆免费视频 | 最近中文字幕大全 | 日韩理论电影网 | 五月婷婷综合激情 | 亚洲成人av在线播放 | 视频一区二区在线观看 | 国内精品视频一区二区三区八戒 | 亚洲色图27p | 一区二区三区手机在线观看 | 9999国产精品 | 久草观看| 亚洲国产偷| 在线免费视频 你懂得 | 国内精品久久久久久久影视简单 | 丝袜美腿av| 免费看黄电影 | 91精选 | 久久久午夜剧场 | 欧美久久久久久久久久 | 在线免费看黄色 | 久久99国产精品自在自在app | 久久久网站 | 国产精品视频线看 | 日韩在线观看av | a级国产乱理论片在线观看 特级毛片在线观看 | 日韩电影在线观看一区二区 | 亚洲精品99 | 国产视频一区二区三区在线 | 99精品视频在线 | 96精品高清视频在线观看软件特色 | 一区二区三区四区五区六区 | 日韩精品免费在线视频 | 密桃av在线 | 午夜黄色| 一区三区视频在线观看 | 欧美成人亚洲 | www.久热 | 亚洲国产剧情 | 狠狠的操狠狠的干 | 在线观看中文字幕亚洲 | 国产精品 日韩精品 | 免费看国产曰批40分钟 | 丁香婷婷久久久综合精品国产 | 天天干天天操天天爱 | 美女黄频在线观看 | 99热这里只有精品免费 | 亚洲黄色在线播放 | 五月综合网站 | 97成人在线观看视频 | 中文字幕在线免费97 | 国产国语在线 | www.久久久com | 日韩在线观看影院 | 久久久久久久国产精品 | 亚洲精品99久久久久久 | 免费久久99精品国产 | 国产精品乱码一区二三区 | 在线看黄网站 | 国内精品久久天天躁人人爽 | 黄色av播放| 午夜精品久久久久久久99水蜜桃 | 在线观看一区 | 三级黄色欧美 | 色综合久久久久综合99 | 亚洲手机av | 天海冀一区二区三区 | 91免费日韩 | 在线观看免费一级片 | 国产在线精 | 看片在线亚洲 | 国产视频18 | 中文字幕日本特黄aa毛片 | 成人97视频 | 中文字幕频道 | 成人高清av在线 | 婷婷激情网站 | 在线观看黄色的网站 | 91麻豆精品国产91久久久久久久久 | 天天干夜夜夜操天 | 涩涩伊人 | 午夜久久影视 | 五月天天色 | av天天草 | 日韩免费电影一区二区 | 国产高清免费观看 | 99久久这里有精品 | 婷婷色综合 | www国产一区 | 99草视频| 成人午夜av电影 | 欧美日韩免费一区 | 色香蕉网| 夜夜操天天摸 | 一区二区三区影院 | 探花系列在线 | 国产一级黄大片 | 亚洲激色 | 久久久久久久久久久影视 | 精品久久久久久亚洲 | 激情视频久久 | 97超碰香蕉 | 国产色a在线观看 | 国产一区二区三区免费在线观看 | 98久久| 九九精品久久久 | 国产自在线观看 | 久爱综合| 国产一区二区三区视频在线 | 九九有精品 | 欧美性超爽 | 人人爱人人爽 | 在线免费黄 | 欧美少妇xxx | 成人宗合网 | 国产a国产| 国产精品毛片完整版 | 久青草视频 | 中文字幕在线观看亚洲 | 久久午夜影院 | 一级免费片 | 97国产一区二区 | 免费av观看 | 欧美日韩亚洲精品在线 | 成人欧美一区二区三区黑人麻豆 | 国产在线观看一 | 九色视频网站 | 亚洲精品字幕在线观看 | 日韩女同av | 欧美精品久久久久久久久久久 | 久久久国产精品久久久 | www.久久久| 91在线视频免费91 | 97免费在线观看视频 | 在线看欧美 | 国产看片 色 | av丝袜天堂 | 日韩激情av在线 | 黄色小说视频在线 | 啪啪免费观看网站 | 免费a网址 | 伊人亚洲综合 | 狠狠色香婷婷久久亚洲精品 | 在线免费高清一区二区三区 | 久久另类小说 | 伊人五月在线 | 欧美日韩国产高清视频 | 欧美乱码精品一区 | 黄网站色欧美视频 | 国产日韩精品一区二区 | 欧美午夜一区二区福利视频 | 国产一级不卡毛片 | 色婷婷激情电影 | 日韩二区精品 | 色欧美88888久久久久久影院 | 日操操| 亚洲精品一区二区在线观看 | 欧美二区三区91 | 亚洲精品国产精品国产 | 九七在线视频 | 国产专区一| 天天艹天天操 | 国产福利不卡视频 | 成 人 黄 色视频免费播放 | 97超碰在线播放 | 亚洲天堂免费视频 | 中文字幕一区三区 | 国产精品久久久久久久婷婷 | 久久久久久久久免费 | 丁香六月网 | 亚洲精品乱码久久久久久蜜桃欧美 | 激情婷婷综合网 | 五月激情丁香图片 | 亚洲国产精久久久久久久 | 999久久久久| 视频国产 | 九九热在线观看 | 亚洲成人黄 | 少妇bbb| 18久久久久久 | 最近中文字幕大全中文字幕免费 | 国产精品久久久亚洲 | 夜夜操网 | 91看片一区二区三区 | 91九色网站| 91网在线 | 久久久久免费看 | 欧美日韩在线免费视频 | 黄色一级大片免费看 | 国产一区二区手机在线观看 | 亚洲欧美视频网站 | 国产精彩视频一区 | 国产伦精品一区二区三区无广告 | 国产精品手机播放 | 国产91精品高清一区二区三区 | 日韩理论片中文字幕 | 日韩一级片观看 | 久久综合九色九九 | 久久9999久久| 久久亚洲综合国产精品99麻豆的功能介绍 | 欧美射射射 | 欧美人zozo| 国产精品一区二区免费在线观看 | 狠狠狠狠干 | 在线视频观看你懂的 | 国内精品久久久精品电影院 | 国产精品成人免费一区久久羞羞 | www.亚洲精品视频 | 干av在线| 97在线资源 | 久久久久女教师免费一区 | 香蕉视频在线免费 | 人人插人人干 | 国产一区二区在线播放视频 | 精品1区2区3区 | 国产日韩在线播放 | 久久国产片 | 精品在线99 | 特级黄色视频毛片 | 久久av不卡| 五月天狠狠操 | 夜夜躁狠狠燥 | 91麻豆看国产在线紧急地址 | 天天做天天爱天天爽综合网 | 在线观看午夜av | 日一日操一操 | 在线免费看黄色 | 日本h在线播放 | av专区在线 | 91在线观看欧美日韩 | 成人av资源在线 | 午夜久久网站 | 中文字幕国产在线 | 中文字幕av最新更新 | 高清中文字幕 | av一本久道久久波多野结衣 | 97视频免费观看 | 亚洲黄电影 | 国产在线a不卡 | 国内偷拍精品视频 | 在线观看亚洲免费视频 | 草在线视频| 国产精品久久久一区二区三区网站 | 欧美一级片在线观看视频 | 国产一区网址 | 天天草天天爽 | 欧美日韩一区二区久久 | www国产亚洲精品久久麻豆 | 亚洲欧美日韩在线一区二区 | 国产精品2区 | 色一色在线| 久亚洲 | 国产小视频国产精品 | 91自拍91 | 9999国产| www.久久91| 91麻豆产精品久久久久久 | 国产精品美女久久久久久 | 国产69精品久久久久99尤 | 久久久久久久久久久综合 | 亚洲黄色区| 免费91麻豆精品国产自产在线观看 | 国产手机在线视频 | 高清视频一区 | 色综合久久综合中文综合网 | 国产一区二区在线播放 | 天天爽夜夜爽人人爽曰av | 在线观看免费高清视频大全追剧 | 国产日韩精品久久 | 91在线免费播放视频 | www色网站| 日韩精品不卡在线观看 | 日本久久久久久科技有限公司 | 久久精品免费观看 | 97久久精品午夜一区二区 | 波多野结衣在线观看一区二区三区 | 成人a级黄色片 | 亚洲人人精品 | 欧美日韩国产免费视频 | 在线免费观看成人 | 久久成人午夜视频 | 国产成人一区二区三区久久精品 | 9i看片成人免费看片 | 青青草国产精品视频 | 久久精品91久久久久久再现 | 国产精品入口麻豆 | 91热视频| 天天操天天色天天射 | 久久在线视频在线 | 国产成人精品综合久久久 | 国产精品99精品久久免费 | 丁香婷婷激情啪啪 | 欧美日韩中文国产 | 久久国产精品久久国产精品 | 日韩在线观看一区二区三区 | 国产高清一区二区 | 欧美成人按摩 | 男女免费视频观看 | av大全在线看 | 四虎在线视频免费观看 | 成年人免费在线看 | 99久久er热在这里只有精品66 | 亚洲一级二级三级 | 亚洲综合成人专区片 | 国产精品久久久久久a | 一区二区三区中文字幕在线观看 | 九九久久免费视频 | 24小时日本在线www免费的 | 亚洲精品国产精品乱码在线观看 | 亚洲精品久久久蜜臀下载官网 | 久久久国产电影 | 国产精品成人aaaaa网站 | 精品免费观看视频 | 国产五月色婷婷六月丁香视频 | av综合网址| 欧美大片mv免费 | 免费日韩三级 | 一本—道久久a久久精品蜜桃 | 97热在线观看 | 久久一区二区三区国产精品 | 精品视频在线看 | 久av在线| 日韩在线免费小视频 | 久久久久福利视频 | 亚洲欧洲精品一区二区 | 又色又爽又黄高潮的免费视频 | 色综合天天色综合 | 日韩高清免费电影 | 国产精品日韩在线观看 | 欧美 日韩 国产 中文字幕 | 黄网站免费久久 | 天天天色 | 啪啪免费试看 | 国产原创中文在线 | 韩日精品在线观看 | 国产在线理论片 | 亚洲精品网站在线 | 欧美一级片免费播放 | 美女黄濒 | 麻豆视频国产精品 | 久久久精品99 | 日日躁天天躁 | 福利av影院 | a黄色片在线观看 | 欧美 亚洲 另类 激情 另类 | 精品黄色片 | 在线视频久久 | 在线视频欧美日韩 | 在线高清 | 久久精品一区二区三区视频 | 中文字幕中文字幕中文字幕 | 在线观看av免费观看 | 日韩三级不卡 | 日韩在线短视频 | 在线播放av网址 | www.狠狠色 | 午夜婷婷在线播放 | 免费黄在线观看 | 国产午夜剧场 | 亚洲国产精品成人女人久久 | 中文字幕色站 | 在线欧美中文字幕 | 国产高清av免费在线观看 | 在线精品播放 | 色婷婷国产精品一区在线观看 | bbbb操bbbb| 中文字幕av在线免费 | 日韩在线免费视频观看 | 精品久久五月天 | 成人亚洲综合 | 亚洲免费小视频 | 日本中文字幕在线看 | 国产一级特黄毛片在线毛片 | 亚洲干视频在线观看 | 久久亚洲私人国产精品va | 一级免费黄色 | 国产福利一区二区三区视频 | 国产精品中文久久久久久久 | 福利片免费看 | 在线观看亚洲专区 | 91香蕉视频色版 | 久久在现 | 亚洲电影久久 | 国产一级在线观看视频 | 国色天香在线观看 | 99色亚洲 | 青草视频在线看 | 日日夜夜婷婷 | av成人在线观看 | 色资源在线 | 亚洲少妇天堂 | 免费在线精品视频 | 久要激情网 | 午夜精品久久久久久久99无限制 | 国产一区二区在线免费视频 | 看黄色.com| 3d黄动漫免费看 | 日本性xxxxx| 色婷婷亚洲 | 99精品在线 | 国产h片在线观看 | 91亚洲永久精品 | 欧洲不卡av | 久久久国产精品亚洲一区 | 成人黄在线 | 国内精品小视频 | 天天av资源 | www欧美xxxx| 国产亚洲精品美女久久 | 视频一区二区视频 | 国产午夜影院 | 国产精品女同一区二区三区久久夜 | 精品国产乱码久久久久久1区二区 | 日韩av男人的天堂 | 深夜免费网站 | 韩国精品一区二区三区六区色诱 | 日本不卡123 | 狠狠操狠狠插 | 九九热在线精品 | 成人午夜影视 | 日韩在线不卡视频 | 99视频精品在线 | 国产精品一区免费看8c0m | 免费精品视频在线观看 | 国产一二三四在线视频 | 国产精品麻豆三级一区视频 | 日韩欧美在线视频一区二区三区 | 久草在线中文视频 | 日本久久久久久久久 | 欧美日韩一区二区三区在线免费观看 | 91传媒在线| 国产伦精品一区二区三区… | 婷婷丁香激情网 | 在线观看视频一区二区三区 | 免费福利视频导航 | 日韩成人邪恶影片 | 国产品久精国精产拍 | 天天综合在线观看 |