gpt4 book ai didi

java - Jedis(Redis)减速

转载 作者:可可西里 更新时间:2023-11-01 10:56:47 29 4
gpt4 key购买 nike

我正在向 Redis 中插入大量文本以逐行存储频率。但是,jedis/redis 会变慢,并且在执行一定数量的操作后需要花费大量时间e 操作并且程序以错误结束:java.lang.OutOfMemoryError 。

这是我用于测试的主要文件: 公共(public)课温度{

private ExecutorService executor;

public temp() {
executor = Executors.newFixedThreadPool(5);
}

public static void main(String[] args) {
temp ob = new temp();

System.out.println("starting");
for(long i =0;i<10000000;i++) {
if (i%10000 == 0) {
System.out.println(i);
}
String x = Integer.toString(new Random().nextInt());
ob.executor.submit(new Runner1("abra"+x));
ob.executor.submit(new Runner2("delhi"+x));
}

try {
if (ob.executor.awaitTermination(Long.MAX_VALUE, TimeUnit.NANOSECONDS)) {
System.out.println("completed");
}
} catch (Exception ex) {
ex.printStackTrace();
}

}


}

这是我的两个运行者:亚军 1:

public class Runner1 implements Runnable {
//private static RedisClientUtil redisClient = null;
private String key;
private static Integer count = 0;

public Runner1(String key) {
this.key = key;
}

public void run() {
try {

ArrayList<ArrayList<Object>> cmd = new ArrayList<ArrayList<Object>>();

String offer_title = this.key + " this is thread1";
String offer_title_words[] = offer_title.split(" ");
for (String word : offer_title_words) {
// INCR the frequency in reddis
cmd.add(GenerateUtils.getArrayList("incrBy", "test"+word, 1));
}

List<Object> responses = RedisbenchmarkTest.getLocalhostJedisPool().executePipelinedAndReturnResponses(0,cmd);
cmd = null;
responses = null;

updateNumberOfRowsInserted();

} catch (Exception ex) {
ex.printStackTrace();
}
}

private synchronized void updateNumberOfRowsInserted() {
//logging
count++;
if(count%10000==0)
System.out.println("Thread 1 : " + count);
}



}

亚军 2:

public class Runner2 implements Runnable {
//private static RedisClientUtil redisClient = null;
private String key;
private static Integer count = 0;

public Runner2(String key) {
this.key = key;
}

public void run() {
try {

ArrayList<ArrayList<Object>> cmd = new ArrayList<ArrayList<Object>>();

String offer_title = this.key + " this is thread2";
String offer_title_words [] = offer_title.split(" ");
for (String word : offer_title_words) {
// INCR the category_word in reddis
cmd.add(GenerateUtils.getArrayList("incrBy","test1"+word,1));
} RedisbenchmarkTest.getLocalhostJedisPool().executePipelinedWithoutReturningResponses(0,cmd);
updateNumberOfRowsInserted();

} catch (Exception ex) {
ex.printStackTrace();
}
}

private synchronized void updateNumberOfRowsInserted() {
//logging
count++;
if(count%10000==0)
System.out.println("Thread 2 : " + count);
}

}

这是我的 Redis 客户端:

public class RedisbenchmarkTest {

private static RedisClientUtil localhostJedisPool;


private static final JedisPoolConfig standardJedisPoolConfig = new JedisPoolConfig() {{
setMaxTotal(500);
setMaxIdle(20);
setMaxWaitMillis(500);
setTestOnBorrow(false);
setTestOnReturn(false);
}};

private static final int semiLowTimeout = 500;

static {
initialize();
}

public static void initialize() {
localhostJedisPool = new RedisClientUtil(
standardJedisPoolConfig
, "localhost"
, 6379
, semiLowTimeout
);
}



public static RedisClientUtil getLocalhostJedisPool() {
if (localhostJedisPool == null) {
initialize();
}
return localhostJedisPool;
}
}

最佳答案

  • 您应该在 redis.conf 中禁用 bgsave 如果 redis 启动 bgsave 通常意味着在保存完成之前会有很大的延迟。
  • 您应该确保 redis.conf 中的 maxmemory 足够高。我猜你的实例运行满了。

关于java - Jedis(Redis)减速,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40634699/

29 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com