Redis

本文详细介绍了Redis的基础知识,包括Redis的入门、NoSQL概念、Redis的安装与启动、常用命令行客户端、数据结构(如String、Hash)以及Key的层级格式。还探讨了Redis作为键值型NoSQL数据库的特性和优势,如单线程、原子性操作、数据持久化等。
摘要由CSDN通过智能技术生成

Reids

第一部分:基础篇

1.Redis入门课程介绍

  • 认识Redis
    • 认识NoSQL
    • 认识Redis
    • 安装Redis
  • Redis常见命令
    • 5种常见数据结构
    • 通用命令
    • 不同数据结构的操作命令
  • Redis的Java客户端
    • Jedis客户端
    • SpringDataRedis客户端

2.认识NoSQL

SQLNoSQL
数据结构结构化(Structured)非结构化
数据关联关联的(Relational)无关联的
查询方式SQL查询非SQL
事务特性ACIDBASE
存储方式磁盘内存
扩展性垂直水平
使用场景1.数据结构固定;2.相关业务对数据安全性、一致性要求较高1.数据结构不固定;2.对一致性、安全性要求不高;3.对性能要求

非结构化分类

键值类型(Redis)、文档类型(Mongo)、列类型(HBase)、Graph类型(Neo4j)

3.认识Redis

认识Redis

Redis诞生于2009年全称是Remote Dictionary Server,远程词典服务器,是一个基于内存的键值型NoSQL数据库。

特性

  • 键值(Key-Value)型,value支持多种不同数据结构,功能丰富
  • 单线程,每个命令具备原子性
  • 低延迟、速度快(基于内存、IO多路复用、良好编码)
  • 支持数据持久化
  • 支持主从集群、分片集群
  • 支持多语言客户端

4.安装Redis及启动

1.单机安装Redis
1.1.安装Redis依赖
Redis是基于C语言编写的,因此首先需要安装Redis所需要的gcc依赖:
yum install -y gcc tcl
1.2.上传安装包并解压,放到/usr/local/src目录
redis-6.2.6.tar.gz
1.3.解压
tar -zxvf redis-6.2.6.tar.gz
cd redis-6.2.6/
运行编译命令:make && make install
1.3.1.默认启动:redis-server

1.3.2.指定配置启动
如果要让Redis以后台方式启动,则必须修改Redis配置文件,就在我们之前解压的redis安装包下(/usr/loacl/src/redis-6.2.6),名字叫redis.conf;
我们先将这个配置文件备份一份:
cp redis.conf redis.conf.bck

修改redis.conf

# 运行访问的地址,默认是127.0.0.1,会导致只能在本地访问,修改为0.0.0.0则可以在任意IP访问,生产环境不要设置为0.0.0.0
bing 0.0.0.0

# 守护进程,修改为yes后即可后台运行
daemonize yes

# 密码 设置后访问redis必须输入密码
requirepass 123321

# 监听的端口
port 6379

# 工作目录,默认是当前目录,也就是运行redis-server时的命令、日志、持久化等文件保存在这个目录:
dir .

# 数据库数量,设置为1,代表只使用1个库,默认有16个库,编号0-15
database 1

# 设置redis能够使用的最大内存
maxmemory 512mb

# 日志文件,默认为空,不记录日志,可以指定日志文件名
logfile "redis.log"

启动Redis

# 进入redis安装目录
cd /usr/local/src/redis-6.2.6
# 启动
redis-server redis.conf
# 查看是否启动成功
ps -ef | grep redis
# 停止redis
kill -9 14821

1.3.3.开机自启

我们也可以通过配置来实现开机自启

首先,新建一个系统服务文件:

vi /etc/systemd/system/redis.service
[Unit]
Description=redis-server
After=network.target

[Service]
Type=forking
ExecStart=/usr/local/bin/redis-server /usr/local/src/redis-6.2.6/redis.conf
PrivateTmp=true

[Install]
WantedBy=multi-user.target
# 然后重载系统服务
systemctl daemon-reload

5.Redis命令行客户端

Redis安装完成后就自带了命令行客户端:redis-cli,使用方式如下:

redis-cli [options] [commonds]

其中常见的options有:

  • -h 127.0.0.1:指定要连接redis节点的IP地址,默认是127.0.0.1
  • -p 6379:指定要连接的redis节点的端口,默认是6379
  • -a 123321:指定redis的访问密码

其中commonds就是redis的操作命令,例如:

  • ping:与redis服务端做心跳测试,服务端正常会返回pong

6.Redis图形化界面

7.数据结构介绍

8.通用命令

通用指令是部分数据类型的,都可以使用的指令,常见的有:

  • keys:查看符合模板的所有key,不建议在生产环境设备上使用
  • del:删除一个指定的key
  • EXISTS:判断key是否存在
  • EXPIRE:给一个key设置有效期,有效期到期时期该key会被自动删除
  • TTL:查看一个KEY的剩余有效期
127.0.0.1:6379> mset k1 v1 k2 v2 k3 v3
OK
127.0.0.1:6379> keys *
1) "k2"
2) "k1"
3) "k3"
127.0.0.1:6379> del k1 k2 k3 k4
(integer) 3
127.0.0.1:6379> exists age
(integer) 0
127.0.0.1:6379> expire age 20
(integer) 0
127.0.0.1:6379> set age 1
OK
127.0.0.1:6379> expire age 20
(integer) 1
127.0.0.1:6379> ttl age
(integer) -2
127.0.0.1:6379> keys *
(empty array)
127.0.0.1:6379> set age 18
OK
127.0.0.1:6379> ttl age
(integer) -1
127.0.0.1:6379> 

9.String类型

String类型,也就是字符串类型,是Redis中最简单的存储类型

其value是字符串,不过根据字符串的格式不同,又可以分为3类:

  • string:普通字符串
  • int:整数类型,可以做自增、自减操作
  • float:浮点类型,可以做自增、自减操作

不管是哪种格式,底层都是字节数组形式存储,只不过是编码方式不同。字符串类型的最大空间不能超过512m。

KEYVALUE
msghello world
num10
score92.5

String类型常见命令

  • SET:添加或者修改已经存在的一个String类型的键值对
  • GET:根据key获取String类型的value
# 当key值一样,value值会被覆盖
127.0.0.1:6379> set name Rose
OK
127.0.0.1:6379> get name
"Rose"
127.0.0.1:6379> set name Jack
OK
127.0.0.1:6379> get name
"Jack"
  • MSET:批量添加多高String类型的键值对
  • MGET:根据多个key获取多个String类型的value
127.0.0.1:6379> mset k1 v1 k2 v2 k3 v3
OK
127.0.0.1:6379> mget name age k1 k2 k3
1) "Jack"
2) "18"
3) "v1"
4) "v2"
5) "v3"
  • INCR:让一个整型的key自增1
  • INCRBY:让一个整型的key自增并指定步长,例如:incrby num 2让num值自增2
  • INCRBYFLOAT:让一个浮点类型的数字自增并指定步长
127.0.0.1:6379> get age
"18"
127.0.0.1:6379> incr age
(integer) 19
127.0.0.1:6379> incr age
(integer) 20
127.0.0.1:6379> incr age
(integer) 21
127.0.0.1:6379> incrby age 2
(integer) 23
127.0.0.1:6379> incrby age 2
(integer) 25
127.0.0.1:6379> incrby age 2
(integer) 27
127.0.0.1:6379> incrby age -1
(integer) 26
127.0.0.1:6379> incrby age -1
(integer) 25
127.0.0.1:6379> incrby age -1
(integer) 24
127.0.0.1:6379> incrby age -1
(integer) 23
127.0.0.1:6379> set score 10.1
OK
127.0.0.1:6379> incrbyfloat score 0.5
"10.6"
127.0.0.1:6379> incrbyfloat score 0.5
"11.1"
127.0.0.1:6379> incrbyfloat score 0.5
"11.6"
  • SETNX:添加一个String类型的键值对,前提是这个key不存在,否则不执行
127.0.0.1:6379> setnx name lisi
(integer) 0
127.0.0.1:6379> get name
"Jack"
127.0.0.1:6379> setnx name2 lisi
(integer) 1
127.0.0.1:6379> get name2
"lisi"
  • SETEX:添加一个String类型的键值对,并且指定有效期
127.0.0.1:6379> setex name 10 jack
OK
127.0.0.1:6379> ttl name
(integer) 0

10.key的层级格式

思考

Redis没有类似MySQL中的Table的概念,我们该如何区分不同类型的key呢?

例如:需要存储用户、商品信息到redis,有一个用户id是1,有一个商品id恰好也是1

key的机构

Redis的key允许有多个单词形成层级结构,多个单词之间用":"隔开,格式如下:

项目名:业务名:类型:id

这个格式并非固定,也可以根据自己的需求来删除或添加词条。

例如我们的项目名称叫heima,有user和product两种不同类型的数据,我们可以这样定义key:

  1. user相关的key:heima:user:1
  2. product相关的key:heima:product:1
127.0.0.1:6379> set heima:user:1 '{"id":1, "name":"Jack", "age": 21}'
OK
127.0.0.1:6379> set heima:user:2 '{"id":2, "name":"Rose", "age": 18}'
OK
127.0.0.1:6379> set heima:product:1 '{"id":1, "name":"小米11", "price": 4999}'
OK
127.0.0.1:6379> set heima:product:2 '{"id":2, "name":"荣耀6", "price": 2999}'
OK

Hash类型

Hash类型,也叫散列,其value是一个无序字典,类似于Java中的HashMap结构

String结构是将对象序列化为JSON字符串后存储,当需要修改对象某个字段时很不方便

keyvalue
heima:user:1{name:“Jack”,age:21}
heima:user:2{name:“Rose”,age:18}

Hash结构可以将对象中的每个字段独立存储,可以针对单个字段做CRUD

keyvalue
fieldvalue
heima:user:1nameJack
age21
heima:user:2nameRose
age18

Hash类型的常见命令

  • hset key field value:添加或者修改hash类型key的field的值
  • hget key field:获取一个hash类型key的field的值
  • hmset:批量添加多个hash类型key的field的值
  • hmget:批量获取多个hash类型key的field的值
  • hgetall:获取一个hash类型的key中的所有的field和value
  • hkeys:获取一个hash类型的key中的所有的field
  • hvals:获取一个hash类型的key中的所有的value
  • hincrby:让一个hash类型key的字段值自增并指定步长
  • hsetnx:添加一个hash类型的key的field值,前提是这个field不存在,否则不执行

第二部分:实战篇

第三部分:高级篇

第四部分:原理篇

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

coder-N

踏实 勤奋 努力 拼搏

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值