Redis笔记

记录键值数据库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 缓存产品有以下三个特点:

  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开启命令,出现以下图片情况表示成功。在这里插入图片描述

可以使用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类型:

  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. 元素具有唯⼀性,不重复

添加元素:

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

  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

删除指定元素:

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服务)

  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的数据,但是从机不可添加、修改、删除内容


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

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值