(简单易懂!)理论+实验——Redis(基本配置及常用命令)

一、关系数据库与非关系型数据库

■ 关系型数据库

  • 一个结构化的数据库,创建在关系模型基础上
  • 一般面向于记录
  • 包括
    ◆ Oracle、MySQL、SQL Server、Microsoft Access、DB2等

■ 非关系型数据库

  • 除了主流的关系型数据库外的数据库,都认为是非关系型
  • 包括
    ◆ Redis、MongBD、Hbase、CouhDB等

二、非关系型数据库产生背景

■ High performance——对数据库高并发读写需求
■ Huge Storage——对海量数据高效存储与访问需求
■ High Scalability && High Availability——对数据库高可扩展性与高可用性需求

三、Redis简介

■ Redis基于内存并支持持久化
■ 采用key-valus(键值对)的存储形式
■ 优点

  • 具有极高的数据读写速度
  • 支持丰富的数据类型
  • 支持数据的持久化
  • 原子性
  • 支持数据备份

在这里插入图片描述

四、实验

4.1 开局

iptables -F
setenforce 0
iptables -t nat -F
systemctl stop firewalld
yum -y install gcc gcc-c++ make

4.2 Redis安装

'将redis 数据库软件包 拖入 root  目录下
解压到opt目录下面'
[root@localhost ~]# tar zxvf redis-5.0.7.tar.gz -C /opt/   
[root@localhost ~]# cd /opt
[root@localhost opt]# ls
redis-5.0.7  rh
[root@localhost opt]# cd redis-5.0.7/     ###直接make,因为没有configure脚本
[root@localhost redis-5.0.7]# make
[root@localhost redis-5.0.7]# make prefix=/usr/local/redis install
[root@localhost redis-5.0.7]# cd utils/
[root@localhost utils]# ./install_server.sh    ##一直回车

Selected config:
Port           : 6379     ##端口号
Config file    : /etc/redis/6379.conf    ##配置文件路径
Log file       : /var/log/redis_6379.log  ##日志文件路径
Data dir       : /var/lib/redis/6379        ##数据文件路径
Executable     : /usr/local/bin/redis-server  ##执行服务脚本路径
Cli Executable : /usr/local/bin/redis-cli        ##客户端工具

[root@localhost utils]# netstat -ntap  | grep redis
tcp        0      0 127.0.0.1:6379          0.0.0.0:*               LISTEN      9236/redis-server 1 

'redis-benchmark测试工具
-h:指定服务器主机名
-p:指定服务器端口
-c:指定并发连接数
-n:指定请求数
-d:以字节的形式指定SET/GET值的数据大小
-q:强制退出Redis,仅显示query/sec值'

[root@localhost utils]# redis-cli  -h 127.0.0.1  -p  6379   
127.0.0.1:6379>   ##成功进入
127.0.0.1:6379> set  name zhangsan  ##写入一个数据
OK
127.0.0.1:6379> get name   ##查看key中的value
"zhangsan"
127.0.0.1:6379> exit      ##退出数据库
[root@localhost utils]# redis-cli  -h 20.0.0.21  -p  6379     ##切换主机登录

[root@localhost utils]# vim /etc/redis/6379.conf
bind 127.0.0.1  20.0.0.21  ##添加监听地址

[root@localhost utils]# /etc/init.d/redis_6379 stop    ##重启服务
Stopping ...
Redis stopped
[root@localhost utils]# /etc/init.d/redis_6379 start
Starting Redis server...

[root@localhost utils]# netstat -natp | grep redis
tcp        0      0 20.0.0.31:6379          0.0.0.0:*               LISTEN      9448/redis-server 1 
tcp        0      0 127.0.0.1:6379          0.0.0.0:*               LISTEN      9448/redis-server 1 

[root@localhost utils]# redis-cli  -h 20.0.0.21  -p  6379    ##登录成功

4.3 Redis数据类型

重点:
Redis支持五种数据类型:string(字符串)hash(哈希)list(列表)set(集合)zset(sorted set:有序集合)。

4.3.1 String(字符串)

string 是 redis 最基本的类型,你可以理解成与 Memcached 一模一样的类型,一个 key 对应一个 value。
string 类型是二进制安全的。redis 的 string 可以包含热和数据。比如jpg图片或序列化的对象。
string 类型是 Redis 最基本的数据类型,string 类型的值最大能存储 512MB。

示例:

20.0.0.21:6379> set name zhangsan
OK
20.0.0.21:6379> get name
"zhangsan"

4.3.2 Hash(哈希字典)

Redis hash 是一个键值(key=>value)对集合。
Redis hash 是一个 string 类型的 field 和 value 的映射表,hash 特别适用于存储对象。
每个 hash 可以存储 2的32次方 -1 键值对。
//作用场景:
键值对集合,即编程语言中的Map类型 适合存储对象,并且可以像数据库中update一个属性一样只修改某一项属性值

示例:

20.0.0.21:6379> hmset stu name lisi age 18 sex 男
OK
20.0.0.21:6379> hget stu name
"lisi"
20.0.0.21:6379> hget stu age
"18"
20.0.0.21:6379> hget stu sex
"\xe7\x94\xb7"

'###--raw:解决中文乱码问题###'
20.0.0.21:6379> quit
[root@localhost utils]# redis-cli -h 20.0.0.21 -p 6379 --raw
20.0.0.21:6379> hget stu sex
男

4.3.3 List(列表)

Redis 列表是简单的字符串列表,按照插入顺序排序,可以重复。可以添加一个元素到列表的头部(左边)或者尾部(右边)。
列表最多可存储 2的32次方 - 1 元素
//作用场景:
增删快,提供了操作某一段元素的API 1. 最新消息排行等功能(比如朋友圈的时间线)2. 消息队列
lrange:从下往上

示例:

20.0.0.21:6379> lpush hobby play
1
20.0.0.21:6379> lpush hobby read
2
20.0.0.21:6379> lpush hobby sport
3
20.0.0.21:6379> lrange hobby 0 10
sport
read
play
20.0.0.21:6379> lrange hobby 0 0
sport
20.0.0.21:6379> lrange hobby 1 1
read
20.0.0.21:6379> lrange hobby 2 2
play
20.0.0.21:6379> lpush hobby read
4
20.0.0.21:6379> lrange hobby 0 10
read
sport
read
play

4.3.4 Set(集合)

Redis 的 Set 是 string 类型的无序集合。

集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是0(1)。
//作用场景:
1、共同好友 2、利用唯一性,统计访问网站的所有独立ip 3、好友推荐时,根据tag求交集,大于某个阈值就可以推荐

sadd 命令
添加一个 string 元素到 key 对应的 set 集合中,成功返回 1,如果元素已经在集合中返回 0。

示例:

20.0.0.21:6379> sadd color red green yellow
3
20.0.0.21:6379> smembers color
green
yellow
red
20.0.0.21:6379> sadd color red
0

4.3.5 zset(sorted set:有序集合)

Redis zset 和 set 一样也是string类型元素的集合,且不允许重复的成员。
不同的是每个元素都会关联一个double类型的分数。redis正式通过分数来为集合中的长远进行从小到大的排序。
zset的成员是唯一的,但分数(score)却可以重复。

double:浮点型
//作用场景:
将Set中的元素增加一个权重参数score,元素按score有序排列
数据插入集合时,已经进行天然排序 1、排行榜 2、带权重的消息队列

zadd 命令
添加元素到集合,元素在集合中存在则更新对应score

示例:

20.0.0.21:6379> zadd score 0 red
1
20.0.0.21:6379> zadd score 0 blue
1
20.0.0.21:6379> zadd score 1 green
1
20.0.0.21:6379> zadd score 1 yellow
1
20.0.0.21:6379> zrangebyscore score 0 10
blue
red
green
yellow
20.0.0.21:6379> zrangebyscore score 0 0
blue
red
20.0.0.21:6379> zrangebyscore score 1 1
green
yellow
20.0.0.21:6379> zadd score 0.6 black
1
20.0.0.21:6379> zrangebyscore score 0 10
blue
red
black
green
yellow

4.4 多数据库概念

Redis支持多个数据库,并且每个数据库的数据是隔离的,不能共享,并且基于单机才有,如果是集群就没有数据库的概念。

Redis是一个字典结构的存储服务器,而实际上一个Redis实例提供了多个用来存储数据的字典,
客户端可以指定将数据存储在哪个字典中。这与我们熟知的在一个关系数据库实例中可以创建多个数据库类似,
所以可以将其中的每个字典都理解成一个独立的数据库。

每个数据库对都是一个从0开始的递增数字命名,Redis默认支持16个数据库(可以哦谈过配置文件支持更多,无上限),
可以通过配置daatabases来修改这一数字。客户端与Redis建立连接后会自动选择0号数据库,
不过可以随时使用SELECT命令更换数据库,如要选择1号数据库:

示例:

20.0.0.21:6379> select 1
OK
20.0.0.21:6379[1]> set name zhangsan
OK
20.0.0.21:6379[1]> select 2
OK
20.0.0.21:6379[2]> set name zhangsan
OK

//清空所有数据库数据

20.0.0.21:6379[2]> FLUSHALL
OK

20.0.0.21:6379[2]> get name

20.0.0.21:6379[2]> SELECT 1
OK
20.0.0.21:6379[1]> get name

20.0.0.21:6379> keys *
color
hobby
name
stu

select 1:切换到了第二个数据库
默认16个库,不共享,0-15
select:切库
move:转移

//数据迁移:

20.0.0.21:6379> move stu 1
1
20.0.0.21:6379> keys *
color
hobby
name
20.0.0.21:6379> select 1
OK
20.0.0.21:6379[1]> keys *
stu

FLUSHALL:清空所有库 (慎用)
注意:
Redis不支持自定义数据库的名字,每个数据库都以编号命名,开发者必须自己记录哪些数据库存储了哪些数据。
另外Redis也不支持为每个数据库设置不同的访问密码,所以一个客户端要么可以访问全部数据库,
要么连一个数据库也没有权限访问。最重要的一点是多个数据库之间并不是完全隔离的,
比如FLUSHALL命令可以清空一个Redis实例中所有数据库中的数据。
综上所述,这些数据库更像是一种命名空间,而不适宜存储不同应用程序的数据。
作用场景:
可以使用0号数据库存储某个应用生产环境中的数据,使用1号数据库存储测试环境中的数据,
但不适宜使用0号数据库存储A应用的数据而是用1号数据库B应用的数据,不同的应用应该使用不同的Redis实例存储数据。
由于Redis非常轻量级,一个空Redis实例占用的内存只有1M左右,所以不用担心多个Redis实例会额外占用很多内存。

4.5 key常规管理

//验证key是否存在 exists

20.0.0.21:6379> set name zhangsan
OK
20.0.0.21:6379> exists name
1
20.0.0.21:6379> exists names
0

//重命名 rename

20.0.0.21:6379> rename name na
OK
20.0.0.21:6379> get na
zhangsan

//设置超时时间 PEXPIRE (单位:毫秒)

20.0.0.21:6379> PEXPIRE na 30
1
20.0.0.21:6379> get na

//查看剩余时间 PTTL (单位:毫秒)

20.0.0.21:6379> set na zhangsan
OK
20.0.0.21:6379> get na
zhangsan
20.0.0.21:6379> PEXPIRE na 30000
1
20.0.0.21:6379> PTTL na
21394

//PTTL names:-1 永久不超时

//取消超时时间

20.0.0.21:6379> set name zhangsan
OK
20.0.0.21:6379> get name
zhangsan
20.0.0.21:6379> PEXPIRE name 500000
1
20.0.0.21:6379> PTTL name
495552
20.0.0.21:6379> PERSIST name
1
20.0.0.21:6379> PTTL name
-1
20.0.0.21:6379>  get name
zhangsan

//设置超时时间:是一种优化,释放内存空间

//查看类型 type

20.0.0.21:6379> lpush color red blue
2
20.0.0.21:6379> TYPE color
list
20.0.0.21:6379> set bane zhangsan
OK
20.0.0.21:6379> type name
string

//随机返回key RANDOMKEY

20.0.0.21:6379> mset age 18 score 88 sex boy
OK
20.0.0.21:6379> RANDOMKEY
sex
20.0.0.21:6379> RANDOMKEY
color
20.0.0.21:6379> RANDOMKEY
sex
20.0.0.21:6379> RANDOMKEY
score

//查看所有key

20.0.0.21:6379> KEYS *
name
sex
score
color
age
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值