显例:
python
import redis class RedisUtils(object): def __init__(self): if not hasattr(RedisUtils, 'pool'): RedisUtils.getPool() #建立redis链接pool self.coon = redis.Redis(connection_pool=RedisUtils.pool) @staticmethod def getPool(): RedisUtils.pool = redis.ConnectionPool(host='192.168.18.199', port=6379, password='sss', db=10, decode_responses=True) def set(self, key, value, exps=None): if exps: self.coon.set(key, value, ex=30) else: self.coon.set(key, value) def get(self, key): return self.coon.get(key) if __name__ == '__main__': # utils = RedisUtils() # utils.set("sea", "test") # utils.set("xixi", "test", 10) # print(utils.get("sea")) conn_redis = redis.Redis(host='192.168.18.199', port=6379, password='xxx', db=10) conn_redis.set('娘子', '啊哈') conn_redis.set('gg', '啊哈', ex=10) print(conn_redis.get("gg").decode("utf-8"))
不使用链接池:
redis
import redis conn_redis = redis.Redis(host='127.0.0.1', port=6379, password='123456', db=1) conn_redis.set('娘子', '啊哈')
conn_redis.set('娘子', '啊哈',ex=30) #30s 过时
python 操做redis,使用链接池:ide
redis-py使用connection pool来管理对一个redis server的全部链接,避免每次创建、释放链接的开销。默认,每一个Redis实例都会维护一个本身的链接池。能够直接创建一个链接池,而后做为参数Redis,这样就能够实现多个Redis实例共享一个链接池。code
def getcoon(): pool = redis.ConnectionPool(host='192.168.25.126', port=6379, password='123456', db=0) coon = redis.Redis(connection_pool=pool) coon.set('key', 'value') res = coon.get('key') return res
coon.set('sea', 'hahhahaha', ex=30) # 过时时间单位s
set(name, value, ex=None, px=None, nx=False, xx=False) 在 Redis 中设置值,默认,不存在则建立,存在则修改。 参数: ex - 过时时间(秒) px - 过时时间(毫秒) nx - 若是设置为True,则只有name不存在时,当前set操做才执行 xx - 若是设置为True,则只有name存在时,当前set操做才执行
redis 使用链接池操做server
class OPRedis(object): def __init__(self): if not hasattr(OPRedis, 'pool'): OPRedis.getRedisCoon() #建立redis链接 self.coon = redis.Redis(connection_pool=OPRedis.pool) @staticmethod def getRedisCoon(): OPRedis.pool = redis.ConnectionPool(host=redisInfo['host'], password=redisInfo['password'], port=redisInfo['port'], db=redisInfo['db']) """ string类型 {'key':'value'} redis操做 """ def setredis(self, key, value, time=None): #非空即真非0即真 if time: res = self.coon.setex(key, value, time) else: res = self.coon.set(key, value) return res def getRedis(self, key): res = self.coon.get(key).decode() return res def delRedis(self, key): res = self.coon.delete(key) return res """ hash类型,{'name':{'key':'value'}} redis操做 """ def setHashRedis(self, name, key, value): res = self.coon.hset(name, key, value) return res def getHashRedis(self, name, key=None): # 判断key是否我为空,不为空,获取指定name内的某个key的value; 为空则获取name对应的全部value if key: res = self.coon.hget(name, key) else: res = self.coon.hgetall(name) return res def delHashRedis(self, name, key=None): if key: res = self.coon.hdel(name, key) else: res = self.coon.delete(name) return res
redisInfo配置utf-8
redisInfo = { "host": '192.168.1.112', "password": '123456', "port": 6379, "db": 0 }