php redis 分片实现,玩转redis之redis 分片集群方案与实现

一、spring-redis配置

xmlns:context="http://www.springframework.org/schema/context" xmlns:tx="http://www.springframework.org/schema/tx"

xmlns:aop="http://www.springframework.org/schema/aop"

xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd

http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.0.xsd

http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.0.xsd

http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-2.5.xsd">

如上,在shardedJedisPool中增加多个redis分片

二、代码实现

import javax.inject.Inject;

import org.slf4j.Logger;

import org.slf4j.LoggerFactory;

import org.springframework.stereotype.Component;

import com.iflashbuy.base.util.JsonUtil;

import com.iflashbuy.base.util.StringUtil;

import redis.clients.jedis.ShardedJedis;

import redis.clients.jedis.ShardedJedisPool;

@Component

public class RedisOperator {

private static final Logger log = LoggerFactory.getLogger(RedisOperator.class);

@Inject

public ShardedJedisPool shardedJedisPool;

public void set(String key, Object obj) {

String jsonStr = "";

if (obj instanceof String) {

jsonStr = (String) obj;

} else {

jsonStr = JsonUtil.objectToJsonStr(obj);

}

ShardedJedis jedis = shardedJedisPool.getResource();

jedis.set(key, jsonStr);

}

public T get(String key, Class clazz) {

ShardedJedis jedis = shardedJedisPool.getResource();

String jsonStr = jedis.get(key);

if (StringUtil.isNotEmpty(jsonStr)) {

try {

return (T) JsonUtil.formJson(jsonStr, clazz);

} catch (Exception e) {

log.error("joson转为对象失败:" + e);

return null;

}

} else {

return null;

}

}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值