记录键值数据库Redis命令笔记,以便后续使用查看。
redis中文文档:http://redis.cn/commands.html
Redis介绍
nosql概念介绍
- 泛指非关系型的数据库
- 不支持SQL语法
- 存储结构跟传统关系型数据库中的那种关系表完全不同,nosql中存储的数据都是KV形式
- NoSQL的世界中没有一种通用的语言,每种nosql数据库都有自己的api和语法,以及擅长的业务场景
- NoSQL中的产品种类相当多:
- Mongodb
- Redis
- Hbase hadoop
- Cassandra hadoop
简介
Redis是一个开源的使用ANSI C语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的API。从2010年3月15日起,Redis的开发工作由VMware主持。从2013年5月开始,Redis的开发由Pivotal赞助。
Redis是 NoSQL技术阵营中的一员,它通过多种键值数据类型来适应不同场景下的存储需求,借助一些高层级的接口使用其可以胜任,如缓存、队列系统的不同角色。
特性
Redis 与其他 key - value 缓存产品有以下三个特点:
- Redis支持数据的持久化,可以将内存中的数据保存在磁盘中,重启的 时候可以再次加载进行使用。
- Redis不仅仅支持简单的key-value类型的数据,同时还提供list,set, zset,hash等数据结构的存储。
- Redis支持数据的备份,即master-slave模式的数据备份。
优势
- 性能极高 – Redis能读的速度是110000次/s,写的速度是81000次/s 。
- 丰富的数据类型 – Redis支持二进制案例的 Strings, Lists, Hashes, Sets 及 Ordered Sets 数据类型操作。
- 原子 – Redis的所有操作都是原子性的,同时Redis还支持对几个操作全并后的原子性执行。
- 丰富的特性 – Redis还支持 publish/subscribe, 通知, key 过期等等特性。
服务端与客户端命令
服务端
这里使用windows10系统操作redis数据库;
开启服务端命令:(若没有配置环境变量需先cd切换到下载redis的存放目录下)
- windows:redis-server.exe redis.windows.conf
- linux:redis-server “/…/…/redis.conf” (…代表指定的目录路径)
输入windows服务器的redis开启命令,出现以下图片情况表示成功。
可以使用help查看帮助文档
redis-server help
客户端命令: redis-cli [-h(指定连接redis数据库ip) -p(指定端口)]
可以使⽤help查看帮助⽂档
redis-cli --help
连接本地redis数据库命令:
redis-cli
运行测试命令:ping(若出现PONG则为正常)
切换数据库,数据库没有名称,默认有16个,通过0-15来标识,连接redis默认选择第一个数据库:
select 10
数据操作
String
设置值:
set key value
设置值以及过期时间:
setex key seconds value
设置值以及过期时间:
mset key1 value1 [key2 value2...]
追加内容:
append key value
获取键的值:
get key
获取多个值:
mget key1 [key2 ...]
键命令
查看所有键值对:
keys *
删除对应的键值对数据:
del key
判断键是否存在:(存在返回1,反之返回0)
exists key
判断类型:
type key
修改过期时间:
expire key seconds
查看过期时间:
tll key
hash
hash类型:hash⽤于存储对象,对象的结构为属性、值(值的类型为string)。注意:哈希hash中的key指的是一个字典的变量值,而field为字典的键值(key)
设置单个属性:
hset key field value
设置多个属性:
hmset key field value [field2 value2]
获取指定键所有的属性:
hkeys 对象名
获取一个字段的值:
hget key field
获取多个字段的值:
hmget key field field2 ...
例:获取键u2属性’name’、'age的值:
hmget u2 name age
获取所有属性的值:
hvals key
删除属性的值:
hdel key field
list
list类型:
- 列表的元素类型为string
- 按照插入顺序排序
在左侧插⼊数据: insert(0, item)
lpush key value1 value2
在右侧插⼊数据: append(item)
rpush key value1 value2
返回列表⾥指定范围内的元素:
- start、stop为元素的下标索引
- 索引从左侧开始,第⼀个元素为0
- 索引可以是负数,表示从尾部开始计数,如-1表示最后⼀个元素
lrange key start stop
在指定元素的前或后插⼊新元素:
linsert key before或after 现有元素 新元素
设置指定索引位置的元素值:
- 索引从左侧开始,第⼀个元素为0
- 索引可以是负数,表示尾部开始计数,如-1表示最后⼀个元素
lset key index value
删除指定元素:
- 将列表中前count次出现的值为value的元素移除
- count > 0: 从头往尾移除
- count < 0: 从尾往头移除
- count = 0: 移除所有
lrem key count value
例子:lrange查询左右闭区间 []
1:向列表’a2’中加⼊元素’a’、‘b’、‘a’、‘b’、‘a’、‘b’
lpush a2 a b a b a b
2:从’a2’列表右侧开始删除2个’b’
lrem a2 -2 b
3:查看列表’py12’的所有元素(0)
lrange a2 0 -1
set
set类型:说明:对于集合没有修改操作
- ⽆序集合
- 元素为string类型
- 元素具有唯⼀性,不重复
添加元素:
sadd key member1 [member2 ...]
例1:向键’a3’的集合中添加元素’zhangsan’、‘lisi’、‘wangwu’:
sadd a3 zhangsan sili wangwu
返回所有的元素:
smembers key
例2:获取键’a3’的集合中所有元素
smembers a3
删除元素:
srem key member
例3:删除键’a3’的集合中元素’wangwu’
srem a3 wangwu
zset
zset类型:有序的集合(说明:没有修改操作)
- sorted set,有序集合
- 元素为string类型
- 元素具有唯⼀性,不重复
- 每个元素都会关联⼀个double类型的score,表示权重,通过权重将元素从⼩到⼤排序
添加元素:
zadd key score1 member1 score2 member2
例1:向键’a4’的集合中添加元素’lisi’、‘wangwu’、‘zhaoliu’、‘zhangsan’,权重分别为4、5、6、3
zadd a4 4 lisi 5 wangwu 6 zhaoliu 3 zhangsan
返回所有的元素:
- 返回指定范围内的元素
- start、stop为元素的下标索引
- 索引从左侧开始,第⼀个元素为0
- 索引可以是负数,表示从尾部开始计数,如-1表示最后⼀个元素
zrange key start stop
例2:获取键’a4’的集合中所有元素
zrange a4 0 -1
返回score值在min和max之间的成员:
zrangebyscore key min max
例3:获取键’a4’的集合中权限值在5和6之间的成员
zrangebyscore a4 5 6
返回成员member的score值:
zscore key member
例4:获取键’a4’的集合中元素’zhangsan’的权重
zscore a4 zhangsan
删除指定元素:
zrem key member1 member2...
例5:删除集合’a4’中元素’zhangsan’
zrem a4 zhangsan
删除权重在指定范围的元素:
zremrangebyscore key min max
例6:删除集合’a4’中权限在5、6之间的元素
zremrangebyscore a4 5 6
与Python交互
安装redis第三方库: pip install redis
使用python操作redis数据库
- 导入模块
from redis import *
- 创建redis数据库对象()
decode_responses=True :按照utf8的格式将bytes
类型数据转换成字符串
sr=StrictRedis(decode_responses=True)
- 执行redis命令
sr.set(key,value)
sr.get(key)
sr.delete(key)
注意:操作redis服务端时的命令与Python操作redis数据库时的命令大致相同,唯有服务端中的del删除命令在Python内变成delete即可。
主从小结
概念
master和slave都是一个redis实例(redis服务)
- ⼀个master可以拥有多个slave,⼀个slave⼜可以拥有多个slave,如此下去,形成了强⼤的多级服务器集群架构
- master用来写数据,slave用来读数据,经统计:网站的读写比率是10:1
- 通过主从配置可以实现读写分离
简单配置
-
将主机redis的配置文件复印一份并重命名为:slave.conf(名字可自定义)
-
修改从机的redis配置文件vi slave.conf
-
编辑内容:
- bind 【主机指定ip】
- 添加:slaveof 【主机指定ip】 6379
- 修改port 6378
-
保存后,先运行主机redis,后运行从机redis;注意从机 会同时同步主机redis的数据,但是从机不可添加、修改、删除内容
更多笔记内容后续持续更新…