如何在CentOS 7上安装和配置Redis
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