java 多线程 使用jedis 报错 Connection reset by peer: socket write error
时间: 2023-07-08 07:42:18 浏览: 161
如果在多线程环境下使用 Jedis 时出现 Connection reset by peer: socket write error 的错误,可能是因为 Jedis 不是线程安全的。可以通过以下两种方式解决这个问题:
1. 使用线程安全的 JedisPool
JedisPool 可以创建多个 Jedis 实例,并提供线程安全的连接池管理。可以在每个线程中获取一个 Jedis 实例来使用,使用完毕后归还到连接池中,从而避免线程之间的竞争和冲突。
```java
import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPool;
import redis.clients.jedis.JedisPoolConfig;
public class JedisDemo {
private static JedisPool jedisPool;
static {
JedisPoolConfig config = new JedisPoolConfig();
config.setMaxTotal(10);
config.setMaxIdle(5);
config.setTestOnBorrow(true);
jedisPool = new JedisPool(config, "localhost", 6379);
}
public static void main(String[] args) {
Jedis jedis = jedisPool.getResource();
try {
jedis.set("name", "JedisDemo");
String value = jedis.get("name");
System.out.println("name = " + value);
} finally {
if (jedis != null) {
jedis.close();
}
}
jedisPool.close();
}
}
```
2. 在每个线程中创建新的 Jedis 实例
在每个线程中创建新的 Jedis 实例,使用完毕后立即关闭连接。这种方式会频繁地创建和关闭连接,不够高效,但是适用于并发量不高的场景。
```java
import redis.clients.jedis.Jedis;
public class JedisDemo {
public static void main(String[] args) {
Thread thread1 = new Thread(() -> {
Jedis jedis = new Jedis("localhost", 6379);
try {
jedis.set("name", "JedisDemo1");
String value = jedis.get("name");
System.out.println("name = " + value);
} finally {
if (jedis != null) {
jedis.close();
}
}
});
thread1.start();
Thread thread2 = new Thread(() -> {
Jedis jedis = new Jedis("localhost", 6379);
try {
jedis.set("name", "JedisDemo2");
String value = jedis.get("name");
System.out.println("name = " + value);
} finally {
if (jedis != null) {
jedis.close();
}
}
});
thread2.start();
}
}
```
这个示例在两个线程中分别创建新的 Jedis 实例,设置一个键值对,获取键值对的值并打印输出,最后关闭连接。由于每个线程都使用自己的 Jedis 实例,不会出现线程之间的竞争和冲突。
阅读全文