Python連線Redis
Redis: 是一個高效能的key-value資料庫。
簡單來說就是:當你使用關係型資料庫、檔案或者其他介質存東西,效能不好反應慢,這個時候就要拿個東西做快取。同類產品有好幾種,目前比較流行,在我司進行商用的就是這個。目前,這玩意在叢集狀態下,為我們的百萬級併發提供良好的支援。
今天,我們就來簡單聊聊,如何用python操作redis。
牛小妹,把這個放進你的畢業設計,又能錦上添花哦。
redis的安裝,參考文章
1.python 連線redis
普通連線
import redis
#後面是地址 埠
r = redis.Redis(host='127.0.0.1', port=6379)
2.連線池
redis-py使用connection pool來管理對一個redis server的所有連線,避免每次建立、釋放連線的開銷
import redis
pool = redis.ConnectionPool(host='192.168.0.110', port=6379)
r = redis.Redis(connection_pool=pool)
3.管道
redis-py,預設情況下,每次都會進行連線池的連線和斷開。若是想一次執行多條命令,進行事務性操作,就要用管道。
import redis
pool = redis.ConnectionPool(host='192.168.0.110', port=6379)
r = redis.Redis(connection_pool=pool)
pipe = r.pipeline(transaction=True)
r.set('zcx', '5555')
r.set('zcx', '6666')
pipe.execute()
說明:雖然提供了這麼一個功能。但實際情況還是不建議使用。因為這個執行起來慢。另一方面,也沒必要
4.釋出訂閱
在我們學習作業系統這本書的時候,裡面有個生產者和消費者。在這裡,我試著用redis來模擬
定義公共的類,包裝方法和初始化連線
import redis
class redis_util(object):
def __init__(self):
self.__conn = redis.Redis(host='127.0.0.1', port=6379)
self.channel = 'mybaby' # 定義通道名稱
def publish(self, msg): # 定義釋出的方法
self.__conn.publish(self.channel, msg)
return True
def subscribe(self): # 定義訂閱的方法
pub = self.__conn.pubsub()
pub.subscribe(self.channel)
pub.parse_response()
return pub
publisher釋出者:
from polls.redis_utils import redis_util
obj = redis_util()
obj.publish('test')
subscriber訂閱者:
from polls.redis_utils import redis_util
obj = redis_util()
redis_sub = obj.subscribe()
while True:
msg = redis_sub.parse_response()
print(msg)
至於釋出訂閱。只是表達有這麼一個功能。但是,不建議用。後面,我將和大家一起,更深入的討論這方面的問題。
好啦,今晚就玩到這,要去陪我家小baby啦