如何在CentOS 7上安装和配置Redis

时间:2020-03-05 15:24:30  来源:igfitidea点击:

Redis是一个开源的内存中数据结构存储。
它可以用作数据库,缓存和消息代理,并支持各种数据结构,例如字符串,哈希,列表,集合等。
Redis通过Redis Sentinel提供高可用性,包括监视,通知,自动故障转移。
它还使用Redis Cluster在多个Redis节点之间提供自动分区。

本教程说明了如何在CentOS 7服务器上安装和配置Redis。

准备工作

在开始本教程之前,请确保我们以具有sudo特权的用户身份登录。

在CentOS 7上安装Redis

Redis软件包不包含在默认的CentOS存储库中。
我们将从Remi信息库安装Redis 5.0.2版。

安装非常简单,只需执行以下步骤:

  • 首先通过在SSH终端中运行以下命令来启用Remi存储库:
sudo yum install epel-release yum-utilssudo yum install http://rpms.remirepo.net/enterprise/remi-release-7.rpmsudo yum-config-manager --enable remi
  • 通过键入以下命令安装Redis软件包:
sudo yum install redis
  • 安装完成后,启动Redis服务并启用以下命令使其在启动时自动启动:
sudo systemctl start redissudo systemctl enable redis
Created symlink from /etc/systemd/system/multi-user.target.wants/redis.service to /usr/lib/systemd/system/redis.service.

要检查服务的状态,请输入以下命令:

sudo systemctl status redis

我们应该看到类似以下内容的内容:

● redis.service - Redis persistent key-value database
Loaded: loaded (/usr/lib/systemd/system/redis.service; enabled; vendor preset: disabled)
Drop-In: /etc/systemd/system/redis.service.d
        └─limit.conf
Active: active (running) since Sat 2016-11-24 15:21:55 PST; 40s ago
Main PID: 2157 (redis-server)
CGroup: /system.slice/redis.service
        └─2157 /usr/bin/redis-server 127.0.0.1:6379

如果服务器上禁用了IPv6,则Redis服务将无法启动。

恭喜,这时我们已经在CentOS 7服务器上安装并运行了Redis。

配置Redis远程访问

默认情况下,Redis不允许远程连接。
我们只能从运行Redis的计算机127.0.0.1(localhost)连接到Redis服务器。

仅当我们要从远程主机连接到Redis服务器时,才执行以下步骤。
如果使用单个服务器设置,并且应用程序和Redis在同一台计算机上运行,则不应启用远程访问。

要将Redis配置为接受远程连接,请使用文本编辑器打开Redis配置文件:

sudo nano /etc/redis.conf

找到以“ bind 127.0.0.1”开头的行,并在“ 127.0.0.1”之后添加服务器专用IP地址。

/etc/redis.conf

# IF YOU ARE SURE YOU WANT YOUR INSTANCE TO LISTEN TO ALL THE INTERFACES
# JUST COMMENT THE FOLLOWING LINE.
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
bind 127.0.0.1 192.168.121.233

确保将“ 192.168.121.233”替换为IP地址。
保存文件并关闭编辑器。

重新启动Redis服务以使更改生效:

sudo systemctl restart redis

使用以下“ ss”命令来验证Redis服务器正在侦听端口“ 6379”上的专用接口:

ss -an | grep 6379

我们应该看到类似以下的内容:

tcp    LISTEN     0      128    192.168.121.233:6379            *:*
tcp    LISTEN     0      128    127.0.0.1:6379                  *:*

接下来,我们需要添加一个防火墙规则,以启用来自远程计算机的TCP端口“ 6379”上的流量。

假设我们正在使用“ FirewallD”来管理防火墙,并且要允许从“ 192.168.121.0/24”子网进行访问,则可以运行以下命令:

sudo firewall-cmd --new-zone=redis --permanentsudo firewall-cmd --zone=redis --add-port=6379/tcp --permanentsudo firewall-cmd --zone=redis --add-source=192.168.121.0/24 --permanentsudo firewall-cmd --reload

上面的命令创建一个名为“ redis”的新区域,打开端口“ 6379”,并允许从专用网络进行访问。

此时,Redis服务器将接受TCP端口6379上的远程连接。

确保将防火墙配置为仅接受来自受信任IP范围的连接。

要验证所有设置是否正确,我们可以尝试使用提供与Redis服务器的命令行界面的'redis-cli'实用程序从远程计算机ping Redis服务器:

redis-cli -h <REDIS_IP_ADDRESS> ping

该命令应返回“ PONG”的响应:

PONG