【python】Redis介紹及簡單使用


一、redis

  redis是一個key-value存儲系統。和 Memcached類似,它支持存儲的value類型相對更多,包括string(字符串)、 list(鏈表)、set(集合)、zset(sorted set --有序集合)和hash(哈希類型)。這些數據類型都支持push/pop、add/remove及取交集並集和差集及更豐富的操作,而且這些操作都是 原子性的。在此基礎上,redis支持各種不同方式的排序。與memcached一樣,為了保證效率,數據都是緩存在內存中。區別的是redis會周期性 的把更新的數據寫入磁盤或者把修改操作寫入追加的記錄文件,並且在此基礎上實現了master-slave(主從)同步。

  Redis 是一個高性能的key-value數據庫。 redis的出現,很大程度補償了memcached這類key/value存儲的不足,在部 分場合可以對關系數據庫起到很好的補充作用。它提供了Python,Ruby,Erlang,PHP客戶端,使用很方便,Redis支持主從同步。數據可 以從主服務器向任意數量的從服務器上同步,從服務器可以是關聯其他從服務器的主服務器。這使得Redis可執行單層樹復制。從盤可以有意無意的對數據進行 寫操作。由於完全實現了發布/訂閱機制,使得從數據庫在任何地方同步樹時,可訂閱一個頻道並接收主服務器完整的消息發布記錄。

二、python操作redis

1、連接方式

  redis-py提供兩個類Redis和StrictRedis用於實現Redis的命令,StrictRedis用於實現大部分官方的命令,並使用官方的語法和命令,Redis是StrictRedis的子類

1
2
3
4
5
6
7
#!/usr/bin/env python
# -*- coding:utf- 8 -*-
import redis
 
r = redis.Redis(host= '192.168.0.110' , port= 6379 ,db= 0 )
r.set( 'name' , 'zhangsan' )   #添加
print (r.get( 'name' ))   #獲取

2、連接池

  redis- py使用connection pool來管理對一個redis server的所有連接,避免每次建立、釋放連接的開銷。默認,每個Redis實例都會維護一個自己的連接池。可以直接建立一個連接池,然后作為參數 Redis,這樣就可以實現多個Redis實例共享一個連接池。

1
2
3
4
5
6
7
8
#!/usr/bin/env python
# -*- coding:utf- 8 -*-
import redis
 
pool = redis.ConnectionPool(host= '192.168.0.110' , port= 6379 )
r = redis.Redis(connection_pool=pool)
r.set( 'name' , 'zhangsan' )   #添加
print (r.get( 'name' ))   #獲取

3、發布和訂閱

首先定義一個RedisHelper類,連接Redis,定義頻道為monitor,定義發布(publish)及訂閱(subscribe)方法。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
#!/usr/bin/env python
#-*- coding:utf- 8 -*-
import redis
 
class RedisHelper(object):
     def __init__(self):
         self.__conn = redis.Redis(host= '192.168.0.110' ,port= 6379 )#連接Redis
         self.channel = 'monitor' #定義名稱
 
     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

發布者

1
2
3
4
5
6
7
#!/usr/bin/env python
# -*- coding:utf- 8 -*-
#發布
from RedisHelper import RedisHelper
 
obj = RedisHelper()
obj.publish( 'hello' )#發布

訂閱者

1
2
3
4
5
6
7
8
9
10
11
#!/usr/bin/env python
# -*- coding:utf- 8 -*-
#訂閱
from RedisHelper import RedisHelper
 
obj = RedisHelper()
redis_sub = obj.subscribe()#調用訂閱方法
 
while True:
     msg= redis_sub.parse_response()
     print (msg)

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM