title: 踩坑 redis 做臨時(shí)緩存、數(shù)據(jù)庫(kù)使用
tags: ['redis','緩存','python']
date: 2021-12-15
categories: "磨刀不誤砍柴工"
環(huán)境
window10
redis
前言
使用到redis的原因,一是之前做的業(yè)務(wù)邏輯有需要對(duì)用戶操作連續(xù)幾個(gè)操作的邏輯判斷和做一個(gè)時(shí)間上的有效性,二是做一下熱數(shù)據(jù)的臨時(shí)緩存。
redis的使用體驗(yàn)是很舒服,簡(jiǎn)單而又高效。
一點(diǎn)簡(jiǎn)介
安裝就不說(shuō)了,百度上一大堆教程,常用的幾個(gè)config設(shè)置也比較好找,略略略。
Redis 是一個(gè)高性能的key-value數(shù)據(jù)庫(kù),這個(gè)對(duì)我學(xué)習(xí)的重點(diǎn),是 key-value 形式的數(shù)據(jù)庫(kù),這和python的dict基本是一樣的邏輯,這也是我覺(jué)得它灰常方便的主要原因。
常用操作
python操作
1.1 連接redis
-
普通連接
import redis conn = redis.Redis(host='localhost', port=6379, db=0, decode_responses=True) -
線程池連接
import redis Pool = redis.ConnectionPool(host='127.0.0.1', port=6379,db=0, max_connections=10) conn = redis.Redis(connection_pool=Pool)程序中的
db=0指的是當(dāng)前(默認(rèn))連接第一個(gè)數(shù)據(jù)庫(kù),并且redis默認(rèn)有16個(gè)數(shù)據(jù)庫(kù),即db0------db15。不管是那種連接方式,后續(xù)操作都會(huì)使用這個(gè)
conn去執(zhí)行。
1.2 redis的存儲(chǔ)結(jié)構(gòu)及操作
redis使用key-value(鍵值對(duì))的方式存儲(chǔ)數(shù)據(jù),key就是一個(gè)字符串,沒(méi)啥要說(shuō)的,value有幾種存儲(chǔ)數(shù)據(jù)的方式。
1.2.1 字符串 String
這種存儲(chǔ)的value是一個(gè)字符串,比如存儲(chǔ)每個(gè)人的個(gè)性簽名:
# -*- coding: utf-8 -*-
import json
import time
import redis
conn = redis.Redis(host='localhost', port=6379, db=8, decode_responses=True)
data_list = {
"路人甲": "天蒼蒼野茫茫,小灰灰和懶洋洋",
"路人乙": "愛(ài)拼才會(huì)贏,愛(ài)笑才會(huì)有朋友",
"路人丙": "隨便瞎編一句個(gè)性簽名吧。",
}
# 寫入
for key, value in data_list.items():
conn.set(key, value)
# 讀取
for key in conn.keys():
print("{}的個(gè)簽是\t{}".format(key, conn.get(key)))
# 刪除
conn.delete("路人甲")
print("刪除路人的信息之后")
# 讀取
for key in conn.keys():
print("{}的個(gè)簽是\t{}".format(key, conn.get(key)))
# 判斷是否存在
print("路人甲是否存在\t", conn.exists("路人甲"))
print("路人乙是否存在\t", conn.exists("路人乙"))
# 設(shè)置有效時(shí)間
conn.expire("路人乙", 3)
for i in range(0, 5):
time.sleep(1)
print("%d秒后,路人乙是否存在\t%d" % (i + 1, conn.exists("路人乙")))
這個(gè)地方的key對(duì)應(yīng)的value必須全部都是String字符串形式才可以這樣操作,不然會(huì)報(bào)錯(cuò)。
要提前做好每個(gè)庫(kù)的規(guī)劃,不要存的太隨意了。

1.2.2 json 字典 Hash
這種存儲(chǔ)的value是一個(gè)字典,比如存儲(chǔ)每個(gè)人的身高體重血型:
data_list = {
"路人甲": {
"身高": 175,
"體重": 70,
"血型": "A",
},
"路人乙": {
"身高": 160,
"體重": 44,
"血型": "B",
},
"路人丙": {
"身高": 180,
"體重": 180,
"血型": "A",
},
}
# 寫入
for key, value in data_list.items():
conn.hset("個(gè)人信息", key, json.dumps(value))
# 讀取
for key in conn.hgetall("個(gè)人信息"):
data = conn.hget("個(gè)人信息", key)
data = json.loads(data)
print("{}的身高是\t{},體重是\t{},血型是\t{}".format(key, data['身高'], data['體重'], data['血型']))
# 刪除
conn.hdel("個(gè)人信息", "路人甲")
print("刪除路人甲的信息之后")
# 讀取
for key in conn.hgetall("個(gè)人信息"):
data = conn.hget("個(gè)人信息", key)
data = json.loads(data)
print("{}的身高是\t{},體重是\t{},血型是\t{}".format(key, data['身高'], data['體重'], data['血型']))

1.2.3 列表 list
這種存儲(chǔ)的value是一個(gè)字典,比如存儲(chǔ)個(gè)人的todo_list。
每次插值插在最前面
data_list = [
"1 今天睡個(gè)懶覺(jué)",
"2 去吃一碗香菇面",
"3 看個(gè)書吧",
"4 看個(gè) 不看了",
"5 擦擦鼠標(biāo)",
"6 擦擦鍵盤",
"7 打開電腦",
"8 算了睡覺(jué)吧",
]
# 每次插值插在最前面
for data in data_list:
conn.lpush("todo_list", data)
對(duì)應(yīng)在數(shù)據(jù)庫(kù)中的數(shù)據(jù):

每次插值插在最后面:
data_list = [
"1 今天睡個(gè)懶覺(jué)",
"2 去吃一碗香菇面",
"3 看個(gè)書吧",
"4 看個(gè) 不看了",
"5 擦擦鼠標(biāo)",
"6 擦擦鍵盤",
"7 打開電腦",
"8 算了睡覺(jué)吧",
]
# 每次插值插在最前面
for data in data_list:
conn.rpush("todo_list", data)

使用lpush還是rpush看情況決定吧。
取出一個(gè):
task1 = conn.blpop("todo_list")
print(task1)
print(type(task1))
print("最前面(l)一個(gè)任務(wù):", task1[1])
print()
task2 = conn.brpop("todo_list")
print("最后面(r)一個(gè)任務(wù):", task2[1])

1.2.3 集合 set
這種存儲(chǔ)的value是一個(gè)集合,比如存儲(chǔ)我的日常事件(不重復(fù)):
data_list = [
"吃",
"睡",
"蹲坑",
]
for data in data_list:
conn.sadd("我的日常事件", data)
data = conn.smembers("我的日常事件")
print(data)
print(type(data))

寫在最后
上述類型還有很多更詳細(xì)的操作模式,以及還有其他類型,這邊只寫了一下常用的操作。
實(shí)力有限,才疏學(xué)淺,如有錯(cuò)誤,歡迎指正。
- 我的個(gè)人博客 菜貓子小六 - 博客 (codesix.site)
- 我的簡(jiǎn)書 菜貓子小六 - 簡(jiǎn)書 (jianshu.com)
- 我的CSDN 菜貓子小六 - CSDN