redis非关系型数据库(缓存型数据库)——中间件

【重点】redis为什么这么快?(应届)

①redis是纯内存结构,避免磁盘I/O的耗时

②redis核心模块是一个单进程,减少线程切换和回收线程资源时间

③redis采用的是I/O的多路复用机制(每一个执行线路可以同时完成读、写),提升高并发效率(注:redis的读写仍然是单进程处理)

1、redis的服务控制命令

/etc/init.d/redis_6379 restart stop start status

2、redis的命令工具

redis-server:直接启动redis,只能启动

redis-benchmark:检测redis在本机的运行效果

redis-cli:命令行工具

redis-check-aof:检测AOF文件是否正常

redis-check-rdb:检测RDB文件是否正常

3、redis-benchmark语法

-h指定服务器的主机名(IP地址)

-p指定服务器的端口号6379

-c指定并发连接数

-n指定请求数

-a指定登录密码

redis非关系型数据库(缓存型数据库)——中间件_第1张图片

redis非关系型数据库(缓存型数据库)——中间件_第2张图片

4、登录redis

①方法1:redis-cli -h 20.0.0.14 -p 6379远程登录本机或别的服务器

②方法2:redis-cli直接使用,仅限于本地,远程登录仍需要指定目标服务器的IP地址

redis整个库

查看当前库中的键的数量

DBSIZE

切换库

SELECT 2

移动键值到指定库15

move guoqi1 15

设置密码

config set requirepass 123456

在外声明密码

redis-cli -h 20.0.0.14 -p 6379 -a 123456

在内声明密码

auth 123456

①查看当前库中的键的数量DBSIZE

redis非关系型数据库(缓存型数据库)——中间件_第3张图片

redis默认有16个库,第一个是0,最后一个是15,每个数据库之间互相独立、互不干扰

②切换库SELECT 2

③移动键值到指定库15

move guoqi1 15

redis非关系型数据库(缓存型数据库)——中间件_第4张图片

④设置密码config set requirepass 123456

redis非关系型数据库(缓存型数据库)——中间件_第5张图片

在内声明密码auth 123456

redis非关系型数据库(缓存型数据库)——中间件_第6张图片

在外声明密码redis-cli -h 20.0.0.14 -p 6379 -a 123456

redis非关系型数据库(缓存型数据库)——中间件_第7张图片

⑤删除当前库FLUSHDB(删库跑路!坐牢)

redis非关系型数据库(缓存型数据库)——中间件_第8张图片

⑥删除所有库FLUSHALL(删库跑路!坐牢)

redis非关系型数据库(缓存型数据库)——中间件_第9张图片

5、redis五大数据类型【重点】

1)string字符串类型——string

默认类型,最大存储512MB的数据,可以存储任何数据,比如数字、文字、图片等

string字符串类型

查看当前库的键值对

KEYS *

KEYS test

KEYS t*

KEYS t?

KEYS t??

创建string类型的键值对

set test guoqi

查看键值对

get test

判断键是否存在(返回1代表存在;返回0代表不存在)

EXISTS test

删除键

del test1 test2

查看键的类型

type test

追加键值

append test1 hello

查看键的长度

STRLEN test1

自增键值

自减键值

INCR test1

decr test1

给键值增加/减少指定数值

DECRBY test1 3

INCRBY test1 50

给键值设置过期时间

SETEX test2 15 lo

对已有键值对修改生命周期

EXPIRE test 30

批量设置键值对

MSET key1 hello key2 world

批量打印多个键值对

MGET key1 key2

对键重命名

RENAME test guoqi

①查看当前库的键值对KEYS test

redis非关系型数据库(缓存型数据库)——中间件_第10张图片

②创建键值对set test guoqi

③查看键值对get test

redis非关系型数据库(缓存型数据库)——中间件_第11张图片

redis非关系型数据库(缓存型数据库)——中间件_第12张图片

redis非关系型数据库(缓存型数据库)——中间件_第13张图片

④判断键值对test是否存在EXISTS test

redis非关系型数据库(缓存型数据库)——中间件_第14张图片

⑤删除键值对del test1 test2

redis非关系型数据库(缓存型数据库)——中间件_第15张图片

⑥查看键值对的类型type test

⑦追加键值append test1 hello

键已存在,会追加到原有键值后,返回拼接后键值的长度

键不存在,会创建键,直接将键值写入,返回当前键值长度

redis非关系型数据库(缓存型数据库)——中间件_第16张图片

redis非关系型数据库(缓存型数据库)——中间件_第17张图片

⑧查看键值长度STRLEN test1

⑨自增键值INCR test1

自减键值 decr test1

注:只能对数字进行操作

redis非关系型数据库(缓存型数据库)——中间件_第18张图片

⑩给键值增加/减少指定数值

DECRBY test1 3

INCRBY test1 50

redis非关系型数据库(缓存型数据库)——中间件_第19张图片

⑪给键值设置过期时间 SETEX test2 15 lo

redis非关系型数据库(缓存型数据库)——中间件_第20张图片

-2表示键值对已过期

-1表示键值对永不过期

⑫对已有键值对修改生命周期EXPIRE test 30

redis非关系型数据库(缓存型数据库)——中间件_第21张图片

⑬批量设置键值对

MSET key1 hello key2 world

⑭打印多个键值对

duMGET key1 key2

redis非关系型数据库(缓存型数据库)——中间件_第22张图片

⑮对键重命名RENAME test guoqi

redis非关系型数据库(缓存型数据库)——中间件_第23张图片

2)list列表类型——string

列表中的元素是string类型

list列表类型

创建list类型的键值对

lpush guoqi a b c d e f g

查看键值对

lrange guoqi 0 -1

查看某个键值对【下标索引】

lindex guoqi1 0

查看1-2范围内的键值对

【下标索引,从0开始】

lrange guoqi1 1 2

插入数值

lpush guoqi1 10插入左侧

rpush guoqi1 20插入右侧

删除数值

LPOP guoqi1

RPOP guoqi1

修改数值

LSET guoqi1 3 shuai

(根据下表索引,3代表下表索引)

指定数值前插入

LINSERT guoqi1 before 3 zhende

(3代表数值,不是下表索引)

①创建列表键值对

lpush guoqi a b c d e f g倒序

rpush guoqi a b c d e f g正序

redis非关系型数据库(缓存型数据库)——中间件_第24张图片

redis非关系型数据库(缓存型数据库)——中间件_第25张图片

②查看某个键值对lindex guoqi1 0

③查看1-2范围内的键值对lrange guoqi1 1 2

④插入数值

lpush guoqi1 10在左侧插入

rpush guoqi1 20在右侧插入

redis非关系型数据库(缓存型数据库)——中间件_第26张图片

⑤删除数值

LPOP guoqi1

RPOP guoqi1

redis非关系型数据库(缓存型数据库)——中间件_第27张图片

⑥修改数值

 LSET guoqi1 3 shuai(根据下表索引,3代表下表索引)

redis非关系型数据库(缓存型数据库)——中间件_第28张图片

⑦指定数值前插入LINSERT guoqi1 before 3 zhende(3代表数值,不是下表索引)

redis非关系型数据库(缓存型数据库)——中间件_第29张图片

3hash类型

hash类型用于存储对象,采用hash格式进行操作,占用磁盘空间少,一个hash类型可以存储4294967295个(42亿个)键值对

hash类型

创建hsah类型的键值对

HSET guoqi2 tall yes(tall代表字段类型)

查看键值对

hget guoqi2 tall

添加新字段

hset guoqi2 tall yes

删除字段

hdel guoqi2 hansdon tall

创建多个字段和数值

hmset guoqi3 tall rich age 23 fcz yes

查询字段

hgetall guoqi3

直接查询字段及数值

hkeys guoqi3

直接查询数值

hvals guoqi3

删除键值对

del guoqi3

①创建hsah类型的键值对

HSET guoqi2 tall yes

②添加新字段hset guoqi2 tall yes

③查看多个字段的内容hmget info name address iphone

④删除字段 hdel info iphone

redis非关系型数据库(缓存型数据库)——中间件_第30张图片

⑤创建多个字段和数值hmset guoqi3 tall rich age 23 fcz yes

redis非关系型数据库(缓存型数据库)——中间件_第31张图片

⑥查询字段及数值、直接查询字段、直接查询数值

hgetall guoqi3

hkeys guoqi3

hvals guoqi3

redis非关系型数据库(缓存型数据库)——中间件_第32张图片

⑦删除键值对del guoqi3

redis非关系型数据库(缓存型数据库)——中间件_第33张图片

4set无序集合类型——string

元素类型也是string,元素是唯一的,不允许重复,多个集合类型可以进行并集、交集、差集进行运算

使用场景:set中的元素类型是唯一的,可以跟踪一些唯一性数据,例如访问微博的用户名,只要把对应名称写入redis,set自动保存唯一性,方便下次访问

set无序集合类型

创建set类型的键值对

SADD myset a c

查看成员

SMEMBERS myset

查看当前集合中的元素是否存在

SISMEMBER myset a

随机返回集合中的一个元素

SRANDMEMBER myset

随机移除

SPOP myset

指定移除

SREM myset h k

①创建set类型键值 SADD myset a c

②查看成员SMEMBERS myset

redis非关系型数据库(缓存型数据库)——中间件_第34张图片

③查看当前集合中的元素是否存在SISMEMBER myset a

redis非关系型数据库(缓存型数据库)——中间件_第35张图片

④随机返回集合中的一个元素SRANDMEMBER myset

⑤随机移除SPOP myset

⑥指定移除 SREM myset h k

redis非关系型数据库(缓存型数据库)——中间件_第36张图片

5zset有序集合类型——string

元素类型也是string,元素唯一,不能重复。每个元素都会关联一个double类型(小数点)的分数(score,表示权重),可以通过权重的大小进行排序,元素的权重可以相同

使用场景:在线积分的排行榜,实时更新用户的分数

zrange命令获取积分top10的用户,zrank命令通过username获取用户的排行信息

zset有序集合类型

创建zset类型的键值

ZADD myzset 1 one

查看元素和权重

ZRANGE myzset 0 -1 withscores

查看成员的权重

ZSCORE myzset two

查询成员数量

ZCARD myzset

统计权重在1~2范围内的成员数量

ZCOUNT myzset 1 2

删除成员

ZREM myzset three

获取位置索引

ZRANK myzset one

①创建zset类型的键值ZADD myzset 1 one

②查看元素和权重ZRANGE myzset 0 -1 withscores

redis非关系型数据库(缓存型数据库)——中间件_第37张图片

③查看成员的权重ZSCORE myzset two

④获取位置索引 ZRANK myzset one

redis非关系型数据库(缓存型数据库)——中间件_第38张图片

⑤查询成员数量ZCARD myzset

⑥统计权重在1~2范围内的成员数量ZCOUNT myzset 1 2

⑦删除成员ZREM myzset three

redis非关系型数据库(缓存型数据库)——中间件_第39张图片

6、普通类型set和hash类型hset该如何选择?

一般情况下,无特殊需求时,普通创建方式即可;但对一个键值进行多字段存储及节省内存可以使用hash方式

你可能感兴趣的:(缓存,数据库,redis)