Redis连接池-Java代码
1、JedisUtil类
2、测试类
3、测试日志(模拟出现竞争情况)
- import org.apache.log4j.Logger;
- import redis.clients.jedis.Jedis;
- import redis.clients.jedis.JedisPool;
- import redis.clients.jedis.JedisPoolConfig;
- public class JedisUtil {
- protected static Logger logger = Logger.getLogger(JedisUtil.class);
- // Redis server IP
- private static String HOST_LIST = "192.168.0.123";
- // Redis port
- private static int PORT = 6379;
- // auth
- private static String PASS = "jiangtao";
- private static int MAX_ACTIVE = 10;
- private static int MAX_IDLE = 2;
- private static boolean TEST_ON_BORROW = false;
- private static int MAX_WAIT = 3000;
- private static int TIMEOUT = 100000;
- private static JedisPool jedisPool = null;
- /**
- * initial Pool
- */
- private static synchronized void init_pool() {
- if (jedisPool == null) {
- try {
- JedisPoolConfig config = new JedisPoolConfig();
- config.setMaxTotal(MAX_ACTIVE);
- config.setMaxIdle(MAX_IDLE);
- config.setMaxWaitMillis(MAX_WAIT);
- config.setTestOnBorrow(TEST_ON_BORROW);
- jedisPool = new JedisPool(config, HOST_LIST.split(",")[0], PORT, TIMEOUT, PASS);
- } catch (Exception e) {
- logger.error("First create JedisPool error : " + e);
- try {
- // 如果第一个IP异常,则访问第二个IP
- JedisPoolConfig config = new JedisPoolConfig();
- config.setMaxTotal(MAX_ACTIVE);
- config.setMaxIdle(MAX_IDLE);
- config.setMaxWaitMillis(MAX_WAIT);
- config.setTestOnBorrow(TEST_ON_BORROW);
- jedisPool = new JedisPool(config, HOST_LIST.split(",")[1], PORT, TIMEOUT, PASS);
- } catch (Exception e2) {
- logger.error("Second create JedisPool error : " + e2);
- }
- }
- }
- }
- public synchronized static Jedis getJedis() {
- if (jedisPool == null) {
- init_pool();
- }
- Jedis jedis = null;
- try {
- if (jedisPool != null) {
- jedis = jedisPool.getResource();
- }
- } catch (Exception e) {
- System.out.println("no remain redis from pool");
- }
- return jedis;
- }
- /**
- * 释放jedis资源
- *
- *
- *
- * @param jedis
- */
- public static void returnResource(final Jedis jedis) {
- if (jedis != null && jedisPool != null) {
- jedis.close();
- }
- }
- }
- import java.text.DateFormat;
- import java.text.SimpleDateFormat;
- import java.util.Date;
- import redis.clients.jedis.Jedis;
- public class Test {
- public static void main(String[] args) {
- for (int i = 0; i < 1000; i++) {
- Test_Thread t = new Test_Thread(i);
- t.start();
- }
- }
- }
- class Test_Thread extends Thread {
- int i = 0;
- public Test_Thread(int i) {
- this.i = i;
- }
- public void run() {
- Date date = new Date();
- DateFormat format = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
- String time = format.format(date);
- Jedis obj = JedisUtil.getJedis();
- String value = null;
- if (obj != null) {
- obj.set("test",time);
- try {
- sleep(10000);
- } catch (InterruptedException e) {
- System.out.println("sleep error");
- }
- value = obj.get("test");
- Date date2 = new Date();
- String time2 = format.format(date2);
- System.out.println("【输出>>>>】test:" + value + " 第:" + i + "个线程" + "当前时间:" + time2);
- }
- JedisUtil.returnResource(obj);
- // JedisUtil.setString("test", time);
- }
- }
- no remain redis from pool
- no remain redis from pool
- no remain redis from pool
- 【输出>>>>】test:2018-07-22 10:38:19 第:13个线程当前时间:2018-07-22 10:38:29
- 【输出>>>>】test:2018-07-22 10:38:19 第:999个线程当前时间:2018-07-22 10:38:29
- 【输出>>>>】test:2018-07-22 10:38:19 第:995个线程当前时间:2018-07-22 10:38:29
- 【输出>>>>】test:2018-07-22 10:38:19 第:991个线程当前时间:2018-07-22 10:38:29
- 【输出>>>>】test:2018-07-22 10:38:19 第:987个线程当前时间:2018-07-22 10:38:29
- 【输出>>>>】test:2018-07-22 10:38:19 第:983个线程当前时间:2018-07-22 10:38:29
- 【输出>>>>】test:2018-07-22 10:38:19 第:979个线程当前时间:2018-07-22 10:38:29
- 【输出>>>>】test:2018-07-22 10:38:19 第:975个线程当前时间:2018-07-22 10:38:29
- 【输出>>>>】test:2018-07-22 10:38:19 第:971个线程当前时间:2018-07-22 10:38:29
- 【输出>>>>】test:2018-07-22 10:38:19 第:967个线程当前时间:2018-07-22 10:38:29
- no remain redis from pool
- no remain redis from pool
- no remain redis from pool
- 【输出>>>>】test:2018-07-22 10:38:19 第:951个线程当前时间:2018-07-22 10:38:39
- 【输出>>>>】test:2018-07-22 10:38:19 第:947个线程当前时间:2018-07-22 10:38:39
- 【输出>>>>】test:2018-07-22 10:38:19 第:952个线程当前时间:2018-07-22 10:38:39
- 【输出>>>>】test:2018-07-22 10:38:19 第:943个线程当前时间:2018-07-22 10:38:39
- 【输出>>>>】test:2018-07-22 10:38:19 第:997个线程当前时间:2018-07-22 10:38:39
- 【输出>>>>】test:2018-07-22 10:38:19 第:993个线程当前时间:2018-07-22 10:38:39
- 【输出>>>>】test:2018-07-22 10:38:19 第:989个线程当前时间:2018-07-22 10:38:39
- 【输出>>>>】test:2018-07-22 10:38:19 第:985个线程当前时间:2018-07-22 10:38:39
- 【输出>>>>】test:2018-07-22 10:38:19 第:981个线程当前时间:2018-07-22 10:38:39
- 【输出>>>>】test:2018-07-22 10:38:19 第:977个线程当前时间:2018-07-22 10:38:39
- no remain redis from pool
- no remain redis from pool
- no remain redis from pool
- 【输出>>>>】test:2018-07-22 10:38:19 第:998个线程当前时间:2018-07-22 10:38:49
- 【输出>>>>】test:2018-07-22 10:38:19 第:994个线程当前时间:2018-07-22 10:38:49
- 【输出>>>>】test:2018-07-22 10:38:19 第:990个线程当前时间:2018-07-22 10:38:49
- 【输出>>>>】test:2018-07-22 10:38:19 第:986个线程当前时间:2018-07-22 10:38:49
- 【输出>>>>】test:2018-07-22 10:38:19 第:982个线程当前时间:2018-07-22 10:38:49
- 【输出>>>>】test:2018-07-22 10:38:19 第:978个线程当前时间:2018-07-22 10:38:49
- 【输出>>>>】test:2018-07-22 10:38:19 第:974个线程当前时间:2018-07-22 10:38:49
- 【输出>>>>】test:2018-07-22 10:38:19 第:970个线程当前时间:2018-07-22 10:38:49
- 【输出>>>>】test:2018-07-22 10:38:19 第:996个线程当前时间:2018-07-22 10:38:49
- 【输出>>>>】test:2018-07-22 10:38:19 第:992个线程当前时间:2018-07-22 10:38:49
- no remain redis from pool
- no remain redis from pool
- no remain redis from pool
- 【输出>>>>】test:2018-07-22 10:38:19 第:976个线程当前时间:2018-07-22 10:38:59
- 【输出>>>>】test:2018-07-22 10:38:19 第:972个线程当前时间:2018-07-22 10:38:59
- 【输出>>>>】test:2018-07-22 10:38:19 第:968个线程当前时间:2018-07-22 10:38:59
- 【输出>>>>】test:2018-07-22 10:38:19 第:966个线程当前时间:2018-07-22 10:38:59
- 【输出>>>>】test:2018-07-22 10:38:19 第:964个线程当前时间:2018-07-22 10:38:59
- 【输出>>>>】test:2018-07-22 10:38:19 第:960个线程当前时间:2018-07-22 10:38:59
- 【输出>>>>】test:2018-07-22 10:38:19 第:962个线程当前时间:2018-07-22 10:38:59
- 【输出>>>>】test:2018-07-22 10:38:19 第:961个线程当前时间:2018-07-22 10:38:59
- 【输出>>>>】test:2018-07-22 10:38:19 第:956个线程当前时间:2018-07-22 10:38:59
- 【输出>>>>】test:2018-07-22 10:38:19 第:958个线程当前时间:2018-07-22 10:38:59
- no remain redis from pool
- no remain redis from pool
- no remain redis from pool
- 【输出>>>>】test:2018-07-22 10:38:19 第:948个线程当前时间:2018-07-22 10:39:09
- 【输出>>>>】test:2018-07-22 10:38:19 第:953个线程当前时间:2018-07-22 10:39:09
- 【输出>>>>】test:2018-07-22 10:38:19 第:925个线程当前时间:2018-07-22 10:39:09
- 【输出>>>>】test:2018-07-22 10:38:19 第:938个线程当前时间:2018-07-22 10:39:09
- 【输出>>>>】test:2018-07-22 10:38:19 第:937个线程当前时间:2018-07-22 10:39:09
- 【输出>>>>】test:2018-07-22 10:38:19 第:935个线程当前时间:2018-07-22 10:39:09
- 【输出>>>>】test:2018-07-22 10:38:19 第:936个线程当前时间:2018-07-22 10:39:09
- 【输出>>>>】test:2018-07-22 10:38:19 第:950个线程当前时间:2018-07-22 10:39:09
- 【输出>>>>】test:2018-07-22 10:38:19 第:934个线程当前时间:2018-07-22 10:39:09
- 【输出>>>>】test:2018-07-22 10:38:19 第:933个线程当前时间:2018-07-22 10:39:09
- no remain redis from pool
- no remain redis from pool
- no remain redis from pool
- 【输出>>>>】test:2018-07-22 10:38:19 第:945个线程当前时间:2018-07-22 10:39:19
- 【输出>>>>】test:2018-07-22 10:38:19 第:923个线程当前时间:2018-07-22 10:39:19
- 【输出>>>>】test:2018-07-22 10:38:19 第:944个线程当前时间:2018-07-22 10:39:19
- 【输出>>>>】test:2018-07-22 10:38:19 第:919个线程当前时间:2018-07-22 10:39:19
- 【输出>>>>】test:2018-07-22 10:38:19 第:940个线程当前时间:2018-07-22 10:39:19
- 【输出>>>>】test:2018-07-22 10:38:19 第:942个线程当前时间:2018-07-22 10:39:19
- 【输出>>>>】test:2018-07-22 10:38:19 第:932个线程当前时间:2018-07-22 10:39:19
- 【输出>>>>】test:2018-07-22 10:38:19 第:941个线程当前时间:2018-07-22 10:39:19
- 【输出>>>>】test:2018-07-22 10:38:19 第:930个线程当前时间:2018-07-22 10:39:19
- 【输出>>>>】test:2018-07-22 10:38:19 第:929个线程当前时间:2018-07-22 10:39:19
- no remain redis from pool
- no remain redis from pool
- no remain redis from pool
- 【输出>>>>】test:2018-07-22 10:38:19 第:917个线程当前时间:2018-07-22 10:39:29
- 【输出>>>>】test:2018-07-22 10:38:19 第:918个线程当前时间:2018-07-22 10:39:29
- 【输出>>>>】test:2018-07-22 10:38:19 第:898个线程当前时间:2018-07-22 10:39:29
- 【输出>>>>】test:2018-07-22 10:38:19 第:913个线程当前时间:2018-07-22 10:39:29
- 【输出>>>>】test:2018-07-22 10:38:19 第:895个线程当前时间:2018-07-22 10:39:29
- 【输出>>>>】test:2018-07-22 10:38:19 第:915个线程当前时间:2018-07-22 10:39:29
- 【输出>>>>】test:2018-07-22 10:38:19 第:893个线程当前时间:2018-07-22 10:39:29
- 【输出>>>>】test:2018-07-22 10:38:19 第:926个线程当前时间:2018-07-22 10:39:29
- 【输出>>>>】test:2018-07-22 10:38:19 第:855个线程当前时间:2018-07-22 10:39:29
- 【输出>>>>】test:2018-07-22 10:38:19 第:924个线程当前时间:2018-07-22 10:39:29
- no remain redis from pool
- no remain redis from pool
- no remain redis from pool
- 【输出>>>>】test:2018-07-22 10:38:19 第:908个线程当前时间:2018-07-22 10:39:39
- 【输出>>>>】test:2018-07-22 10:38:19 第:882个线程当前时间:2018-07-22 10:39:39
- 【输出>>>>】test:2018-07-22 10:38:19 第:775个线程当前时间:2018-07-22 10:39:39
- 【输出>>>>】test:2018-07-22 10:38:19 第:914个线程当前时间:2018-07-22 10:39:39
- 【输出>>>>】test:2018-07-22 10:38:19 第:901个线程当前时间:2018-07-22 10:39:39
- 【输出>>>>】test:2018-07-22 10:38:19 第:916个线程当前时间:2018-07-22 10:39:39
- 【输出>>>>】test:2018-07-22 10:38:19 第:877个线程当前时间:2018-07-22 10:39:39
- 【输出>>>>】test:2018-07-22 10:38:19 第:837个线程当前时间:2018-07-22 10:39:39
- 【输出>>>>】test:2018-07-22 10:38:19 第:897个线程当前时间:2018-07-22 10:39:39
- 【输出>>>>】test:2018-07-22 10:38:19 第:912个线程当前时间:2018-07-22 10:39:39
- no remain redis from pool
- no remain redis from pool
- no remain redis from pool
- 【输出>>>>】test:2018-07-22 10:38:19 第:907个线程当前时间:2018-07-22 10:39:49
- 【输出>>>>】test:2018-07-22 10:38:19 第:889个线程当前时间:2018-07-22 10:39:49
- 【输出>>>>】test:2018-07-22 10:38:19 第:910个线程当前时间:2018-07-22 10:39:49
- 【输出>>>>】test:2018-07-22 10:38:19 第:885个线程当前时间:2018-07-22 10:39:49
- 【输出>>>>】test:2018-07-22 10:38:19 第:909个线程当前时间:2018-07-22 10:39:49
- 【输出>>>>】test:2018-07-22 10:38:19 第:884个线程当前时间:2018-07-22 10:39:49
- 【输出>>>>】test:2018-07-22 10:38:19 第:886个线程当前时间:2018-07-22 10:39:49
- 【输出>>>>】test:2018-07-22 10:38:19 第:883个线程当前时间:2018-07-22 10:39:49
- 【输出>>>>】test:2018-07-22 10:38:19 第:881个线程当前时间:2018-07-22 10:39:49
- 【输出>>>>】test:2018-07-22 10:38:19 第:880个线程当前时间:2018-07-22 10:39:49
- no remain redis from pool
- no remain redis from pool
- no remain redis from pool
- 【输出>>>>】test:2018-07-22 10:38:19 第:906个线程当前时间:2018-07-22 10:39:59
- 【输出>>>>】test:2018-07-22 10:38:19 第:875个线程当前时间:2018-07-22 10:39:59
- 【输出>>>>】test:2018-07-22 10:38:19 第:902个线程当前时间:2018-07-22 10:39:59
- 【输出>>>>】test:2018-07-22 10:38:19 第:863个线程当前时间:2018-07-22 10:39:59
- 【输出>>>>】test:2018-07-22 10:38:19 第:905个线程当前时间:2018-07-22 10:39:59
- 【输出>>>>】test:2018-07-22 10:38:19 第:859个线程当前时间:2018-07-22 10:39:59
- 【输出>>>>】test:2018-07-22 10:38:19 第:800个线程当前时间:2018-07-22 10:39:59
- 【输出>>>>】test:2018-07-22 10:38:19 第:851个线程当前时间:2018-07-22 10:39:59
- 【输出>>>>】test:2018-07-22 10:38:19 第:903个线程当前时间:2018-07-22 10:39:59
- 【输出>>>>】test:2018-07-22 10:38:19 第:904个线程当前时间:2018-07-22 10:39:59
- no remain redis from pool
- no remain redis from pool
- no remain redis from pool
- 【输出>>>>】test:2018-07-22 10:38:19 第:845个线程当前时间:2018-07-22 10:40:10
- 【输出>>>>】test:2018-07-22 10:38:19 第:894个线程当前时间:2018-07-22 10:40:10
- 【输出>>>>】test:2018-07-22 10:38:19 第:809个线程当前时间:2018-07-22 10:40:10
- 【输出>>>>】test:2018-07-22 10:38:19 第:838个线程当前时间:2018-07-22 10:40:10
- 【输出>>>>】test:2018-07-22 10:38:19 第:896个线程当前时间:2018-07-22 10:40:10
- 【输出>>>>】test:2018-07-22 10:38:19 第:796个线程当前时间:2018-07-22 10:40:10
- 【输出>>>>】test:2018-07-22 10:38:19 第:899个线程当前时间:2018-07-22 10:40:10
- 【输出>>>>】test:2018-07-22 10:38:19 第:874个线程当前时间:2018-07-22 10:40:10
- 【输出>>>>】test:2018-07-22 10:38:19 第:872个线程当前时间:2018-07-22 10:40:10
- 【输出>>>>】test:2018-07-22 10:38:19 第:873个线程当前时间:2018-07-22 10:40:10
- no remain redis from pool
- no remain redis from pool
- no remain redis from pool
- 【输出>>>>】test:2018-07-22 10:38:19 第:821个线程当前时间:2018-07-22 10:40:20
- 【输出>>>>】test:2018-07-22 10:38:19 第:891个线程当前时间:2018-07-22 10:40:20
- 【输出>>>>】test:2018-07-22 10:38:19 第:782个线程当前时间:2018-07-22 10:40:20
- 【输出>>>>】test:2018-07-22 10:38:19 第:826个线程当前时间:2018-07-22 10:40:20
- 【输出>>>>】test:2018-07-22 10:38:19 第:825个线程当前时间:2018-07-22 10:40:20
- 【输出>>>>】test:2018-07-22 10:38:19 第:824个线程当前时间:2018-07-22 10:40:20
- 【输出>>>>】test:2018-07-22 10:38:19 第:829个线程当前时间:2018-07-22 10:40:20
- 【输出>>>>】test:2018-07-22 10:38:19 第:816个线程当前时间:2018-07-22 10:40:20
- 【输出>>>>】test:2018-07-22 10:38:19 第:890个线程当前时间:2018-07-22 10:40:20
- 【输出>>>>】test:2018-07-22 10:38:19 第:765个线程当前时间:2018-07-22 10:40:23
- no remain redis from pool
- no remain redis from pool
- 【输出>>>>】test:2018-07-22 10:38:19 第:818个线程当前时间:2018-07-22 10:40:30
- 【输出>>>>】test:2018-07-22 10:38:19 第:887个线程当前时间:2018-07-22 10:40:30
- 【输出>>>>】test:2018-07-22 10:38:19 第:843个线程当前时间:2018-07-22 10:40:30
- 【输出>>>>】test:2018-07-22 10:38:19 第:819个线程当前时间:2018-07-22 10:40:30
- 【输出>>>>】test:2018-07-22 10:38:19 第:878个线程当前时间:2018-07-22 10:40:30
- 【输出>>>>】test:2018-07-22 10:38:19 第:803个线程当前时间:2018-07-22 10:40:30
- 【输出>>>>】test:2018-07-22 10:38:19 第:811个线程当前时间:2018-07-22 10:40:30
- 【输出>>>>】test:2018-07-22 10:38:19 第:807个线程当前时间:2018-07-22 10:40:30
- 【输出>>>>】test:2018-07-22 10:38:19 第:876个线程当前时间:2018-07-22 10:40:30
- 【输出>>>>】test:2018-07-22 10:38:19 第:795个线程当前时间:2018-07-22 10:40:33
- no remain redis from pool
- no remain redis from pool
- 【输出>>>>】test:2018-07-22 10:38:19 第:791个线程当前时间:2018-07-22 10:40:40
- 【输出>>>>】test:2018-07-22 10:38:19 第:779个线程当前时间:2018-07-22 10:40:40
- 【输出>>>>】test:2018-07-22 10:38:19 第:835个线程当前时间:2018-07-22 10:40:40
- 【输出>>>>】test:2018-07-22 10:38:19 第:771个线程当前时间:2018-07-22 10:40:40
- 【输出>>>>】test:2018-07-22 10:38:19 第:814个线程当前时间:2018-07-22 10:40:40
- 【输出>>>>】test:2018-07-22 10:38:19 第:810个线程当前时间:2018-07-22 10:40:40
- 【输出>>>>】test:2018-07-22 10:38:19 第:839个线程当前时间:2018-07-22 10:40:40
- 【输出>>>>】test:2018-07-22 10:38:19 第:774个线程当前时间:2018-07-22 10:40:40
- 【输出>>>>】test:2018-07-22 10:38:19 第:763个线程当前时间:2018-07-22 10:40:40
- 【输出>>>>】test:2018-07-22 10:38:19 第:759个线程当前时间:2018-07-22 10:40:43
- no remain redis from pool
- no remain redis from pool
- 【输出>>>>】test:2018-07-22 10:38:19 第:856个线程当前时间:2018-07-22 10:40:50
- 【输出>>>>】test:2018-07-22 10:38:19 第:854个线程当前时间:2018-07-22 10:40:50
- 【输出>>>>】test:2018-07-22 10:38:19 第:857个线程当前时间:2018-07-22 10:40:50
- 【输出>>>>】test:2018-07-22 10:38:19 第:755个线程当前时间:2018-07-22 10:40:50
- 【输出>>>>】test:2018-07-22 10:38:19 第:862个线程当前时间:2018-07-22 10:40:50
- 【输出>>>>】test:2018-07-22 10:38:19 第:861个线程当前时间:2018-07-22 10:40:50
- 【输出>>>>】test:2018-07-22 10:38:19 第:864个线程当前时间:2018-07-22 10:40:50
- 【输出>>>>】test:2018-07-22 10:38:19 第:858个线程当前时间:2018-07-22 10:40:50
- 【输出>>>>】test:2018-07-22 10:38:19 第:860个线程当前时间:2018-07-22 10:40:50
- 【输出>>>>】test:2018-07-22 10:38:19 第:853个线程当前时间:2018-07-22 10:40:53
- no remain redis from pool
- no remain redis from pool
- 【输出>>>>】test:2018-07-22 10:38:19 第:848个线程当前时间:2018-07-22 10:41:00
- 【输出>>>>】test:2018-07-22 10:38:19 第:850个线程当前时间:2018-07-22 10:41:00
- 【输出>>>>】test:2018-07-22 10:38:19 第:806个线程当前时间:2018-07-22 10:41:00
- 【输出>>>>】test:2018-07-22 10:38:19 第:743个线程当前时间:2018-07-22 10:41:00
- 【输出>>>>】test:2018-07-22 10:38:19 第:846个线程当前时间:2018-07-22 10:41:00
- 【输出>>>>】test:2018-07-22 10:38:19 第:844个线程当前时间:2018-07-22 10:41:00
- 【输出>>>>】test:2018-07-22 10:38:19 第:842个线程当前时间:2018-07-22 10:41:00
- 【输出>>>>】test:2018-07-22 10:38:19 第:841个线程当前时间:2018-07-22 10:41:00
- 【输出>>>>】test:2018-07-22 10:38:19 第:840个线程当前时间:2018-07-22 10:41:00
- no remain redis from pool
- 【输出>>>>】test:2018-07-22 10:38:19 第:712个线程当前时间:2018-07-22 10:41:05
- no remain redis from pool
- 【输出>>>>】test:2018-07-22 10:38:19 第:727个线程当前时间:2018-07-22 10:41:10
- 【输出>>>>】test:2018-07-22 10:38:19 第:704个线程当前时间:2018-07-22 10:41:10
- 【输出>>>>】test:2018-07-22 10:38:19 第:725个线程当前时间:2018-07-22 10:41:10
- 【输出>>>>】test:2018-07-22 10:38:19 第:834个线程当前时间:2018-07-22 10:41:10
- 【输出>>>>】test:2018-07-22 10:38:19 第:798个线程当前时间:2018-07-22 10:41:10
- 【输出>>>>】test:2018-07-22 10:38:19 第:726个线程当前时间:2018-07-22 10:41:10
- 【输出>>>>】test:2018-07-22 10:38:19 第:801个线程当前时间:2018-07-22 10:41:10
- 【输出>>>>】test:2018-07-22 10:38:19 第:722个线程当前时间:2018-07-22 10:41:10
- 【输出>>>>】test:2018-07-22 10:38:19 第:833个线程当前时间:2018-07-22 10:41:10
- no remain redis from pool
- 【输出>>>>】test:2018-07-22 10:38:19 第:699个线程当前时间:2018-07-22 10:41:15
- no remain redis from pool
- 【输出>>>>】test:2018-07-22 10:38:19 第:797个线程当前时间:2018-07-22 10:41:20
- 【输出>>>>】test:2018-07-22 10:38:19 第:679个线程当前时间:2018-07-22 10:41:20
- 【输出>>>>】test:2018-07-22 10:38:19 第:832个线程当前时间:2018-07-22 10:41:20
- 【输出>>>>】test:2018-07-22 10:38:19 第:667个线程当前时间:2018-07-22 10:41:20
- 【输出>>>>】test:2018-07-22 10:38:19 第:817个线程当前时间:2018-07-22 10:41:20
- 【输出>>>>】test:2018-07-22 10:38:19 第:830个线程当前时间:2018-07-22 10:41:20
- 【输出>>>>】test:2018-07-22 10:38:19 第:786个线程当前时间:2018-07-22 10:41:20
- 【输出>>>>】test:2018-07-22 10:38:19 第:828个线程当前时间:2018-07-22 10:41:20
- 【输出>>>>】test:2018-07-22 10:38:19 第:706个线程当前时间:2018-07-22 10:41:20
Redis连接池-Java代码的更多相关文章
- Java Redis 连接池 Jedis 工具类
import org.slf4j.Logger; import org.slf4j.LoggerFactory; import redis.clients.jedis.Jedis; import re ...
- java操作redis redis连接池
redis作为缓存型数据库,越来越受到大家的欢迎,这里简单介绍一下java如何操作redis. 1.java连接redis java通过需要jedis的jar包获取Jedis连接. jedis-2.8 ...
- Redis】Java中使用Jedis操作Redis(Maven导入包)、创建Redis连接池
如果我们使用Java操作Redis, 需要确保已经安装了 redis 服务及 Java redis 驱动. Maven项目可以直接在pom.xml中加入jedis包驱动: <!-- https: ...
- 这个 Redis 连接池的新监控方式针不戳~我再加一点佐料
Lettuce 是一个 Redis 连接池,和 Jedis 不一样的是,Lettuce 是主要基于 Netty 以及 ProjectReactor 实现的异步连接池.由于基于 ProjectReact ...
- 三:Redis连接池、JedisPool详解、Redisi分布式
单机模式: package com.ljq.utils; import redis.clients.jedis.Jedis; import redis.clients.jedis.JedisPool; ...
- redis连接池 jedis-2.9.0.jar+commons-pool2-2.4.2.jar
java使用Redis连接池 jar包为 jedis-2.9.0.jar+commons-pool2-2.4.2.jar jar下载地址 package com.test; import redis ...
- Go语言之从0到1实现一个简单的Redis连接池
Go语言之从0到1实现一个简单的Redis连接池 前言 最近学习了一些Go语言开发相关内容,但是苦于手头没有可以练手的项目,学的时候理解不清楚,学过容易忘. 结合之前组内分享时学到的Redis相关知识 ...
- golang开发:类库篇(二) Redis连接池的使用
为什么要使用连接池 一个数据库服务器只拥有有限的连接资源,一旦所有的连接资源都在使用,那么其它需要连接的资源就只能等待释放连接资源.所以,在连接资源有限的情况下,提高单位时间的连接的使用效率,缩短连接 ...
- Swoole Redis 连接池的实现
概述 这是关于 Swoole 入门学习的第九篇文章:Swoole Redis 连接池的实现. 第八篇:Swoole MySQL 连接池的实现 第七篇:Swoole RPC 的实现 第六篇:Swoole ...
随机推荐
- jQuery实现发送验证码30s倒计时,且刷新页面时有效
在这里讲一讲这个案例的实现思路吧(个人见解)..核心思想:为防止页面刷新时倒计时失效的解决方案是:当每次刷新一次页面时都执行一个函数 即下面讲到的 setStyle() 函数.这个函数会根据当前的 c ...
- npm init,npm -y, npm install --save,npm install --save-dev
npm init 初始化一个简单的package.json文件,执行该命令后终端会依次询问 name, version, description 等字段 npm init --yes|-y 作用同上, ...
- 逆向破解之160个CrackMe —— 026
CrackMe —— 026 160 CrackMe 是比较适合新手学习逆向破解的CrackMe的一个集合一共160个待逆向破解的程序 CrackMe:它们都是一些公开给别人尝试破解的小程序,制作 c ...
- Windows Server 2008 R2
Windows Server 2008 R2 Windows Server Core 微软因为向往 Linux 的纯命令行, 提出了 Windows Server Core 只能使用命令, 但是只要配 ...
- list 分批
public class TestList { public static void main(String[] args){ List<Integer> list = new Array ...
- HTML(四)图像,表格
HTML 图像 插入动图的语法和静态图的语法是一样的 HTML 图像- 图像标签( )和源属性(Src) 一个来自文件夹中的图像: 一个来自网站的图像: alt 属性用来为图像定义一串预备的可替换的文 ...
- P3225 [HNOI2012]矿场搭建 割点 tarjan 双联通分量
https://www.luogu.org/problemnew/show/P3225 题意 煤矿工地可以看成是由隧道连接挖煤点组成的无向图.为安全起见,希望在工地发生事故时所有挖煤点的工人都能有一条 ...
- win10 无法安装/启用 .net framework 3.5
有些程序依赖.net framework 3.5 win10可以在控制面板->程序和功能->启用或关闭windows功能 启用 但有时会报错 比如 0x800f0950 官方论坛的解决办法 ...
- Matlab2016b破解安装教程——超详细
一.MATLAB是什么 MATLAB :是美国MathWorks公司出品的商业数学软件,用于算法开发.数据可视化.数据分析以及数值计算的高级技术计算语言和交互式环境,主要包括MATLAB和Simuli ...
- Django-开放静态资源-获取请求携带的数据-pychram连接数据库-修改Django默认数据库-DjangoORM操作--表管理-记录管理-01
目录 关于静态资源访问 为什么要配置静态文件才能获取静态资源 常见的静态文件种类 如何配置来开启访问权限 禁用浏览器缓存 django的自动重启机制(热启动) 静态文件接口动态解析 向服务器发送数据 ...