Error condition on socket for SYNC: Connection refused
搭建的redis主从集群时,从服务器上的redis日志报错:
1 23470:S 01 Nov 17:21:24.343 * MASTER <-> SLAVE sync started 2 23470:S 01 Nov 17:21:24.344 # Error condition on socket for SYNC: Connection refused
解决方案: 
在redis主服务器上的redis.conf中修改bind字段,将
bind 127.0.0.1
修改为
bind 0.0.0.0
注释掉也是不行的,如果bind 172.16.3.118 ,客户端需要加IP访问
./redis-cli -h 172.16.3.118 -p 7350
关于bind
翻看网上的文章,此处多翻译为“指定redis只接收来自于该IP地址的请求,如果不进行设置,那么将处理所有请求,在生产环境中最好设置该项”。这种解释会totally搞糊涂初学者,甚至是错误的。该处的英文原文为
# If you want you can bind a single interface, if the bind option is not # specified all the interfaces will listen for incoming connections. # bind 127.0.0.1
该处说明bind的是interface,也就是说是网络接口。服务器可以有一个网络接口(通俗的说网卡),或者多个。打个比方说机器上有两个网卡,分别为192.168.205.5 和192.168.205.6,如果bind 192.168.205.5,那么只有该网卡地址接受外部请求,如果不绑定,则两个网卡口都接受请求。
OK,不知道讲清楚没有,在举一个例子。在我上面的实验过程中,我是将bind项注释掉了,实际上我还有一种解决方案。由于我redis服务器的地址是 192.168.1.4 。如果我不注释bind项,还有什么办法呢?我可以做如下配置:
# bind 192.168.1.4
这里很多人会误以为绑定的ip应该是请求来源的ip。其实不然,这里应该绑定的是你redis服务器本身接受请求的ip。

 
                
            
         浙公网安备 33010602011771号
浙公网安备 33010602011771号