com.landawn.abacus.cache.JRedis Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of abacus-cache Show documentation
Show all versions of abacus-cache Show documentation
Abacus Data Access and Analysis
The newest version!
/*
* Copyright (C) 2015 HaiYang Li
*
* Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except
* in compliance with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software distributed under the License
* is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express
* or implied. See the License for the specific language governing permissions and limitations under
* the License.
*/
package com.landawn.abacus.cache;
import java.net.InetSocketAddress;
import java.util.ArrayList;
import java.util.Collection;
import java.util.List;
import com.landawn.abacus.parser.KryoParser;
import com.landawn.abacus.parser.ParserFactory;
import com.landawn.abacus.util.AddrUtil;
import com.landawn.abacus.util.Charsets;
import com.landawn.abacus.util.N;
import redis.clients.jedis.BinaryShardedJedis;
import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisShardInfo;
/**
*
* @param
*/
@SuppressWarnings("deprecation")
public class JRedis extends AbstractDistributedCacheClient {
private static final KryoParser kryoParser = ParserFactory.createKryoParser();
private final BinaryShardedJedis jedis;
/**
*
*
* @param serverUrl
*/
public JRedis(final String serverUrl) {
this(serverUrl, DEFAULT_TIMEOUT);
}
/**
*
*
* @param serverUrl
* @param timeout
*/
public JRedis(final String serverUrl, final long timeout) {
super(serverUrl);
final List addressList = AddrUtil.getAddressList(serverUrl);
final List jedisClusterNodes = new ArrayList<>();
for (final InetSocketAddress addr : addressList) {
jedisClusterNodes.add(new JedisShardInfo(addr.getHostName(), addr.getPort(), (int) timeout));
}
jedis = new BinaryShardedJedis(jedisClusterNodes);
}
/**
*
* @param key
* @return
*/
@Override
public T get(final String key) {
return decode(jedis.get(getKeyBytes(key)));
}
/**
*
* @param key
* @param obj
* @param liveTime
* @return true, if successful
*/
@Override
public boolean set(final String key, final T obj, final long liveTime) {
jedis.setex(getKeyBytes(key), toSeconds(liveTime), encode(obj));
return true;
}
/**
*
* @param key
* @return true, if successful
*/
@Override
public boolean delete(final String key) {
jedis.del(getKeyBytes(key));
return true;
}
/**
*
* @param key
* @return
*/
@Override
public long incr(final String key) {
return jedis.incr(getKeyBytes(key));
}
/**
*
* @param key
* @param deta
* @return
*/
@Override
public long incr(final String key, final int deta) {
return jedis.incrBy(getKeyBytes(key), deta);
}
/**
*
* @param key
* @return
*/
@Override
public long decr(final String key) {
return jedis.decr(getKeyBytes(key));
}
/**
*
* @param key
* @param deta
* @return
*/
@Override
public long decr(final String key, final int deta) {
return jedis.decrBy(getKeyBytes(key), deta);
}
/**
* Flush all.
*/
@Override
public void flushAll() {
final Collection allShards = jedis.getAllShards();
for (final Jedis j : allShards) {
j.flushAll();
}
}
/**
* Disconnect.
*/
@Override
public void disconnect() {
jedis.disconnect();
}
/**
* Gets the key bytes.
*
* @param key
* @return
*/
protected byte[] getKeyBytes(final String key) {
return key.getBytes(Charsets.UTF_8);
}
/**
*
* @param obj
* @return
*/
protected byte[] encode(final Object obj) {
return obj == null ? N.EMPTY_BYTE_ARRAY : kryoParser.encode(obj);
}
/**
*
* @param bytes
* @return
*/
protected T decode(final byte[] bytes) {
return N.isEmpty(bytes) ? null : kryoParser.decode(bytes);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy