当前位置: 首页 > ai >正文

# Redis-stable 如何在Linux系统上安装和配置

Redis-stable 如何在Linux系统上安装和配置

截至此文更新时,Redis版本升级至 8.x

1 Redis下载与安装

使用非关系型数据库Redis必须先进行安装配置并开启Redis服务,然后使用对应客户端连接使用。Redis支持多种方式的安装配置,例如Linux系统安装、Docker镜像安装等,不同安装方式的安装过程也不相同。

1.1 Redis下载

Redis版本号采用国际标准惯例,即“主版本号.副版本号.补丁级别”。

1.通过访问Redis的官方下载地址wget https://download.redis.io/redis-stable.tar.gz 进行Redis的下载,如下图所示。

2.也可以通过访问国内镜像进行下载,以华为云镜像为例。访问华为云镜像地址https://mirrors.huaweicloud.com/home,直接打开访问即可。在打开的网页中输入“Redis”关键词搜索对应的镜像,然后选择对应的版本进行下载即可。

3.同时还可以通过wget命令进行Redis的下载,在终端输入如下的命令。

redis-stable版本:

wget https://download.redis.io/redis-stable.tar.gz

wget https://github.com/redis/redis/

1.2 Redis安装

Redis官方网站没有提供Windows版的安装包,可以通过访问GitHub的https://github.com/tporadowski/redis/releases地址来下载Windows版的Redis安装包,但官方不推荐。大多数企业都是基于Linux服务器来部署项目,因此课程中我们会基于Linux系统来安装Redis,此处选择的Linux版本为AlamLinux10。

系统内核:6.12.0

1.安装gcc。Redis是基于C语言编写的,因此首先需要先安装Redis所需要的gcc依赖。Linux系统必须处于连网的状态下。

如果系统或gcc版本比较老,建议先删除旧版gcc、tcl,安装redis版本对应推荐的gcc版本

gcc --version
g++ --version

系统升级并安装开发工具集:

# 更新系统,可能会比较久
sudo yum -y update
# 卸载移除系统自带的或之前安装的旧版本gcc、c++编译器
sudo yum remove gcc gcc-c++
# 安装开发工具集(开发套件)
sudo yum groupinstall "Development Tools"
# 创建redis工作目录
mkdir /env
mkdir /env/redis
# 进入到redis工作目录,下载redis-stable安装包,
cd /env/redis/
wget https://download.redis.io/redis-stable.tar.gz
# 等待下载完成后,解压
tar -zxvf redis-stable.tar.gz
# ll检查文件是否齐备
ll

编译安装

# 根据自己的机器配置,设定最大并发进程数,可加速编译, -j 后的数字为最大启用并发编译进程数
make -j 256
# 如果编译安装过程中出现各种奇奇怪怪的问题,报错提示缺东西,可以执行make distclean清除后再行编译
# make distclean
# make -j 256
# 对编译情况进行测试,GCC14编译测试有诸多报错,可能是开发版本与编译版本的差异导致,但编译安装能够正常运行redis-server
make test
# 编译后可以使用make install 进行安装配置,如需特定参数,请参考 make install --prefix 相关参数设置
make install

Ubuntu: 原理同上,只是命令有差异

wget http://download.redis.io/redis-stable.tar.gztar xvzf redis-stable.tar.gzcd redis-stablesudo apt-get install makesudo apt-get install gccsudo apt-get install tclsudo apt-get install build-essentialsudo apt-get update## if there is another error like "fatal error: jemalloc/jemalloc.h: No such file or directory"## just run "make distclean"makemake testmake install

7.默认Redis的安装路径是在/usr/local/bin目录下。可用ll命令检查

[root@localhost redis-stable]# ll /usr/local/bin

[root@localhost redis-stable]# ll /usr/local/bin
total 31068
-rwxr-xr-x. 1 root root  6535224 Jul 18 15:53 redis-benchmark
lrwxrwxrwx. 1 root root       12 Jul 18 15:53 redis-check-aof -> redis-server
lrwxrwxrwx. 1 root root       12 Jul 18 15:53 redis-check-rdb -> redis-server
-rwxr-xr-x. 1 root root  7388784 Jul 18 15:53 redis-cli
lrwxrwxrwx. 1 root root       12 Jul 18 15:53 redis-sentinel -> redis-server
-rwxr-xr-x. 1 root root 17871944 Jul 18 15:53 redis-server

该目录已经默认配置到环境变量,因此可以在任意目录下运行这些命令。对该目录下的文件如下的说明。

文件 作用

redis-cli 是Redis提供的命令行客户端
redis-server 是Redis的服务端启动脚本
redis-sentinel 是Redis的哨兵模式启动脚本

2 启动Redis

Redis的启动方式有很多种方式,常见使用的有:默认启动、指定配置启动、开机自启。

2.1 默认启动

Redis安装完成后,在任意目录输入redis-server命令即可启动Redis服务。这种情况下,默认启动的配置文件是redis.conf。

redis-server

在终端运行上述命令后,输出如下图所示的内容则表明Redis服务启动成功。

这种启动属于前台启动,会阻塞整个会话窗口,窗口关闭或者按下“CTRL + C”则Redis服务停止,因此不推荐使用。

2.2 指定配置启动

Redis默认不会使用后台运行,如果你需要将Redis配成后台运行,需要在redis.conf文件中进行修改,就在我们之前解压的Redis安装包下(/usr/local/src/redis-stable)。当你后台服务启动的时候,会写成一个进程文件运行。

1.实际开发当中,不要直接修改redis.conf文件,我们先将这个配置文件备份一份。

[root@localhost redis-stable]# cp redis.conf redis.conf-backup

2.编辑redis.conf文件。然后修改redis.conf文件中的一些配置(在redis.conf文件中配置Redis为后台运行),如下所示。

允许访问的地址,默认是“bind 127.0.0.1 -::1”,会导致只能在本地访问。修改为“bind 0.0.0.0

-::1”则可以在任意IP访问,生产环境不要设置为“bind 0.0.0.0 -::1”

bind 0.0.0.0 -::1

守护进程,修改为yes后即可后台运行,默认值为no

daemonize yes

密码,设置后redis-cli访问必须输入密码,默认没有配置密码

requirepass 123456

在默认情况下requirepass参数值为空的,表示无需通过密码验证就可以连接到Redis服务。

3.其他的有关Redis的常见配置,以下参数非必要配置。

监听的端口

port 6379

客户端空闲N秒后关闭连接(0表示禁用)

timeout 0

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

dir ./

设置Redis实例中数据库数量,默认有16个库,编号0~15

databases 16

设置Redis能够使用的最大内存,默认没有配置

maxmemory 512mb

日志文件,默认为空,不记录日志,可以指定日志文件名

logfile "redis.log"

4.以配置文件的方式启动Redis。

使用redis-server指令启动Redis服务的时候,可以在指令后添加Redis配置文件的路径,以设置Redis是以何种配置进⾏启动。

进入Redis安装目录

[root@node1 ~]# cd /env/redis/redis-stable

指定配置文件启动redis服务

[root@node1 redis-stable]# redis-server redis.conf

5.检测6379端口是否在监听。

[root@node1 redis-stable]# netstat -lntp | grep 6379
tcp 0 0 0.0.0.0:6379 0.0.0.0:* LISTEN 8925/redis-server 0 
tcp6 0 0 ::1:6379 :::* LISTEN 8925/redis-server 0 

6.停止Redis服务。

利用redis-cli来执行shutdown命令,即可停止Redis服务。需要注意的是,如果Redis实例没有设置访问密码以及修改默认端口号,则这里的参数"-a"和"-p"可省略不写。

因为之前配置了密码,因此需要通过-u来指定密码

[root@node1 redis-stable] redis-cli -a 123456 -p 6379 shutdown

2.3 开机自启

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

1.首先,需新建一个系统服务文件。

vim /etc/systemd/system/redis.service

2.将以下的内容复制放在redis.service文件中。

[Unit]
Description=redis-server
After=network.target[Service]
Type=forking
ExecStart=/usr/local/bin/redis-server /env/redis/redis-stable/redis.conf
PrivateTmp=true[Install]
WantedBy=multi-user.target

3.然后重载系统服务。

systemctl daemon-reload

4.现在,我们可以用下面这组命令来操作Redis服务了。

启动

systemctl start redis

停止

systemctl stop redis

重启

systemctl restart redis

查看状态

systemctl status redis

5.执行下面的命令,可以让Redis开机自启。

systemctl enable redis

3 Redis客户端

安装完成Redis后,我们就可以操作Redis数据库来实现数据的CRUD操作了。这就需要用到Redis客户端,包括命令行客户端、图形化桌面客户端、编程客户端。

3.1 Redis命令行客户端

Redis安装完成后就自带了Redis命令行客户端redis-cli,通过该客户端可以运行Redis命令,用于在Redis服务上执行操作。

3.1.1 连接本地Redis服务

如果需要连接本地Redis服务,Redis客户端的基本语法为:

$

redis-cli

启动Redis服务器后,打开终端并输入命令redis-cli,该命令会连接本地的Redis 服务。

$

redis-cli
127.0.0.1:6379> PING
PONG

通过执行PING命令,用于检测Redis服务器是否启动;如果响应结果为PONG,说明已经成功连接到了Redis服务器。

3.1.2 连接远程Redis服务

如果需要在远程Redis服务上执行命令,同样我们使用的也是redis-cli命令。语法格式如下。

$

redis-cli -h host -p port -a password

对上述命令中的参数做如下的说明。

参数 作用
-h host 用于指定远程Redis服务器的IP地址,默认是127.0.0.1。
-p port 用于指定Redis远程服务器的端口号,默认是6379。
-a password 指定Redis的访问密码,即redis.conf文件中的requirepass参数处填写的密码。可选参数,若远程服务器设置了密码则需要输入。
下面示例展示了如何连接到远程Redis服务器。

[root@node1 redis-stable]# redis-cli -h 127.0.0.1 -p 6379 -a 123456
Warning: Using a password with '-a' or '-u' option on the command line interface may not be safe.
127.0.0.1:6379> PING
PONG
127.0.0.1:6379> EXIT

3.1.3 Redis连接命令

Redis连接命令主要是用于连接Redis服务。只有当Redis客户端与服务器正常连接后才能够实现彼此的交互、通信。Redis 通过“Redis序列化协议”(简称RESP),实现客户端与服务端之间的连接通信,该协议主要包括两个部分:网络模型和序列化协议。其中,网络模型主要负责数据交互的组织方式,序列化协议则实现了数据的序列化。

由此可知,Redis客户端与服务端交互的数据是以序列后的协议数据进行传输的。下面是一个简单的请求/响应示意图,如下所示。

下表罗列了常用的Redis连接命令:

命令 描述
AUTH password 验证密码是否正确。
ECHO message 打印字符串。
PING 查看服务是否运行。
QUIT 关闭当前连接。
SELECT index 切换到指定的数据库。
以下示例演示了客户端如何通过密码验证连接到Redis服务,并检测服务是否在运行,以及Redis其他连接命令的使用。

进入控制台后,通过auth命令来指定密码

[root@node1 redis-stable]# redis-cli -h 127.0.0.1 -p 6379
127.0.0.1:6379> AUTH 123456
OK
127.0.0.1:6379> PING
PONG
127.0.0.1:6379> ECHO "Hello Redis"
"Hello Redis"
192.168.230.131:6379> QUIT

执行上述命令后,终端的结果如下图所示。

3.2 Redis图形化桌面客户端

Redis有许多第三方可视化工具,可以让你更加直观形象地的操作Redis数据库,常见的Redis GUI工具有Redis Desktop Manager(又称RDM)、Another Redis DeskTop Manager及FastoRedis。

3.2.1 AnotherRedisDesktopManager

Another Redis Desktop Manager是一个更快、更好、更稳定的Redis桌面(GUI)管理客户端工具,兼容Windows、Mac、Linux,性能出众,轻松加载海量键值。

Another Redis Desktop Manager支持哨兵、集群、ssh通道、ssl认证、stream、subscribe订阅、树状视图、命令行,以及暗黑模式;多种格式化方式,甚至能够自定义格式化脚本,满足你的一切需求。

Another Redis Desktop Manager官网下载地址https://goanother.com/cn,而且完全开源免费。

3.2.2 Redis Insight

Redis Insight是由Redis官方提供的免费图形化桌面客户端工具。Redis Insight是一个功能强大的桌面用户界面,可帮助你可视化和优化Redis和Redis Stack的数据。此外,它还支持在功能齐全的桌面UI客户端中进行CLI交互。

Redis Insight官网下载地址https://redis.io/insight,而且完全开源免费。

3.2.3 RedisDesktopManager

Redis Desktop Manager(简称RDM)是一个跨平台Redis桌面管理软件,支持Windows、Liunx和macOS。该工具为用户提供了易于使用的Redis可视化操作,同时支持SSL/TLS加密,以及SSH隧道技术和云Redis实例,例如Amazon ElastiCache,Microsoft Azure Redis Cache和Redis Labs。

GitHub上的大神编写了Redis的图形化桌面客户端,下载地址是https://github.com/uglide/RedisDesktopManager。不过该仓库提供的是RedisDesktopManager的源码,并未提供Windows安装包(此工具付费)。

我们可以访问https://github.com/lework/RedisDesktopManager-Windows/releases这个仓库找到RDM的安装包(此工具免费)。

Redis的图形化界面工具只是辅助操作,可根据喜好进行选择性下载。我人个推荐使用前两种,因为开源免费,且对不同的操作系统提供了版本支持。本教程我使用的是AnotherRedisDesktopManager客户端工具。

3.3 桌面客户端连接Redis

由于Redis的图形化桌面客户端工具安装都非常简单,傻瓜式安装即可,因此关于工具的安装这里将不再展开介绍。下面我们以AnotherRedisDesktopManager工具为例,介绍如何连接Redis数据库。

1.防火墙相关操作命令
在使用Redis的图形化桌面客户端连接Redis服务之前,一定要先关闭Linux的防火墙,否则未来在连接Redis服务时可能会提示" Client On Error: Error: connect ECONNREFUSED 192.168.230.131:6379 Config right?"的错误。

查询防火墙状态

$

 systemctl status firewalld

启动防火墙

$

systemctl start firewalld

重启防火墙

$

systemctl restart firewalld

关闭防火墙

$

systemctl stop firewalld

禁用防火墙(禁止开机启动)

$

systemctl disable firewalld

开启6379端口(暂时开通)

$

/sbin/iptables -I INPUT -p tcp --dport 6379 -j ACCEPT

2.完成AnotherRedisDesktopManager安装后,双击图标即可运行。为了操作方便,可以在打开的窗口中点击左上角的设置按钮,将语言设置为简体中文的格式。

3.点击窗口左上角的“新建连接”按钮,在弹出的窗口中填写Redis服务信息,如下图所示。

在Redis连接配置窗口中填写对应的连接地址(Redis服务地址)、连接端口(Redis默认端口为6379)、密码(Redis认证密码)、连接名称(自定义),而用户名和分隔符选项,可以不用配置;然后,单击【确认】按钮进行连接,如果连接失败,则需要重新检查服务启动情况或者连接配置信息,如果连接成功,将进入客户端管理页面。

4.然后点击“确定”按钮,会打开如下图所示的窗口,此时表明Redis服务连接成功。同时我们会发现,在左侧菜单会出现这个一个连接。

5.使用命令行工具。在控制台左侧菜单可以点击“>_”按钮,将会打开下图所示的窗口,在这里可以使用Redis的命令进行操作。

Redis默认有16个仓库,编号从0至15。通过配置文件可以设置仓库数量,但是不超过16,并且不能自定义仓库名称。如果是基于redis-cli连接Redis服务,可以通过select命令来选择数据库。
————————————————

                    版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。

参考文章链接:https://blog.csdn.net/2301_82300081/article/details/144545829

http://www.xdnf.cn/news/15672.html

相关文章:

  • java常见的jvm内存分析工具
  • C语言-一维数组,二维数组
  • 菱形继承 虚继承
  • 快速安装GitLab指南
  • go安装使用gin 框架
  • web3 区块链技术与用
  • 【论文精读】基于共识的分布式量子分解算法用于考虑最优传输线切换的安全约束机组组合
  • Django母婴商城项目实践(五)- 数据模型的搭建
  • UniApp TabBar 用户头像方案:绕过原生限制的实践
  • Selenium 攻略:从元素操作到 WebDriver 实战
  • STM32之L298N电机驱动模块
  • 【iOS】MRC与ARC
  • Fish Speech:开源多语言语音合成的革命性突破
  • 伺服电机与步进电机要点详解
  • 专题:2025智能体研究报告|附70份报告PDF、原数据表汇总下载
  • 质变科技亮相可信数据库发展大会,参编《数据库发展研究报告2025》
  • Linux学习之认识Linux的基本指令
  • 前端性能优化“核武器”:新一代图片格式(AVIF/WebP)与自动化优化流程实战
  • 多模态大模型重构人机交互,全感官时代已来
  • 微服务项目总结
  • 短视频矩阵系统:选择与开发的全方位指南
  • Python网络爬虫实现selenium对百度识图二次开发以及批量保存Excel
  • Java学习------使用Jemter测试若依项目自定义的功能
  • Unity 常见数据结构分析与实战展示 C#
  • APIs案例及知识点串讲(下)
  • CES Asia 2025备受瞩目,跨国企业锁定亚洲战略首发契机
  • 基于Ubuntu22.04源码安装配置RabbitVCS过程记录
  • ARM64高速缓存,内存属性及MAIR配置
  • 基于华为openEuler系统安装DailyNotes个人笔记管理工具
  • Java全栈面试实录:从Spring Boot到AI大模型的深度解析