Redis 时遇到错误信息 DENIED Redis is running in protected mode because protected mode is enabled and no password is set for the default user

当你在使用 Redis 时遇到错误信息 DENIED Redis is running in protected mode because protected mode is enabled and no password is set for the default user,这意味着 Redis 服务器出于安全考虑,只接受来自本地回环接口(loopback interface)的连接。如果你需要从外部连接到 Redis 服务器,需要采取相应的措施来禁用保护模式或设置密码。以下是解决这个问题的几种方法:

方法 1:禁用保护模式

使用 CONFIG SET 命令

  1. 连接到 Redis 服务器:
    • 使用 Redis 客户端(如 redis-cli)从同一台主机连接到 Redis。
  2. 禁用保护模式:
    • 执行 CONFIG SET protected-mode no 命令来禁用保护模式。
  3. 使更改永久生效:
    • 执行 CONFIG REWRITE 命令将配置更改写入 redis.conf 文件。
      示例

        # 连接到 Redis 服务器
        redis-cli
      
        # 禁用保护模式
        CONFIG SET protected-mode no
      
        # 使更改永久生效
        CONFIG REWRITE
      

注意事项

  • 安全性:
    • 禁用保护模式后,Redis 服务器将不再限制来自非本地接口的连接。
    • 确保 Redis 服务器不直接暴露在互联网上,或者使用防火墙和安全组来限制访问。

方法 2:编辑 redis.conf 文件

  1. 编辑 redis.conf 文件:
    • 找到 protected-mode 配置项,将其设置为 no。
  2. 重启 Redis 服务器:
    • 保存文件并重启 Redis 服务器以使更改生效。
      示例

        # 编辑 redis.conf 文件
        sudo nano /etc/redis/redis.conf
      
        # 找到 protected-mode 配置项,将其设置为 no
        protected-mode no
      
        # 保存并退出编辑器
        Ctrl + X
        Y
        Enter
      
        # 重启 Redis 服务器
        sudo systemctl restart redis
      

方法 3:启动 Redis 时禁用保护模式

如果你只是手动启动 Redis 服务器进行测试,可以在启动命令中添加 --protected-mode no 选项。
示例

		# 启动 Redis 服务器并禁用保护模式
		redis-server --protected-mode no

方法 4:设置密码

设置密码是一种更安全的解决方案,它允许你通过身份验证来访问 Redis 服务器。

  1. 编辑 redis.conf 文件:
    • 找到 requirepass 配置项,设置一个强密码。
  2. 重启 Redis 服务器:
    • 保存文件并重启 Redis 服务器以使更改生效。
      示例

        # 编辑 redis.conf 文件
        sudo nano /etc/redis/redis.conf
      
        # 找到 requirepass 配置项,设置一个强密码
        requirepass yourStrongPassword
      
        # 保存并退出编辑器
        Ctrl + X
        Y
        Enter
      
        # 重启 Redis 服务器
        sudo systemctl restart redis
      

在客户端中使用密码

  1. 连接到 Redis 服务器:
    • 使用密码连接到 Redis 服务器。
  2. 验证密码:
    • 使用 AUTH 命令进行身份验证。
      示例

        # 连接到 Redis 服务器
        redis-cli
      
        # 验证密码
        AUTH yourStrongPassword
      

建议的最佳实践

  • 设置密码:
    • 使用密码是最安全的解决方案,可以有效防止未经授权的访问。
  • 使用防火墙:
    • 即使禁用保护模式,也应使用防火墙或安全组来限制对 Redis 服务器的访问。
  • 绑定到特定 IP:
    • 在 redis.conf 文件中设置 bind 配置项,绑定到特定的 IP 地址,而不是 0.0.0.0。
      示例:绑定到特定 IP

        # 编辑 redis.conf 文件
        sudo nano /etc/redis/redis.conf
      
        # 找到 bind 配置项,绑定到特定的 IP 地址
        bind 127.0.0.1 192.168.1.100
      
        # 保存并退出编辑器
        Ctrl + X
        Y
        Enter
      
        # 重启 Redis 服务器
        sudo systemctl restart redis
      

总结

  • 禁用保护模式:
    • 使用 CONFIG SET protected-mode no 和 CONFIG REWRITE 命令。
    • 或者编辑 redis.conf 文件将 protected-mode 设置为 no 并重启服务器。
    • 或者在启动 Redis 时添加 --protected-mode no 选项。
  • 设置密码:
    • 在 redis.conf 文件中设置 requirepass 配置项。
    • 使用 AUTH 命令在客户端进行身份验证。
  • 最佳实践:
    • 建议设置密码并结合防火墙规则来提高安全性。
    • 避免将 Redis 服务器直接暴露在互联网上。
      通过这些方法,可以解决 Redis 保护模式导致的连接问题,并确保 Redis 服务器的安全性和稳定性。

参考资源

posted @ 2024-12-30 23:48  似梦亦非梦  阅读(36)  评论(0编辑  收藏  举报