1.redis模块简介
1、redis是一个key-value存储系统。属于Nosql数据库(非关系型数据库),以键值对来存储; 和Memcached类似,它支持存储的value类型相对更多,包括string(字符串)、list(链表)、set(集合)、zset(sorted set --有序集合)和hash(哈希类型)。
2、这些数据类型都支持push/pop、add/remove及取交集并集和差集及更丰富的操作,而且这些操作都是原子性的。在此基础上,redis支持各种不同方式的排序。与memcached一样,为了保证效率,数据都是缓存在内存中;数据先缓存在内存中;redis会周期性的把更新的数据写入磁盘或者把修改操作写入追加的记录文件,并且在此基础上实现了master-slave(主从)同步
3、 redis的出现,很大程度补偿了memcached这类key/value存储的不足,在部 分场合可以对关系数据库起到很好的补充作用
2.redis数据库的编译安装
(1)获得redis安装包并解压
tar zxf redis-5.0.3.tar.gz
cd redis-5.0.3 ##到解压的redis目录下进行编译安装
make && make install
cd utils
./install_server.sh
(2)修改配置文件开放端口
- 端口:6379
vim /etc/redis/6379.conf
(2) 开启服务
/etc/init.d/redis_6379 restart
(3)redis数据库存储应用
redis-cli
3.redis数据库的连接
3.1直接连接
conn=redis.Redis(host='localhost',port=6379) ##连接本地redis数据库 端口6379
3.2 连接池连接
- 原理:通过预先创建多个连接,当进行redis操作时,直接获取已经创建的连接进行操作,而且操作完成后,不会释放,用于后续的其他redis连接操作,这样就达到了避免频繁的redis连接创建和释放的目的,从而提高性能;
- redis模块采用ConnectionPool来管理对redisserver的所有连接
pool = redis.ConnectionPool(host='localhost',port=6379)
conn = redis.Redis(connection_pool=pool)
4.对redis数据库的操作
4.1数据的建立
pool = redis.ConnectionPool(host='localhost',port=6379)
conn = redis.Redis(connection_pool=pool)
conn.set('name','粉条',4) #4代表的是失效时间 单位为s
conn.set('name','fentiao',3)
conn.set('age',10,3)
conn.set('score',100,3)
print(conn.get('name').decode('utf-8')) ## .get默认返回b(bit)比特类型 如果转换 需解码为utf-8编码格式
print('等待3s....')
time.sleep(3)
print(conn.get('name'))
4.2 获取所有key值conn.keys()
print(conn.keys())
print(len(conn.keys()))
4.3 获取redis数据库中数据的条数dbsize()
print(conn.dbsize())
4.4 删除指定的key-values值delete()
conn.delete('score')
print('正在删除key...')
print(conn.get('score'))
4.5 清除redis所有key-values fiushall()
print('清除前:',conn.keys())
# 清除redis里面的所有key-value
conn.flushall()
print('清除后:',conn.keys())
4.6 选择集合存储 key 可以重复 conn.sadd()
conn.sadd('python','user1')
conn.sadd('python','user2')
conn.sadd('python','user3')
conn.sadd('movie','user1')
conn.sadd('movie','user6')
conn.sadd('movie','user7')
4.7 获取某个圈子的成员 conn.smembers()
print(conn.smembers('python'))
print(conn.smembers('movie'))
4.8 获取某个圈子共同拥有的成员 conn.sinter(’’,’’)
print(conn.sinter('python','movie'))
4.9 获取并集 sunion(’’,’’)
print(conn.sunion('python','movie'))