當前位置: 首頁>>代碼示例>>Java>>正文


Java JedisConnectionException類代碼示例

本文整理匯總了Java中redis.clients.jedis.exceptions.JedisConnectionException的典型用法代碼示例。如果您正苦於以下問題:Java JedisConnectionException類的具體用法?Java JedisConnectionException怎麽用?Java JedisConnectionException使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


JedisConnectionException類屬於redis.clients.jedis.exceptions包,在下文中一共展示了JedisConnectionException類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: isAvailable

import redis.clients.jedis.exceptions.JedisConnectionException; //導入依賴的package包/類
public boolean isAvailable() {
    for (JedisPool jedisPool : jedisPools.values()) {
        Jedis jedis = jedisPool.getResource();
        boolean isBroken = false;
        try {
            if (jedis.isConnected()) {
                return true; // 至少需單台機器可用
            }
        } catch (JedisConnectionException e) {
            isBroken = true;
        } finally {
            if (isBroken) {
                jedisPool.returnBrokenResource(jedis);
            } else {
                jedisPool.returnResource(jedis);
            }
        }
    }
    return false;
}
 
開發者ID:zhuxiaolei,項目名稱:dubbo2,代碼行數:21,代碼來源:RedisRegistry.java

示例2: onMessage

import redis.clients.jedis.exceptions.JedisConnectionException; //導入依賴的package包/類
@Override
public void onMessage(String key, String msg) {
    if (logger.isInfoEnabled()) {
        logger.info("redis event: " + key + " = " + msg);
    }
    if (msg.equals(Constants.REGISTER)
            || msg.equals(Constants.UNREGISTER)) {
        try {
            Jedis jedis = jedisPool.getResource();
            boolean isBroken = false;
            try {
                doNotify(jedis, key);
            } catch (JedisConnectionException e){
                isBroken = true;
            } finally {
                if(isBroken){
                    jedisPool.returnBrokenResource(jedis);
                } else {
                    jedisPool.returnResource(jedis);
                }
            }
        } catch (Throwable t) { // TODO 通知失敗沒有恢複機製保障
            logger.error(t.getMessage(), t);
        }
    }
}
 
開發者ID:flychao88,項目名稱:dubbocloud,代碼行數:27,代碼來源:RedisRegistry.java

示例3: rpop

import redis.clients.jedis.exceptions.JedisConnectionException; //導入依賴的package包/類
public String rpop(String key) {
    Jedis jedis = null;
    try {
        jedis = getJedis();
        if (jedis == null) {
            logger.error("get jedis failed.");
            return null;
        }
        return jedis.rpop(key);
    } catch (JedisConnectionException e) {
        if (jedis != null) {
            jedis.close();
            jedis = null;
        }
        logger.error("increame connect error:", e);
    } finally {
        returnJedisResource(jedis);
    }
    return null;
}
 
開發者ID:Zephery,項目名稱:newblog,代碼行數:21,代碼來源:JedisUtil.java

示例4: toJedisPool0

import redis.clients.jedis.exceptions.JedisConnectionException; //導入依賴的package包/類
private JedisPool toJedisPool0() {
    return new JedisPool(new GenericObjectPoolConfig(), this.getHost(), this.getPort(), this.getTimeout(), this.getPassword(), this.getDatabase()) {
        @Override
        public Jedis getResource() {
            try {
                return super.getResource();
            } catch (JedisConnectionException var2) {
                RedisConfig.LOGGER.error(RedisConfig.this.toString(), var2);
                throw new JedisConnectionException(RedisConfig.this.toString(), var2);
            }
        }

        @Override
        public void close() {
        }
    };
}
 
開發者ID:wxz1211,項目名稱:dooo,代碼行數:18,代碼來源:RedisConfig.java

示例5: available

import redis.clients.jedis.exceptions.JedisConnectionException; //導入依賴的package包/類
@Override
public boolean available() {
    for (JedisPool jedisPool : jedisPools.values()) {
        Jedis jedis = jedisPool.getResource();
        try {
            if (jedis.isConnected()) {
                return true; // 至少需單台機器可用
            }
        } catch (JedisConnectionException e) {
        	logger.error("Jedis Connection Exception", e);
        } finally {
        	if(jedis != null){
            	jedis.close();
            }
        }
    }
    return false;
}
 
開發者ID:yu120,項目名稱:coon,代碼行數:19,代碼來源:RedisMreg.java

示例6: disconnect

import redis.clients.jedis.exceptions.JedisConnectionException; //導入依賴的package包/類
@SuppressWarnings("finally")
public boolean disconnect() {
	if (isConnected()) {
		try {
			outputStream.flush();
			socket.close();
			return true;
		} catch (IOException ex) {
			broken = true;
			throw new JedisConnectionException(ex);
		} finally {
			closeQuietly(socket);
			return true;
		}
	}
	return false;
}
 
開發者ID:qq1588518,項目名稱:JRediClients,代碼行數:18,代碼來源:Connection.java

示例7: sendCommand

import redis.clients.jedis.exceptions.JedisConnectionException; //導入依賴的package包/類
private static void sendCommand(final RedisOutputStream os, final byte[] command, final byte[]... args) {
	try {
		os.write(ASTERISK_BYTE);
		os.writeIntCrLf(args.length + 1);
		os.write(DOLLAR_BYTE);
		os.writeIntCrLf(command.length);
		os.write(command);
		os.writeCrLf();

		for (final byte[] arg : args) {
			os.write(DOLLAR_BYTE);
			os.writeIntCrLf(arg.length);
			os.write(arg);
			os.writeCrLf();
		}
	} catch (IOException e) {
		throw new JedisConnectionException(e);
	}
}
 
開發者ID:qq1588518,項目名稱:JRediClients,代碼行數:20,代碼來源:Protocol.java

示例8: process

import redis.clients.jedis.exceptions.JedisConnectionException; //導入依賴的package包/類
private static Object process(final RedisInputStream is) {

		final byte b = is.readByte();
		if (b == PLUS_BYTE) {
			return processStatusCodeReply(is);
		} else if (b == DOLLAR_BYTE) {
			return processBulkReply(is);
		} else if (b == ASTERISK_BYTE) {
			return processMultiBulkReply(is);
		} else if (b == COLON_BYTE) {
			return processInteger(is);
		} else if (b == MINUS_BYTE) {
			processError(is);
			return null;
		} else {
			throw new JedisConnectionException("Unknown reply: " + (char) b);
		}
	}
 
開發者ID:qq1588518,項目名稱:JRediClients,代碼行數:19,代碼來源:Protocol.java

示例9: processBulkReply

import redis.clients.jedis.exceptions.JedisConnectionException; //導入依賴的package包/類
private static byte[] processBulkReply(final RedisInputStream is) {
	final int len = is.readIntCrLf();
	if (len == -1) {
		return null;
	}

	final byte[] read = new byte[len];
	int offset = 0;
	while (offset < len) {
		final int size = is.read(read, offset, (len - offset));
		if (size == -1)
			throw new JedisConnectionException("It seems like server has closed the connection.");
		offset += size;
	}

	// read 2 more bytes for the command delimiter
	is.readByte();
	is.readByte();

	return read;
}
 
開發者ID:qq1588518,項目名稱:JRediClients,代碼行數:22,代碼來源:Protocol.java

示例10: process

import redis.clients.jedis.exceptions.JedisConnectionException; //導入依賴的package包/類
private static Object process(final RedisInputStream is) {

    final byte b = is.readByte();
    if (b == PLUS_BYTE) {
      return processStatusCodeReply(is);
    } else if (b == DOLLAR_BYTE) {
      return processBulkReply(is);
    } else if (b == ASTERISK_BYTE) {
      return processMultiBulkReply(is);
    } else if (b == COLON_BYTE) {
      return processInteger(is);
    } else if (b == MINUS_BYTE) {
      processError(is);
      return null;
    } else {
      throw new JedisConnectionException("Unknown reply: " + (char) b);
    }
  }
 
開發者ID:x7-framework,項目名稱:x7,代碼行數:19,代碼來源:Protocol.java

示例11: scriptExistsWithBrokenConnection

import redis.clients.jedis.exceptions.JedisConnectionException; //導入依賴的package包/類
@Test
public void scriptExistsWithBrokenConnection() {
  Jedis deadClient = new Jedis(jedis.getClient().getHost(), jedis.getClient().getPort());
  deadClient.auth("foobared");

  deadClient.clientSetname("DEAD");

  ClientKillerUtil.killClient(deadClient, "DEAD");

  // sure, script doesn't exist, but it's just for checking connection
  try {
    deadClient.scriptExists("abcdefg");
  } catch (JedisConnectionException e) {
    // ignore it
  }

  assertEquals(true, deadClient.getClient().isBroken());

  deadClient.close();
}
 
開發者ID:qq1588518,項目名稱:JRediClients,代碼行數:21,代碼來源:ScriptingCommandsTest.java

示例12: getErrorAfterConnectionReset

import redis.clients.jedis.exceptions.JedisConnectionException; //導入依賴的package包/類
@Test
public void getErrorAfterConnectionReset() throws Exception {
  class TestConnection extends Connection {
    public TestConnection() {
      super("localhost", 6379);
    }

    protected boolean sendCommand(Command cmd, byte[]... args) {
      return super.sendCommand(cmd, args);
    }
  }

  TestConnection conn = new TestConnection();

  try {
    conn.sendCommand(Command.HMSET, new byte[1024 * 1024 + 1][0]);
    fail("Should throw exception");
  } catch (JedisConnectionException jce) {
    assertEquals("ERR Protocol error: invalid multibulk length", jce.getMessage());
  }
}
 
開發者ID:qq1588518,項目名稱:JRediClients,代碼行數:22,代碼來源:ConnectionTest.java

示例13: connectWithShardInfoAndCustomHostnameVerifierByIpAddress

import redis.clients.jedis.exceptions.JedisConnectionException; //導入依賴的package包/類
/**
 * Tests opening an SSL/TLS connection to redis with a custom hostname
 * verifier. This test should fail because "127.0.0.1" does not match the
 * certificate subject common name and there are no subject alternative names
 * in the certificate.
 */
@Test
public void connectWithShardInfoAndCustomHostnameVerifierByIpAddress() {
  final URI uri = URI.create("rediss://127.0.0.1:6390");
  final SSLSocketFactory sslSocketFactory = (SSLSocketFactory) SSLSocketFactory.getDefault();
  final SSLParameters sslParameters = new SSLParameters();

  HostnameVerifier hostnameVerifier = new BasicHostnameVerifier();
  JedisShardInfo shardInfo = new JedisShardInfo(uri, sslSocketFactory, sslParameters, hostnameVerifier);
  shardInfo.setPassword("foobared");

  Jedis jedis = new Jedis(shardInfo);
  try {
    jedis.get("foo");
    Assert.fail("The code did not throw the expected JedisConnectionException.");
  } catch (JedisConnectionException e) {
    Assert.assertEquals("The JedisConnectionException does not contain the expected message.",
        "The connection to '127.0.0.1' failed ssl/tls hostname verification.", e.getMessage());
  }

  try {
    jedis.close();
  } catch (Throwable e1) {
    // Expected.
  }
}
 
開發者ID:qq1588518,項目名稱:JRediClients,代碼行數:32,代碼來源:SSLJedisTest.java

示例14: timeoutConnection

import redis.clients.jedis.exceptions.JedisConnectionException; //導入依賴的package包/類
@Test(expected = JedisConnectionException.class)
public void timeoutConnection() throws Exception {
  jedis = new Jedis("localhost", 6379, 15000);
  jedis.auth("foobared");
  jedis.configSet("timeout", "1");
  Thread.sleep(2000);
  jedis.hmget("foobar", "foo");
}
 
開發者ID:qq1588518,項目名稱:JRediClients,代碼行數:9,代碼來源:JedisTest.java

示例15: get

import redis.clients.jedis.exceptions.JedisConnectionException; //導入依賴的package包/類
public String get(String key) {
    Jedis jedis = null;
    String result = "";
    try {
        jedis = getJedis();
        if (jedis != null) {
            result = jedis.get(key);
        } else {
            logger.error("get opt connection null error!");
        }
    } catch (JedisConnectionException e) {
        if (jedis != null) {
            jedis.close();
            jedis = null;
        }
        logger.error("get value connect error:", e);
    } finally {
        returnJedisResource(jedis);
    }
    return result;
}
 
開發者ID:Zephery,項目名稱:newblog,代碼行數:22,代碼來源:JedisUtil.java


注:本文中的redis.clients.jedis.exceptions.JedisConnectionException類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。