Redis

关注公众号 jb51net

关闭
首页 > 数据库 > Redis > Linux下redis环境配置和全局命令

redis在Linux系统下的环境配置和redis的全局命令大全

作者:小谢在努力

在Linux系统中我们经常使用Redis作为高性能的缓存数据库,然而有时候我们需要在系统中多个地方使用Redis命令,这就需要将Redis的全局命令设置好,这篇文章主要给大家介绍了关于redis在Linux系统下的环境配置和redis的全局命令大全的相关资料,需要的朋友可以参考下

 一.redix在Linux下的环境配置

1.基于Centos下的环境配置

1.使用yum安装

1.如果你的Centos是Centos8的话,直接使用yum安装即可

yum install redis

但如果你的Centos是Centos7的话,就需要安装额外的软件源了,我们这边就需要先安装 scl 软件源

yum install centos-release-scl-rh
yum install rh-redis5-redis

注意这些操作都是要在root身份下进行的 

2.构建符号链接

默认情况下,Redis 可能会被安装在一个比较深的目录中,例如 /opt/rh/rhredis5/root/usr/bin/。这样的路径不仅难记,而且在日常使用或编写脚本时输入起来也很不方便。

构建符号链接可以创建一个简短且易于记忆的访问路径,通常指向 Redis 的二进制文件(如 redis-server、redis-cli 等)。这样,你就可以在系统的任何地方轻松地调用这些工具,而无需指定完整的路径。例如,你可以将 redis-server 链接到 /usr/local/bin/redis-server,这是一个通常在系统 $PATH 环境变量中的目录,使得系统可以在任何路径下识别并执行该命令

1.首先进入 /usr/bin目录

cd /usr/bin

2. 构建符号链接

ln -s /opt/rh/rh-redis5/root/usr/bin/redis-server ./redis-server
ln -s /opt/rh/rh-redis5/root/usr/bin/redis-sentinel ./redis-sentinel
ln -s /opt/rh/rh-redis5/root/usr/bin/redis-cli ./redis-cli

构建完成后可以查看是否构建成功 

ll ./redis-server
ll ./redis-cli
ll ./redis-sentinel

如果出现上图这个样子就说明构建成功 

3.针对配置⽂件设置符号链接

cd /etc/
ln -s /etc/opt/rh/rh-redis5/ ./redis

同理也可以查看是否构建成功

ll ./redis

4.修改配置文件

由于redis默认的配置文件,像只能在自己的主机上通信,保护模式不允许从任何主机访问 Redis 等等方面的原因,就需要我们手动的去修改

1.打开配置文件

vim /etc/redis/redis.conf

2.设置 IP 地址

使得 Redis 监听所有可用的网络接口

 找到下图的 bind

改成

bind 0.0.0.0

3.关闭保护模式

 关闭保护模式允许从任何主机访问 Redis

找到 protected-mode

修改成

protected-mode no

4.启动守护进程

使得 Redis 以后台守护进程的方式运行。这对于生产环境是必要的,因为它允许 Redis 在用户退出 SSH 会话或关闭终端后继续运行 

找到daemonize

修改成

daemonize yes

5.设置工作目录和日志目录

先退出配置文件

创建工作目录和日志目录

mkdir -p /var/lib/redis
mkdir -p /var/log/redis

再次进入配置文件

找到 dir

修改成

dir /var/lib/redis

找到 logfile

修改成

logfile /var/log/redis/redis-server.log

 后续如果你还需要修改那些命令可以自行去修改,这里就介绍一些目前学习要用到的

5.启动 redis

1.启动redis服务器

redis-server /etc/redis/redis.conf

2.打开redis的客服端

redis-cli

 出现下图就说明启动成功了

你可以创建一些值看一下是否可以使用 

set key 1 #创建键值对
get key   #获得key的Value值

6.停⽌redis服务器

这里博主就不建议停止redis服务器,以免再次使用redis时还得打开服务器

1.先查看到redis-server的pid(进程ID)

ps aux | grep redis

2.关闭 redis服务器

kill 进程ID

 关闭后,执行第五步即可.

2.基于Ubuntu下的环境配置

 基于Ubuntu环境下其实步骤和基于Centos的步骤更简单,因为它不需要创建符号链接,其他的步骤都和Centos的步骤上的一样,除了使用安装的运营商不同.可以参考Centos的步骤

1.安装

apt install redis -y

不需要创建符号链接修改配置文件参考Centos的步骤,修改的内容是一样的没有差别

二.redis的全局命令

我们都知道redis支持多种数据结构,并且redis 是以键值对的形式来组织数据的,通过网络来传输数据,可以看成是一个联网的哈希表,其中 key 固定就是字符串的形式,Value 是可以以多种数据结构的形式存在的

既然可以以这么多数据结构来表示,就说明每个数据结构都有不同的redis命令,这些命令,博主后续会为大家介绍,而全局命令就是无论 Value是以什么样的数据结构所表示都可以使用的命令,全局命令其实还挺多的,博主这里就介绍一些日常工作学习比较常用的命令,其他的命令大家需要用到的时候可以去翻阅redis的官方文档来具体使用 Understand Redis data types | Docs

以上就是 Value目前可以以这些数据结构的形式来表示

1.get 和 set

属于Redis中最基础且广泛使用的命令,可以说只要你用redis就必须会到这两个命令

1.set

set key value

把key 和 value 存储到 redis 中,这个默认是字符串的形式的,value 以其他数据结构表示的有其他的更高效和精确的命令.

注意:redis是不区分大小写的,并且这里你加不加单引号或者双引号都可以.都是默认你存储的数据位字符串的形式

2.get

根据 key 来返回 value的值

如果 key不存在

如果key不存在就返回 nil 和 Java 的 null 与c++的NULL 一个意思,表示键不存在.

2.keys

用来查询当前服务器符合给定模式的 key 

语法为

keys patten

patten 主要是一些选项,支持一些通配符

解释之前我们先存储几个 key value 进去好做实验

set hello 1
set hallo 2
set hllo 3
set heeello 4
set hhllo 5
set hbllo 6

1.? 匹配任意一个字符

keys h?llo

可以看到 ? 可以只能匹配任意一个字符,所以就列出以下这些符合条件的 key

2. * 匹配任意多个字符包括0个

keys h*llo

3.[a,b,c]只能匹配括号里面的字符

keys h[a,b,c]llo

4.[^e] 排除括号里的字符

keys h[^e]llo

5.[a-d]匹配字符a到字符d之间的字符,前闭后闭

keys h[a-d]llo

6.注意事项

      4.无论是 KEYS 还是 SCAN,返回的键都是无序的,不能保证按照任何特定顺序排列。 

    5.谨慎使用模式匹配:在使用模式匹配时,应尽量避免使用过于宽泛的模式,比如 "*",这可能         导致返回大量键,即使使用 SCAN 也会消耗较多资源

3.exists

检查一个或多个key是否存在。返回存在的键的数量

语法

exists key ....

注意:这个操作的时间复杂度为 0(N) 这里N为要查询的 Key的数量,这是官方文档说明的,同时要注意能够写多个就写多个,尽量不要一个一个的去查询,因为exists 每次查询都需要访问到redis服务器,它们之间的通信是网络通信,所以性能会降低,并且还会消耗更多的系统资源

4.del

删除一个或多个键及其对应的值

 语法

del key...

注意:这个操作的时间复杂度为 0(N) 这里N为要删除的 Key的数量,这是官方文档说明的,同时要注意能够写多个就写多个,尽量不要一个一个的去删除,因为del 每次访问都需要访问到redis服务器,它们之间的通信是网络通信,所以性能会降低,并且还会消耗更多的系统资源  

5.expire

为键设置一个过期时间(单位为秒),超过此时间键将自动删除。

语法 

expire key seconds#单位为秒

1.应用场景

像手机收到的验证码,就是可以运用这个命令,规定在多少秒之后,就不生效了,还有像那些购物网站的优惠价也可以这样设置,超过多少时间就失效了,等等总之这个命令还是比较常用实用的. 通过合理使用 EXPIRE,开发者能够设计出更加高效、自动化的数据管理策略,提升系统的灵活性和健壮性。

2.注意事项

该过期时间的时间单位为秒,如果你要想更精细的话,可以使用

pexpire key 毫秒

6. TTL

一般和expire搭配使用,查看 当前 key 的过期时间还剩多少

语法 

ttl key

注意:如果键不存在或没有设置过期时间,返回 -1 或 -2 分别表示。 

7.key的过期策略的实现(面试经典问题)

在实际开发中 一个 redis 中可能同时存在很多很多 key,这些 key 中可能有很大一部分都有过期时间.此时,redis 服务器如何知道哪些key 已经过期要被删除, 哪些 key 还没过期??

1.惰性删除

假设这个 key 已经到过期时间了,但是暂时还没删它,key 还存在.紧接着,后面又一次访问,正好用到了这个 key,于是这次访问就会让 redis 服务器触发删除 key 的操作,同时再返回一个 nil,这种方式虽然降低了性能开销,但可能造成过期键占用内存较长时间,比较不一定会去访问过期的键.

2.定期删除

为了弥补惰性删除可能带来的内存占用问题,Redis还会周期性地执行一个称为“过期键检查”的操作。在这个操作中,Redis会遍历数据库中的部分键,检查并删除已过期的键。这个过程不是一次性检查所有键,而是分批进行,以避免对服务器造成太大压力。定期删除的频率和每次检查的键的数量可以通过配置参数调整,以达到内存使用和性能之间的最佳平衡。

3.内存淘汰机制

虽然有了上述两种策略结合,整体的效果一般仍然可能会有很多过期的 key 被残留了,没有及时删除掉,redis 为了对上述进行补充,还提供了一系列的内存淘汰策略.例如,如果数据访问具有明显的热点,使用LRU或LFU淘汰机制;如果数据大部分都设置了过期时间,使用volatile相关的策略可以更针对性地管理内存。正确配置淘汰策略对保持Redis服务的稳定性和性能至关重要。 

8.type

返回key所存储的value的类型。

redis的 value 是可以以多种数据结构形式来表示的,每个数据结构的 redis 命令 都会有所不同,所以我们知道相应的 value 的数据类型是很重要的 特殊是当数据量特别大的时候,知道value 的数据类型是个很重要的事

语法 

type key

为了实验这个命令我们要设置不同类型value

set key1 1 #字符串
rpush key2 1 2 3 #列表
sadd key3 1 2 3 #集合
hset key4 field 1 #哈希表

type key1
type key2
type key3
type key4

9.info

提供关于Redis服务器的各种信息,包括服务器状态、客户端连接、内存使用情况、持久化、复制等。

info + 选项

1.注意事项

总之,INFO 是一个强大的命令,使用时应权衡获取信息的需求与对系统性能的影响,特别是在生产环境中要谨慎处理,确保信息安全。

总结

以上就是一些常用的全局命令,还是那句话,博主只深入介绍几个比较常用的全局命令,可能还有一些遗漏的命令,博主在后续的文章里也会继续讲解说明.如果遇到了不懂或者是需要用到其他的全局命令的时候,那就是去看官方文档.文档上的一定是正确的,并且是最新的.好了就介绍到这了,如果在配置环境上有什么不懂的可以私聊博主,或者加文末的微信,后续的内容,博主也在持续更新中,如果感兴趣的话可以关注一手,谢谢你的阅读,祝你一天愉快.

到此这篇关于redis在Linux系统下的环境配置和redis的全局命令大全的文章就介绍到这了,更多相关Linux下redis环境配置和全局命令内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文