天天看点

Redis笔记Redis介绍服务端与客户端命令数据操作与Python交互主从小结

记录键值数据库Redis命令笔记,以便后续使用查看。

redis中文文档:http://redis.cn/commands.html

目录

  • Redis介绍
    • nosql概念介绍
    • 简介
    • 特性
    • 优势
  • 服务端与客户端命令
    • 服务端
  • 数据操作
    • String
    • 键命令
    • hash
    • list
    • set
    • zset
  • 与Python交互
  • 主从小结
    • 概念
    • 简单配置

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 缓存产品有以下三个特点:

  1. Redis支持数据的持久化,可以将内存中的数据保存在磁盘中,重启的 时候可以再次加载进行使用。
  2. Redis不仅仅支持简单的key-value类型的数据,同时还提供list,set, zset,hash等数据结构的存储。
  3. Redis支持数据的备份,即master-slave模式的数据备份。

优势

  1. 性能极高 – Redis能读的速度是110000次/s,写的速度是81000次/s 。
  2. 丰富的数据类型 – Redis支持二进制案例的 Strings, Lists, Hashes, Sets 及 Ordered Sets 数据类型操作。
  3. 原子 – Redis的所有操作都是原子性的,同时Redis还支持对几个操作全并后的原子性执行。
  4. 丰富的特性 – Redis还支持 publish/subscribe, 通知, key 过期等等特性。

服务端与客户端命令

服务端

  这里使用windows10系统操作redis数据库;

开启服务端命令:(若没有配置环境变量需先cd切换到下载redis的存放目录下)

  1. windows:redis-server.exe redis.windows.conf
  2. linux:redis-server “/…/…/redis.conf” (…代表指定的目录路径)

输入windows服务器的redis开启命令,出现以下图片情况表示成功。

Redis笔记Redis介绍服务端与客户端命令数据操作与Python交互主从小结

可以使用help查看帮助文档

redis-server help
           

客户端命令: redis-cli [-h(指定连接redis数据库ip) -p(指定端口)]

可以使⽤help查看帮助⽂档

redis-cli --help
           

连接本地redis数据库命令:

Redis笔记Redis介绍服务端与客户端命令数据操作与Python交互主从小结

运行测试命令:ping(若出现PONG则为正常)

Redis笔记Redis介绍服务端与客户端命令数据操作与Python交互主从小结

切换数据库,数据库没有名称,默认有16个,通过0-15来标识,连接redis默认选择第一个数据库:

select 10
           
Redis笔记Redis介绍服务端与客户端命令数据操作与Python交互主从小结

数据操作

String

设置值:

set key value
           

设置值以及过期时间:

setex key seconds value
           

设置值以及过期时间:

追加内容:

append key value
           

获取键的值:

get key
           

获取多个值:

键命令

查看所有键值对:

删除对应的键值对数据:

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
           

设置多个属性:

获取指定键所有的属性:

hkeys 对象名
           

获取一个字段的值:

hget key field
           

获取多个字段的值:

例:获取键u2属性’name’、'age的值:

hmget u2 name age
           

获取所有属性的值:

hvals key
           

删除属性的值:

hdel key field
           

list

list类型:

  1. 列表的元素类型为string
  2. 按照插入顺序排序

在左侧插⼊数据: insert(0, item)

lpush key value1 value2
           

在右侧插⼊数据: append(item)

rpush key value1 value2
           

返回列表⾥指定范围内的元素:

  1. start、stop为元素的下标索引
  2. 索引从左侧开始,第⼀个元素为0
  3. 索引可以是负数,表示从尾部开始计数,如-1表示最后⼀个元素
lrange key start stop
           

在指定元素的前或后插⼊新元素:

linsert key before或after 现有元素 新元素
           

设置指定索引位置的元素值:

  1. 索引从左侧开始,第⼀个元素为0
  2. 索引可以是负数,表示尾部开始计数,如-1表示最后⼀个元素
lset key index value
           

删除指定元素:

  1. 将列表中前count次出现的值为value的元素移除
  2. count > 0: 从头往尾移除
  3. count < 0: 从尾往头移除
  4. 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类型:说明:对于集合没有修改操作

  1. ⽆序集合
  2. 元素为string类型
  3. 元素具有唯⼀性,不重复

添加元素:

例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类型:有序的集合(说明:没有修改操作)

  1. sorted set,有序集合
  2. 元素为string类型
  3. 元素具有唯⼀性,不重复
  4. 每个元素都会关联⼀个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
           

返回所有的元素:

  1. 返回指定范围内的元素
  2. start、stop为元素的下标索引
  3. 索引从左侧开始,第⼀个元素为0
  4. 索引可以是负数,表示从尾部开始计数,如-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
           

删除指定元素:

例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数据库

  • 导入模块
  • 创建redis数据库对象()

    decode_responses=True :按照utf8的格式将

    bytes

    类型数据转换成

    字符串

  • 执行redis命令
sr.set(key,value)
sr.get(key)
sr.delete(key)
           

注意:操作redis服务端时的命令与Python操作redis数据库时的命令大致相同,唯有服务端中的del删除命令在Python内变成delete即可。

主从小结

概念

master和slave都是一个redis实例(redis服务)

  1. ⼀个master可以拥有多个slave,⼀个slave⼜可以拥有多个slave,如此下去,形成了强⼤的多级服务器集群架构
  2. master用来写数据,slave用来读数据,经统计:网站的读写比率是10:1
  3. 通过主从配置可以实现读写分离

简单配置

  1. 将主机redis的配置文件复印一份并重命名为:slave.conf(名字可自定义)
  2. 修改从机的redis配置文件vi slave.conf
  3. 编辑内容:
    • bind 【主机指定ip】
    • 添加:slaveof 【主机指定ip】 6379
    • 修改port 6378
  4. 保存后,先运行主机redis,后运行从机redis;注意从机 会同时同步主机redis的数据,但是从机不可添加、修改、删除内容

更多笔记内容后续持续更新…