写了一段这样的代码:
package test;
import redis.clients.jedis.Jedis;
public class TestMain {
public static void main(String[] args) {
Jedis jedis=new Jedis("127.0.0.1",6379);//redis客户端的IP地址和端口号port
jedis.set("key1","value1");
System.out.println(jedis.get("key1"));
jedis.close();
}
}
然后他就报了这样的错误:
Exception in thread "main" redis.clients.jedis.exceptions.JedisConnectionException: Failed connecting to xxx.xx.xx.xx:6379
at redis.clients.jedis.Connection.connect(Connection.java:165)
at redis.clients.jedis.BinaryClient.connect(BinaryClient.java:109)
at redis.clients.jedis.Connection.sendCommand(Connection.java:114)
at redis.clients.jedis.BinaryClient.set(BinaryClient.java:133)
at redis.clients.jedis.Client.set(Client.java:58)
at redis.clients.jedis.Jedis.set(Jedis.java:153)
at test.TestMain.main(TestMain.java:13)
Caused by: java.net.SocketTimeoutException: connect timed out
at java.net.DualStackPlainSocketImpl.waitForConnect(Native Method)
at java.net.DualStackPlainSocketImpl.socketConnect(DualStackPlainSocketImpl.java:81)
at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:476)
at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:218)
at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:200)
at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:162)
at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:394)
at java.net.Socket.connect(Socket.java:606)
at redis.clients.jedis.DefaultJedisSocketFactory.createSocket(DefaultJedisSocketFactory.java:53)
at redis.clients.jedis.Connection.connect(Connection.java:158)
... 6 more
Process finished with exit code 1
首先检查服务器有没有开(可以用默认配置打开也可以用手动配置打开):
这里能发现redis服务端是开启,所以应该不是服务端没开启的问题。
一般出现这样问题可能是你的服务端没有开启
或者是redis启动的配置没有将bind
设置好。
首先你得确保Redis配置中的找到bind配置项,如果你得是bind 127.0.0.1
这个是只允许本机电脑访问,那么可以把他配置成bind 0.0.0.0
他的意思是外网的所有的电脑都可以访问这个redis(不过实际生产中不会这么设置的,这里仅测试使用)。
然后在用这个配置重启一下redis服务端。
如果还是不行话,那么很可能是防火墙出现了问题,导致端口不开放。
此时我们可以:
firewall-cmd --list-all 查看当前防火墙配置
firewall-cmd --add-service=http --permanent 开放http访问
firewall-cmd --add-port=6379/tcp --permanent 开放6379端口
如果firewall-cmd --list-all
出现下列情况:
可以使用systemctl restart firewalld来开启防火墙
首先得保证redis中存在keys,我这边就先存了个key1进去值为value1
那么都设置好后程序最后运行的结果为:
value1