首頁  >  文章  >  資料庫  >  jedis和redistemplate區別

jedis和redistemplate區別

(*-*)浩
(*-*)浩原創
2019-11-22 14:46:018457瀏覽

jedis和redistemplate區別

Jedis是Redis官方推薦的Java導向的操作Redis的客戶端,而RedisTemplate是SpringDataRedis中對JedisApi的高度封裝。

使用原生jedis和spring的redisTemplate呼叫連接池,發現差異巨大:                            #中學習:

##li見到多個視訊教學課程。 redis配置:

  redis:
    database: 0
    host: 127.0.0.1
    port: 6379
    password: 123456
    timeout: 5000
    lettuce:
      shutdown-timeout: 200
      pool:
        max-active: 500
        max-idle: 100
        min-idle: 50
        max-wait: 2000
jedis單元測試:

  public void testJedis() throws IOException {
    GreExam greExam = new GreExam();
    greExam.setId(997);
    String greExamStr = JacksonUtil.bean2Json(greExam);
 
    long time = 0;
    for (int i = 0; i < 100; i++) {
      try (Jedis jedis = jedisPool.getResource()) {
        // 1、推送
        long time1 = System.currentTimeMillis();
        jedis.lpush("jedis-mq", greExamStr);
        // 2、接收
        String msg = jedis.brpoplpush("jedis-mq", "jedis-mq_bak", 0);
        jedis.lrem("jedis-mq_bak", 1, msg);
        long time2 = System.currentTimeMillis();
        time += time2 - time1;
      } catch (Exception e) {
        e.printStackTrace();
      }
    }
    System.out.println("总时间:" + time);
  }
jedis和redistemplate區別redisTemplate單元測試:

  public void testRedisTemplate() throws IOException {
    GreExam greExam = new GreExam();
    greExam.setId(997);
    String greExamStr = JacksonUtil.bean2Json(greExam);
    long time = 0;
    for (int i = 0; i < 100; i++) {
      // 1、推送
      long time1 = System.currentTimeMillis();
      redisTemplate.opsForList().leftPush("redisTemplate-mq", greExamStr);
      // 2、接收
      String msg = (String) redisTemplate.opsForList().rightPopAndLeftPush(
          "redisTemplate-mq", "redisTemplate-mq_bak", 1, TimeUnit.SECONDS);
      redisTemplate.opsForList().remove("redisTemplate-mq_bak", 1, msg);
      long time2 = System.currentTimeMillis();
      time += time2 - time1;
    }
    System.out.println("总时间:" + time);
  }

時效比較:

###結論:###原生jedis效率優於redisTemplate。另外,測試種發現,使用了100次請求,每次不進行業務操作,執行速度很快,redis只保持了幾個連接,但是若是加上自己的業務處理或者休眠幾秒,會發現redis持續保持了連接池的配置50 連線。 ######由於是單線程,上一個jedis執行完畢後,似乎沒有關閉,而且下次呼叫也沒有分派空閒連接,而是打開新連接,直到最小連接數飽和,才分配空閒連接給下一個(按理說單線程應該保證新調用的時候,上一個已經完全空閒,所以不再開新連接),具體原因位置,保持疑問,可能和線程池的原理有關。 ######更多Redis相關技術文章,請造訪###Redis資料庫使用入門教學###欄位學習! ###

以上是jedis和redistemplate區別的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn