redis中bind有什么用

76次阅读
没有评论

共计 2219 个字符,预计需要花费 6 分钟才能阅读完成。

自动写代码机器人,免费开通

这篇文章给大家分享的是有关 redis 中 bind 有什么用的内容。丸趣 TV 小编觉得挺实用的,因此分享给大家做个参考,一起跟随丸趣 TV 小编过来看看吧。

我一直以为 redis 配置文件中的 bind 的作用是:限制 redis 服务器用来接收来自哪些服务器(IP 地址)的 redis 连接请求,只有在 bind 指定的 IP 地址的计算机才可以访问这个 redis 服务器。

事实证明,上面的结论大错特错。

今天在搭建 Redis 服务集群的时候,发现自己一直以来对 Redis 中 bind 的理解的一个误区。

例如:

bind 127.0.0.1       就是用来限制只有本机可以连接 redis 服务连接

bind 0.0.0.0         就是用来允许任意计算机都可以连接 redis 服务连接。

注意:以上的理解都是错误的。他们正好是特例,对我们产生了一种错觉。

不信的的话你们可以试一试:(最好试一试)

bind 10.0.0.1(或者除了 127.0.0.1 和 0.0.0.0 之外的任何 IP 地址)

然后重启 redis,就会发现启动不起来。

redis 中 bind 有什么用

对于为什么启动不起来,你们知道了 bind 的真正意思之后,就会明白启动不起来的原因。

对于 Redis 中 bind 的正确的理解是:

bind:是绑定本机的 IP 地址,(准确的是:本机的网卡对应的 IP 地址,每一个网卡都有一个 IP 地址),而不是 redis 允许来自其他计算机的 IP 地址。

如果指定了 bind,则说明只允许来自指定网卡的 Redis 请求。如果没有指定,就说明可以接受来自任意一个网卡的 Redis 请求。

举个例子:如果 redis 服务器(本机)上有两个网卡,每一个网卡对应一个 IP 地址,例如 IP1 和 IP2。(注意这个 IP1 和 IP2 都是本机的 IP 地址)。

我们的配置文件:bind IP1。  只有我们通过 IP1 来访问 redis 服务器,才允许连接 Redis 服务器,如果我们通过 IP2 来访问 Redis 服务器,就会连不上 Redis。

查看本地的网卡对应的 IP 地址:使用 ifconfig 命令。

redis 中 bind 有什么用

从上面看出我们有两个网卡,也就是我们只能使用:127.0.0.1 和 172.18.235.206 最为 bind 的地址,不然 redis 启动不起来。

这就说明了上面例子(bind 10.0.0.1)为什么启动不起来,因为我们没有对应的网卡 IP 地址。这就说明了 bind 并不是指定 redis 中可以接受来自哪些服务器请求的 IP 地址。

而是:bind 用于指定本机网卡对应的 IP 地址。

附注:

bind 127.0.0.1 的解释:(为什么只有本机可以连接,而其他不可以连接)

我们从 ifconfig 可以看出:lo 网卡(对应 127.0.0.1IP 地址):是一个回环地址(Local Loopback),也就是只有本地才能访问到这个回环地址,而其他的计算机也只能访问他们自己的回环地址。

那么来自这个 lo 网卡的计算机只有本机,所以只有本机可以访问,而其他计算机不能访问。

bind 172.18.235.206 的话,只要通过这个网卡地址(172.18.235.206)来的 Redis 请求,都可以访问 redis。我使用的阿里云的服务器。我在另一个服务器上去请求              redis-cli 阿里云公网 IP 地址         就会连接到 redis 服务器。

因为公网地址的请求:都是经过这个 eth0 的网卡地址(172.18.235.206),从而接收到这个 redis 请求。

当你们不使用那个回环地址,基本上外部的计算机都可以访问本机的 Redis 服务器。

如果我们想限制只有指定的主机可以连接到 redis 中,我们只能通过防火墙来控制,而不能通过 redis 中的 bind 参数来限制。

使用阿里云的安全组,来限制指定的主机连接 6379 端口。

redis 中的【protected-mode】的理解:

redis 本身无法限制【只有指定主机】连接到 redis 中,就像我上面说的一样,bind 指定只是用来设置接口地址(interfaces)。

1、如果你的 bind 设置为:bind 127.0.0.1,这是非常安全的,因为只有本台主机可以连接到 redis,就算不设置密码,也是安全的,除非有人登入到你的服务器上。

2、如果你的 bind 设置为:bind 0.0.0.0,表示所有主机都可以连接到 redis。(前提:你的服务器必须开放 redis 的端口)。这时设置密码,就会多一层保护,只有知道密码的才可以访问。也就是任何知道密码的主机都可以访问到你的 redis。

protected-mode 是 redis 本身的一个安全层,这个安全层的作用:就是只有【本机】可以访问 redis,其他任何都不可以访问 redis。这个安全层开启必须满足三个条件,不然安全层处于关闭状态:

(1)protected-mode yes(处于开启)

(2)没有 bind 指令。原文:The server is not binding explicitly to a set of addresses using the bind directive.

(3)没有设置密码。原文:No password is configured。

这时 redis 的保护机制就会开启。开启之后,只有本机才可以访问 redis。如果上面三个条件任何一个不满足,就不会开启保护机制。

感谢各位的阅读!关于“redis 中 bind 有什么用”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!

向 AI 问一下细节

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-12-04发表,共计2219字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)