使用Java远程连接操作Redis

时间:2021-09-04 14:40:27

前言:

Redis是目前十分流行的key-value类型存储系统,因为其高效的性能,主从同步的架构,丰富的存储方式以及极其简便的操作备受开发者青睐的一款工具。为了保证效率,数据都是缓存在内存中,redis会周期性的把更新的数据写入磁盘或者把修改操作写入追加的记录文件,并且在此基础上实现了master-slave(主从)同步。Redis同时提供了Java,C/C++,C#,PHP,JavaScript,Perl,Object-C,Python,Ruby,Erlang等客户端,使用很方便。

上一篇文章中我们中我们在Linux机器上安装了Redis的server端,在本篇文章中我们将在Windows开发环境中使用java作为Client端远程连接并操作Redis。

准备:

1.已装好Redis的Linux服务器(Redis 3.2.6)
2.Jedis-2.9.0.jar(java-client端有很多,这里我们推荐官方的Jedis,2.9.0是最新版)
3.Eclipse开发环境(可以自己选择,不多做说明)

测试:

1.首先在server端启动redis,启动命令是:(详情请看安装篇)
./redis-server redis.conf
2.java建立project,因为jedis包是jdk 1.7编译的,请使用1.7或以上版本的jre环境
测试代码如下

import redis.clients.jedis.Jedis;
public class Test {

public static void main(String[] args) {
// TODO Auto-generated method stub
init();
}

public static void init(){
Jedis jedis = new Jedis("192.168.201.142");
jedis.set("myredis","ok");
System.out.println(jedis.get("myredis"));
}
}

若是成功的话,控制台会输出ok的结果,若是报错,请看下面依照实际情况处理。

异常:

1.connection refused:connect的异常

报错信息如下:

Exception in thread "main" redis.clients.jedis.exceptions.JedisConnectionException: java.net.ConnectException: Connection refused: connect
at redis.clients.jedis.Connection.connect(Connection.java:207)
at redis.clients.jedis.BinaryClient.connect(BinaryClient.java:93)
at redis.clients.jedis.Connection.sendCommand(Connection.java:126)
at redis.clients.jedis.BinaryClient.set(BinaryClient.java:110)
at redis.clients.jedis.Client.set(Client.java:47)
at redis.clients.jedis.Jedis.set(Jedis.java:120)
at roy.redis.test.Test.init(Test.java:13)
at roy.redis.test.Test.main(Test.java:8)
Caused by: java.net.ConnectException: Connection refused: connect
at java.net.DualStackPlainSocketImpl.waitForConnect(Native Method)
at java.net.DualStackPlainSocketImpl.socketConnect(DualStackPlainSocketImpl.java:85)
at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350)
at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206)
at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188)
at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:172)
at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392)
at java.net.Socket.connect(Socket.java:589)
at redis.clients.jedis.Connection.connect(Connection.java:184)
... 7 more

这可能是两个原因造成的,首先可能是redis的6379端口无法访问,清先在cmd中输入命令
telnet 192.168.201.142 6379
看看可不可以访问redis-server机器的6379端口,如果不能访问,需要在远程机器关掉防火墙或者添加允许通过
1)使用root用户登录,vi /etc/sysconfig/iptables,添加如图所以一行
使用Java远程连接操作Redis
2)输入命令service iptables restart重启防火墙

或者可以直接root用户使用命令service iptables stop关闭防火墙。

防火墙检查完后,如果还是出现上述问题,说明redis还有地方需要配置,redis默认是只有本机可以访问的,想要远程访问需要修改redis.conf配置文件。
进入redis.conf目录,并使用vi命令打开,找到bind那行修改后,wq保存退出,重启redis-server。
使用Java远程连接操作Redis

bind 后加的是允许访问的ip
bind 127.0.0.1代表只有本机可以访问,可以将允许访问的ip加入,也可以直接注释掉这一行,这样所有机器都可以访问。

2.DENIED Redis is running in protected mode

报错信息如下:

Exception in thread "main" redis.clients.jedis.exceptions.JedisDataException: DENIED Redis is running in protected mode because protected mode is enabled, no bind address was specified, no authentication password is requested to clients. In this mode connections are only accepted from the loopback interface. If you want to connect from external computers to Redis you may adopt one of the following solutions: 
1) Just disable protected mode sending the command 'CONFIG SET protected-mode no' from the loopback interface by connecting to Redis from the same host the server is running, however MAKE SURE Redis is not publicly accessible from internet if you do so. Use CONFIG REWRITE to make this change permanent.
2) Alternatively you can just disable the protected mode by editing the Redis configuration file, and setting the protected mode option to 'no', and then restarting the server.
3) If you started the server manually just for testing, restart it with the '--protected-mode no' option.
4) Setup a bind address or an authentication password. NOTE: You only need to do one of the above things in order for the server to start accepting connections from the outside.
at redis.clients.jedis.Protocol.processError(Protocol.java:127)
at redis.clients.jedis.Protocol.process(Protocol.java:161)
at redis.clients.jedis.Protocol.read(Protocol.java:215)
at redis.clients.jedis.Connection.readProtocolWithCheckingBroken(Connection.java:340)
at redis.clients.jedis.Connection.getStatusCodeReply(Connection.java:239)
at redis.clients.jedis.Jedis.set(Jedis.java:121)
at roy.redis.test.Test.init(Test.java:13)
at roy.redis.test.Test.main(Test.java:8)

报错信息很长,但是主要是说redis开启了protected mode,这也是Redis3.2加入的新特性,开启保护模式的redis只允许本机登录,同样设置在配置文件redis.conf中,如图
使用Java远程连接操作Redis
这里原来是yes代表开启了保护模式,后面可以填密码也可以填no代表关闭,我们这里选择关闭保护模式,wq保存退出后再重启redis-server

此时应该就可以成功操作了,谢谢观看本文,希望能帮到你。