Redis 基础应用

发布时间:2020-04-19 22:53:44 作者:逐梦小涛
来源:网络 阅读:823

Redis 基础应用(一)

==============================================================================

概述:

==============================================================================

Redis简介

 1.简介

Redis

REmote DIctionary Server(Redis)

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

 2.功能

支持的功能如下:

数据结构服务器:

单进程

持久化机制

Replication

 主从:

 3.优势

优势

 4.Redis与其他key-value存储有什么不同

区别:

和memcached的区别

redis、memcache、mongoDB 对比
从以下几个维度,对redis、memcache、mongoDB 做了对比,欢迎拍砖
性能

操作的便利性

内存空间的大小和数据量的大小

可用性(单点问题)
对于单点问题

可靠性(持久化)
对于数据持久化和数据恢复,

数据一致性(事务支持)

数据分析

应用场景

Redis安装及数据结构

 1.安装及程序环境

安装方法:

程序环境

配置文件

主程序

命令行客户端

演示:

1.安装程序包

# 配置好epel仓库
[root@centos7 ~]# yum install redis

2.程序环境如下:

[root@centos7 ~]# rpm -ql redis
/etc/logrotate.d/redis
/etc/redis-sentinel.conf
/etc/redis.conf
/etc/systemd/system/redis-sentinel.service.d
/etc/systemd/system/redis-sentinel.service.d/limit.conf
/etc/systemd/system/redis.service.d
/etc/systemd/system/redis.service.d/limit.conf
/usr/bin/redis-benchmark
/usr/bin/redis-check-aof
/usr/bin/redis-check-rdb
/usr/bin/redis-cli
/usr/bin/redis-sentinel
/usr/bin/redis-server
/usr/bin/redis-shutdown
/usr/lib/systemd/system/redis-sentinel.service
/usr/lib/systemd/system/redis.service
/usr/lib/tmpfiles.d/redis.conf
/usr/share/doc/redis-3.2.3
/usr/share/doc/redis-3.2.3/00-RELEASENOTES
/usr/share/doc/redis-3.2.3/BUGS
/usr/share/doc/redis-3.2.3/CONTRIBUTING
/usr/share/doc/redis-3.2.3/MANIFESTO
/usr/share/doc/redis-3.2.3/README.md
/usr/share/licenses/redis-3.2.3
/usr/share/licenses/redis-3.2.3/COPYING
/var/lib/redis
/var/log/redis
/var/run/redis

3.配置文件/etc/redis.conf 如下:

# 备份
[root@centos7 ~]# cp /etc/redis.conf{,.bak}
 
[root@centos7 ~]# grep "^##" /etc/redis.conf
################################## INCLUDES ###################################
################################## NETWORK #####################################
################################# GENERAL #####################################
################################ SNAPSHOTTING  ################################
################################# REPLICATION #################################
################################## SECURITY ###################################
################################### LIMITS ####################################
############################## APPEND ONLY MODE ###############################
################################ LUA SCRIPTING  ###############################
################################ REDIS CLUSTER  ###############################
################################## SLOW LOG ###################################
################################ LATENCY MONITOR ##############################
############################# EVENT NOTIFICATION ##############################
############################### ADVANCED CONFIG ###############################

[root@centos7 ~]# vim /etc/redis.conf
 bind 0.0.0.0  # 修改绑定的端口
 
# 启动 redis,查看坚挺的端口 6379
[root@centos7 ~]# systemctl start redis
[root@centos7 ~]# ss -tnlp |grep "redis"
LISTEN     0      128          *:6379                     *:*                   users:(("redis-server",pid=3840,fd=4))

 3.命令行客户端命令

redis-cli

语法:

常用选项:

演示:

1.本地连接,直接运行 redis-cli 命令即可

[root@centos7 ~]# redis-cli
127.0.0.1:6379> ping
PONG

2.远程连接,指明要连接的主机,端口和密码即可

[root@centos7 ~]# redis-cli -h 192.168.1.112
192.168.1.112:6379> ping
PONG

192.168.1.112:6379> help  # 获取帮助
redis-cli 3.2.3
To get help about Redis commands type:
      "help @<group>" to get a list of commands in <group>
      "help <command>" for help on <command>
      "help <tab>" to get a list of possible help topics
      "quit" to exit

To set redis-cli perferences:
      ":set hints" enable online hints
      ":set nohints" disable online hints
Set your preferences in ~/.redisclirc

Redis:k/v

 1.k/v 和 group

k/v

group

 2.string(字符串)

作用:

基本语法:

演示:

192.168.1.112:6379> SET count 1
OK
192.168.1.112:6379> GET count
"1"
192.168.1.112:6379> INCR count
(integer) 2
192.168.1.112:6379> INCR count
(integer) 3
192.168.1.112:6379> INCR count
(integer) 4
192.168.1.112:6379> INCR count
(integer) 5
192.168.1.112:6379> DECR count
(integer) 4
192.168.1.112:6379> DECR count
(integer) 3
192.168.1.112:6379> DECR count
(integer) 2
192.168.1.112:6379> DECR count
(integer) 1

下表列出了常用的 redis 字符串命令:

序号命令及描述
1SET key value 
设置指定 key 的值
2GET key 
获取指定 key 的值。
3GETRANGE key start end 
返回 key 中字符串值的子字符
4GETSET key value
将给定 key 的值设为 value ,并返回 key 的旧值(old value)。
5GETBIT key offset
对 key 所储存的字符串值,获取指定偏移量上的位(bit)。
6MGET key1 [key2..]
获取所有(一个或多个)给定 key 的值。
7SETBIT key offset value
对 key 所储存的字符串值,设置或清除指定偏移量上的位(bit)。
8SETEX key seconds value
将值 value 关联到 key ,并将 key 的过期时间设为 seconds (以秒为单位)。
9SETNX key value
只有在 key 不存在时设置 key 的值。
10SETRANGE key offset value
用 value 参数覆写给定 key 所储存的字符串值,从偏移量 offset 开始。
11STRLEN key
返回 key 所储存的字符串值的长度。
12MSET key value [key value ...]
同时设置一个或多个 key-value 对。
13MSETNX key value [key value ...] 
同时设置一个或多个 key-value 对,当且仅当所有给定 key 都不存在。
14PSETEX key milliseconds value
这个命令和 SETEX 命令相似,但它以毫秒为单位设置 key 的生存时间,而不是像 SETEX 命令那样,以秒为单位。
15INCR key
将 key 中储存的数字值增一。
16INCRBY key increment
将 key 所储存的值加上给定的增量值(increment) 。
17INCRBYFLOAT key increment
将 key 所储存的值加上给定的浮点增量值(increment) 。
18DECR key
将 key 中储存的数字值减一。
19DECRBY key decrement
key 所储存的值减去给定的减量值(decrement) 。
20APPEND key value
如果 key 已经存在并且是一个字符串, APPEND 命令将 value 追加到 key 原来的值的末尾。

 3.list(列表)

作用

演示:

192.168.1.112:6379> RPUSH mylist "mon"
(integer) 1
192.168.1.112:6379> LINDEX mylist 0
"mon"
192.168.1.112:6379> RPUSH mylist "tun"
(integer) 2
192.168.1.112:6379> LPUSH mylist "sun"
(integer) 3
192.168.1.112:6379> LINDEX mylist 0
"sun"
192.168.1.112:6379> LINDEX mylist 0
"sun"
192.168.1.112:6379> LINDEX mylist 1
"mon"
192.168.1.112:6379> LINDEX mylist 2
"tun"
192.168.1.112:6379> RPOP mylist
"tun"
192.168.1.112:6379> LLEN mylist
(integer) 2

下表列出了列表相关的基本命令:

序号命令及描述
1BLPOP key1 [key2 ] timeout 
移出并获取列表的第一个元素, 如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止。
2BRPOP key1 [key2 ] timeout 
移出并获取列表的最后一个元素, 如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止。
3BRPOPLPUSH source destination timeout 
从列表中弹出一个值,将弹出的元素插入到另外一个列表中并返回它; 如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止。
4LINDEX key index 
通过索引获取列表中的元素
5LINSERT key BEFORE|AFTER pivot value 
在列表的元素前或者后插入元素
6LLEN key 
获取列表长度
7LPOP key 
移出并获取列表的第一个元素
8LPUSH key value1 [value2] 
将一个或多个值插入到列表头部
9LPUSHX key value 
将一个或多个值插入到已存在的列表头部
10LRANGE key start stop 
获取列表指定范围内的元素
11LREM key count value 
移除列表元素
12LSET key index value 
通过索引设置列表元素的值
13LTRIM key start stop 
对一个列表进行修剪(trim),就是说,让列表只保留指定区间内的元素,不在指定区间之内的元素都将被删除。
14RPOP key 
移除并获取列表最后一个元素
15RPOPLPUSH source destination 
移除列表的最后一个元素,并将该元素添加到另一个列表并返回
16RPUSH key value1 [value2] 
在列表中添加一个或多个值
17RPUSHX key value 
为已存在的列表添加值

 4.set(集合)

作用:

演示:

192.168.1.112:6379> SADD s1 'a' 'b' 'c'
(integer) 3
192.168.1.112:6379> SMEMBERS s1
1) "c"
2) "b"
3) "a"
192.168.1.112:6379> SISMEMBER s1 'a'
(integer) 1
192.168.1.112:6379> SISMEMBER s1 'c'
(integer) 1
192.168.1.112:6379> SISMEMBER s1 'd'
(integer) 0
192.168.1.112:6379> SADD s2 'a' 'c' 'd' 'f'
(integer) 4
192.168.1.112:6379> SINTER s1 s2
1) "c"
2) "a"
192.168.1.112:6379> SUNION s1 s2
1) "f"
2) "a"
3) "b"
4) "d"
5) "c"

下表列出了 Redis 集合基本命令:

序号命令及描述
1SADD key member1 [member2] 
向集合添加一个或多个成员
2SCARD key 
获取集合的成员数
3SDIFF key1 [key2] 
返回给定所有集合的差集
4SDIFFSTORE destination key1 [key2] 
返回给定所有集合的差集并存储在 destination 中
5SINTER key1 [key2] 
返回给定所有集合的交集
6SINTERSTORE destination key1 [key2] 
返回给定所有集合的交集并存储在 destination 中
7SISMEMBER key member 
判断 member 元素是否是集合 key 的成员
8SMEMBERS key 
返回集合中的所有成员
9SMOVE source destination member 
将 member 元素从 source 集合移动到 destination 集合
10SPOP key 
移除并返回集合中的一个随机元素
11SRANDMEMBER key [count] 
返回集合中一个或多个随机数
12SREM key member1 [member2] 
移除集合中一个或多个成员
13SUNION key1 [key2] 
返回所有给定集合的并集
14SUNIONSTORE destination key1 [key2] 
所有给定集合的并集存储在 destination 集合中
15SSCAN key cursor [MATCH pattern] [COUNT count] 
迭代集合中的元素

 5.hash(哈希)

作用:

演示:

192.168.1.112:6379> HSET h2 name taotao
(integer) 1
192.168.1.112:6379> HSET h2 age 25
(integer) 1
192.168.1.112:6379> HGETALL h2
1) "name"
2) "taotao"
3) "age"
4) "25"
192.168.1.112:6379> HKEYS h2
1) "name"
2) "age"
192.168.1.112:6379> HVALS h2
1) "taotao"
2) "25"
192.168.1.112:6379> HGET h2 name
"taotao"
192.168.1.112:6379> HGET h2 age
"25"

下表列出了 redis hash 基本的相关命令:

序号命令及描述
1HDEL key field2 [field2] 
删除一个或多个哈希表字段
2HEXISTS key field 
查看哈希表 key 中,指定的字段是否存在。
3HGET key field 
获取存储在哈希表中指定字段的值。
4HGETALL key 
获取在哈希表中指定 key 的所有字段和值
5HINCRBY key field increment 
为哈希表 key 中的指定字段的整数值加上增量 increment 。
6HINCRBYFLOAT key field increment 
为哈希表 key 中的指定字段的浮点数值加上增量 increment 。
7HKEYS key 
获取所有哈希表中的字段
8HLEN key 
获取哈希表中字段的数量
9HMGET key field1 [field2] 
获取所有给定字段的值
10HMSET key field1 value1 [field2 value2 ] 
同时将多个 field-value (域-值)对设置到哈希表 key 中。
11HSET key field value 
将哈希表 key 中的字段 field 的值设为 value 。
12HSETNX key field value 
只有在字段 field 不存在时,设置哈希表字段的值。
13HVALS key 
获取哈希表中所有值
14HSCAN key cursor [MATCH pattern] [COUNT count] 
迭代哈希表中的键值对。

 6.sorted set(有序集合)

作用:

下表列出了 redis 有序集合的基本命令:

序号命令及描述
1ZADD key score1 member1 [score2 member2] 
向有序集合添加一个或多个成员,或者更新已存在成员的分数
2ZCARD key 
获取有序集合的成员数
3ZCOUNT key min max 
计算在有序集合中指定区间分数的成员数
4ZINCRBY key increment member 
有序集合中对指定成员的分数加上增量 increment
5ZINTERSTORE destination numkeys key [key ...] 
计算给定的一个或多个有序集的交集并将结果集存储在新的有序集合 key 中
6ZLEXCOUNT key min max 
在有序集合中计算指定字典区间内成员数量
7ZRANGE key start stop [WITHSCORES] 
通过索引区间返回有序集合成指定区间内的成员
8ZRANGEBYLEX key min max [LIMIT offset count] 
通过字典区间返回有序集合的成员
9ZRANGEBYSCORE key min max [WITHSCORES] [LIMIT] 
通过分数返回有序集合指定区间内的成员
10ZRANK key member 
返回有序集合中指定成员的索引
11ZREM key member [member ...] 
移除有序集合中的一个或多个成员
12ZREMRANGEBYLEX key min max 
移除有序集合中给定的字典区间的所有成员
13ZREMRANGEBYRANK key start stop 
移除有序集合中给定的排名区间的所有成员
14ZREMRANGEBYSCORE key min max 
移除有序集合中给定的分数区间的所有成员
15ZREVRANGE key start stop [WITHSCORES] 
返回有序集中指定区间内的成员,通过索引,分数从高到底
16ZREVRANGEBYSCORE key max min [WITHSCORES] 
返回有序集中指定分数区间内的成员,分数从高到低排序
17ZREVRANK key member 
返回有序集合中指定成员的排名,有序集成员按分数值递减(从大到小)排序
18ZSCORE key member 
返回有序集中,成员的分数值
19ZUNIONSTORE destination numkeys key [key ...] 
计算给定的一个或多个有序集的并集,并存储在新的 key 中
20ZSCAN key cursor [MATCH pattern] [COUNT count] 
迭代有序集合中的元素(包括元素成员和元素分值)






推荐阅读:
  1. nosql之redis简单安装与使用
  2. 如何编写CentOS下redis自启动shell脚本

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

redis edi

上一篇:WIN8--L2T虚拟教程

下一篇:有关于mysql复合索引

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》