理论+实验——Redis常用命令

一、简介
1.1 非关系数据库产生背景

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

■ Redis 是完全开源的,遵守 BSD 协议,是一个高性能的 key-value 数据库。

■ Redis 与其他 key - value 缓存产品有以下三个特点:

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

1.3 Redis优势

性能极高 – Redis能读的速度是110000次/s,写的速度是81000次/s 。
丰富的数据类型 – Redis支持二进制案例的 Strings, Lists, Hashes, Sets 及 Ordered Sets 数据类型操作。
原子 – Redis的所有操作都是原子性的,意思就是要么成功执行要么失败完全不执行。单个操作是原子性的。多个操作也支持事务,即原子性,通过MULTI和EXEC指令包起来。
丰富的特性 – Redis还支持 publish/subscribe, 通知, key 过期等等特性。
支持数据库备份

部署Redis

    部署Redis

[root@localhost ~]# iptables -F			###清除防火墙规则
[root@localhost ~]# iptables -t nat -F			###清除防火墙表规则
[root@localhost ~]# setenforce 0			###关闭核心防护
[root@localhost ~]# yum -y install gcc gcc-c++ 		###安装gcc、gcc-c++环境包
将包上传到服务器
[root@localhost ~]# tar zxvf redis-5.0.7.tar.gz -C /opt/	###解压redis到opt目录下
[root@localhost ~]# cd /opt/redis-5.0.7/

[root@localhost redis-5.0.7]# make			###编译

[root@localhost redis-5.0.7]# make  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.log1	//日志文件路径
Data dir: /var/lib/redis/6379		//数据文件路径
Executable : /usr/local/redis/bin/redis-server   //可执行文件路径Cli Executable : /usr/local/bin/redis-cli		//客户端命令工具

	
[root@localhost utils]# netstat -anpt | grep redis		###查看一下redis启动了没
tcp        0      0 127.0.0.1:6379          0.0.0.0:*               LISTEN      6124/redis-server 1 


[root@localhost utils]# redis-cli -h 127.0.0.1 -p 6379	###连接本地数据库
127.0.0.1:6379> set name zhangsan		###创建一个name键,赋予一个zhangsan的值
OK
127.0.0.1:6379> get name			###输出name键的值
"zhangsan"
127.0.0.1:6379> quit       			 ###退出


[root@localhost utils]# vim /etc/redis/6379.conf 	###配置redis主配置文件
70行  bind 127.0.0.1 20.0.0.21			###监听20.0.0.21

[root@localhost utils]# /etc/init.d/redis_6379 stop	  ###关闭redis_6379服务
[root@localhost utils]# /etc/init.d/redis_6379 start	  ###开启redis_6379服务
		     /etc/init.d/redis_6379 restart ###重启redis_6379服务
		    /etc/init.d/redis_6379 status	  ###查看redis_6379服务状态
	

[root@localhost utils]# redis-cli -h 20.0.0.21 -p 6379 --raw	###连接远程数据库,加--raw可以解决中文乱码问题


20.0.0.21:6379> type name	###用type查看类型
string			###字符串类型

二、Redis数据类型

Redis支持五种数据类型: string(字符串)最常规的基础类型,hash(哈希)用来存储对象的(对象又包含多个属性和参数),list(列表)存的都是字符串的集合,set(集合)及zset(sorted set:有序集合)。
2.1 String (字符串)

string 是redis最基本的类型,你可以理解成与Memcached一模一样的类型,一个key对应一个value。
string类型是二进制安全的。
redis的string 可以包含任何数据。比如jpg图片或者序列化的对象。
string类型是Redis最基本的数据类型,string类型的值最大能存储512MB.
示例:
20.0.0.21:6379> set name zhangsan	###创建一个name键,值是zhangsan
OK
20.0.0.21:6379> get name		###查看name键的值
zhangsan

2.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 男	###创建一个stu对象,有姓名、年龄、性别值。一个对象当中包含多个key(键)和value(值)
OK
20.0.0.21:6379> hget stu name		###查看stu对象里的name键的值
lisi
20.0.0.21:6379> hget stu age
18
20.0.0.21:6379> hget stu sex
男

20.0.0.21:6379> keys *	###获取所有的符合规则的键值列表
stu
name

2.3 List(列表)

Redis列表是简单的字符串列表,按照插入顺序排序,可以重复。可以添加一个元素到列表的头部(左边)或者尾部(右边)。
列表最多可存储2的32次方 -1 元素。
/作用场景:
增删快,提供了操作某一段元素的APl 1,最新消息排行等功能(比如朋友圈的时间线)2,消息队列
20.0.0.21:6379> lpush hobby play	###创建一个hobby的列表名,和列表值	
1
20.0.0.21:6379> lpush hobby read
2
20.0.0.21:6379> lpush hobby sport
3
20.0.0.21:6379> lpush hobby sport
4
20.0.0.21:6379> lrange hobby 0 10	###查看hobby的的列表名,从0到10
sport
sport
read
play
20.0

数据从右往左取值 
存不进去显示0
可以存重复的数据

2.4 Set(集合-无序集合)

Redis的Set是string类型的无序集合。不能存储重复数据

集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是 0或1
//作用场景:
1、共同好友 2、利用唯一性,统计访问网站的所有独立ip 3、好友推荐时,根据tag求交集,大于某个阈值就可以推荐
示例:
20.0.0.21:6379> sadd color red green yellow	###创建一个color集合,有三个值
3
20.0.0.21:6379> smembers color		###查看color的值
yellow
green
red
20.0.0.21:6379> sadd color red 	 	###在重复创建一个值,显示0不能创建了!
0

Set(集合是)无序的,不能拿到指定信息
Set(集合)不能有重复数据
只要是集合当中就不能有重复数据

2.5 zset(sorted set:有序集合)

Redis zset和set一样也是string类型元素的集合,且不允许重复的成员。
不同的是每个元素都会关联一个double类型的分数。redis正是通过分数来为集合中的成员进行从小到大的排序。
zset的成员是唯一的,但分数(score)却可以重复。
//作用场景:
将Set中的元素增加一个权重参数score,元素按score有序排列
数据插入集合时,已经进行天然排序 1、排行榜2、带权重的消息队列
示例:
20.0.0.21:6379> ZADD co 0 red		###co结合名称,定义的分数、也可以是索引,然后是值
1
20.0.0.21:6379> ZADD co 0 blue
1
20.0.0.21:6379> ZADD co 0 green
1
20.0.0.21:6379> ZADD co 1 yellow
1
20.0.0.21:6379> zrangebyscore co 0 10	###利用co建立索引调用出来,起始位是0、结束位是10
blue
green
red
yellow
20.0.0.21:6379> zrangebyscore co 0 0
blue
green
red
20.0.0.21:6379> zrangebyscore co 1 1
yellow

三、多数据库概念

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

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

每个数据库对外都是一个从0开始的递增数字命名,Redis默认支持16个数据库(可以通过配置文件支持更多,无上限),可以通过配置databases来修改这一数字。客户端与Redis建立连接后会自动选择0号数据库,
不过可以随时使用SELECT命令更换数据库
示例:
20.0.0.21:6379> select 1		###切换到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		###高危命令,清空所有数据库的数据,0-15的数据库


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


20.0.0.21:6379[2]> select 1	  ###切换数据库,但每个库之间都是隔离的
OK

20.0.0.21:6379[2]> move stu 1	  ###用move数据库迁移,将stu库迁移到2库(0-15所以1是库2)
0

20.0.0.21:6379[2]> keys *	  ###查看库里的所有key值
name

四、key常规管理
4.1 验证key是否存在 exists

20.0.0.21:6379[2]> set name zhangsan	###创建一个name的name键,键里面放一个zhangsan值
OK
20.0.0.21:6379[2]> exists name	   ###查看name键存不存在,存在显示1,不存在显示0

4.2 重命名 rename

20.0.0.21:6379[2]> rename name na	   ###将name键改名成na
OK

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

192.168.195.180:6379> PEXPIRE na 3000	     ###设置na的键超时时间为3秒,三秒后就不存在
1
192.168.195.180:6379> get na

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

192.168.195.180:6379> PEXPIRE name 30000	###给name设置30秒
1
192.168.195.180:6379> PTTL name		###查看name剩余时间
22528

4.5 取消超时时间

192.168.195.180:6379> set name zhangsan
oK
192.168.195.180:6379>PEXPIRE name 50000
1
192.168.195.180:6379> PTTL name
44606
192.168.195.180:6379> PERSIST name
1
192.168.195.180:6379> PTTL name
-1
192.168.195.180:6379> get name
zhangsan

4.6 查看类型type

192.168.195.180:6379> lpush color red blue
2
192.168.195.180:6379> TYPE color
list
192.168.195.180:6379> set name zhangsan
oK
192.168.195.180:6379>TYPE name
string

4.7 随机返回key RANDOMKEY

192.168.195.180:6379> mset age 18 score 88 sex boy
oK
192.168.195.180:6379> RANDOMKEY
sex
192.168.195.180:6379> RANDOMKEY
color
192.168.195.180:6379> RANDOMKEY
sex

4.8 查看所有key

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值