first commit
This commit is contained in:
@ -1,5 +1,7 @@
|
||||
package com.qiaoba.common.redis.service;
|
||||
|
||||
import com.qiaoba.common.base.entity.BasePage;
|
||||
|
||||
import java.util.Collection;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
@ -325,6 +327,15 @@ public interface RedisService {
|
||||
*/
|
||||
Long lRemove(String key, long count, Object value);
|
||||
|
||||
/**
|
||||
* 分页查询
|
||||
*
|
||||
* @param key key
|
||||
* @param pageNumber pageNumber
|
||||
* @param pageSize pageSize
|
||||
* @return // List<clazz>
|
||||
*/
|
||||
BasePage getPageList(String key, long pageNumber, long pageSize);
|
||||
|
||||
/**
|
||||
* 模糊查询所有key
|
||||
@ -358,11 +369,27 @@ public interface RedisService {
|
||||
/**
|
||||
* hGetObject
|
||||
*
|
||||
* @param key key
|
||||
* @param hashKey hashKey
|
||||
* @param clazz clazz
|
||||
* @param <T> T
|
||||
* @param key key
|
||||
* @param hashKey hashKey
|
||||
* @param clazz clazz
|
||||
* @param <T> T
|
||||
* @return clazz
|
||||
*/
|
||||
<T> T hGetObject(String key, String hashKey, Class<T> clazz);
|
||||
|
||||
/**
|
||||
* key添加租户前缀
|
||||
*
|
||||
* @param key key
|
||||
* @return newKey
|
||||
*/
|
||||
String addTenantPrefix(String key);
|
||||
|
||||
/**
|
||||
* key去除租户前缀
|
||||
*
|
||||
* @param key key
|
||||
* @return newKey
|
||||
*/
|
||||
String removeTenantPrefix(String key);
|
||||
}
|
||||
|
@ -1,16 +1,15 @@
|
||||
package com.qiaoba.common.redis.service.impl;
|
||||
|
||||
|
||||
import com.qiaoba.common.base.constants.BaseConstant;
|
||||
import com.qiaoba.common.base.context.BaseContext;
|
||||
import com.qiaoba.common.base.entity.BasePage;
|
||||
import com.qiaoba.common.redis.service.RedisService;
|
||||
import lombok.RequiredArgsConstructor;
|
||||
import org.springframework.data.redis.core.RedisTemplate;
|
||||
import org.springframework.stereotype.Service;
|
||||
|
||||
import java.util.Collection;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
import java.util.Set;
|
||||
import java.util.*;
|
||||
import java.util.concurrent.TimeUnit;
|
||||
import java.util.stream.Collectors;
|
||||
|
||||
@ -29,27 +28,27 @@ public class RedisServiceImpl implements RedisService {
|
||||
|
||||
@Override
|
||||
public void set(String key, Object value, long time) {
|
||||
redisTemplate.opsForValue().set(handleKey(key), value, time, TimeUnit.SECONDS);
|
||||
redisTemplate.opsForValue().set(addTenantPrefix(key), value, time, TimeUnit.SECONDS);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void set(String key, Object value) {
|
||||
redisTemplate.opsForValue().set(handleKey(key), value);
|
||||
redisTemplate.opsForValue().set(addTenantPrefix(key), value);
|
||||
}
|
||||
|
||||
@Override
|
||||
public Object get(String key) {
|
||||
return redisTemplate.opsForValue().get(handleKey(key));
|
||||
return redisTemplate.opsForValue().get(addTenantPrefix(key));
|
||||
}
|
||||
|
||||
@Override
|
||||
public Boolean del(String key) {
|
||||
return redisTemplate.delete(handleKey(key));
|
||||
return redisTemplate.delete(addTenantPrefix(key));
|
||||
}
|
||||
|
||||
@Override
|
||||
public void del(Collection<String> keys) {
|
||||
List<String> list = keys.stream().map(key -> key = handleKey(key)).collect(Collectors.toList());
|
||||
List<String> list = keys.stream().map(key -> key = addTenantPrefix(key)).collect(Collectors.toList());
|
||||
redisTemplate.delete(list);
|
||||
}
|
||||
|
||||
@ -60,91 +59,91 @@ public class RedisServiceImpl implements RedisService {
|
||||
|
||||
@Override
|
||||
public Long getExpire(String key) {
|
||||
return redisTemplate.getExpire(handleKey(key), TimeUnit.SECONDS);
|
||||
return redisTemplate.getExpire(addTenantPrefix(key), TimeUnit.SECONDS);
|
||||
}
|
||||
|
||||
@Override
|
||||
public Boolean hasKey(String key) {
|
||||
return redisTemplate.hasKey(handleKey(key));
|
||||
return redisTemplate.hasKey(addTenantPrefix(key));
|
||||
}
|
||||
|
||||
@Override
|
||||
public Long incr(String key, long delta) {
|
||||
return redisTemplate.opsForValue().increment(handleKey(key), delta);
|
||||
return redisTemplate.opsForValue().increment(addTenantPrefix(key), delta);
|
||||
}
|
||||
|
||||
@Override
|
||||
public Long decr(String key, long delta) {
|
||||
return redisTemplate.opsForValue().increment(handleKey(key), -delta);
|
||||
return redisTemplate.opsForValue().increment(addTenantPrefix(key), -delta);
|
||||
}
|
||||
|
||||
@Override
|
||||
public Object hGet(String key, String hashKey) {
|
||||
return redisTemplate.opsForHash().get(handleKey(key), hashKey);
|
||||
return redisTemplate.opsForHash().get(addTenantPrefix(key), hashKey);
|
||||
}
|
||||
|
||||
@Override
|
||||
public Boolean hSet(String key, String hashKey, Object value, long time) {
|
||||
String newKey = handleKey(key);
|
||||
String newKey = addTenantPrefix(key);
|
||||
redisTemplate.opsForHash().put(newKey, hashKey, value);
|
||||
return expire(newKey, time);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void hSet(String key, String hashKey, Object value) {
|
||||
redisTemplate.opsForHash().put(handleKey(key), hashKey, value);
|
||||
redisTemplate.opsForHash().put(addTenantPrefix(key), hashKey, value);
|
||||
}
|
||||
|
||||
@Override
|
||||
public Map<Object, Object> hGetAll(String key) {
|
||||
return redisTemplate.opsForHash().entries(handleKey(key));
|
||||
return redisTemplate.opsForHash().entries(addTenantPrefix(key));
|
||||
}
|
||||
|
||||
@Override
|
||||
public Boolean hSetAll(String key, Map<String, Object> map, long time) {
|
||||
String newKey = handleKey(key);
|
||||
String newKey = addTenantPrefix(key);
|
||||
redisTemplate.opsForHash().putAll(newKey, map);
|
||||
return expire(newKey, time);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void hSetAll(String key, Map<String, ?> map) {
|
||||
redisTemplate.opsForHash().putAll(handleKey(key), map);
|
||||
redisTemplate.opsForHash().putAll(addTenantPrefix(key), map);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void hDel(String key, Object... hashKey) {
|
||||
redisTemplate.opsForHash().delete(handleKey(key), hashKey);
|
||||
redisTemplate.opsForHash().delete(addTenantPrefix(key), hashKey);
|
||||
}
|
||||
|
||||
@Override
|
||||
public Boolean hHasKey(String key, String hashKey) {
|
||||
return redisTemplate.opsForHash().hasKey(handleKey(key), hashKey);
|
||||
return redisTemplate.opsForHash().hasKey(addTenantPrefix(key), hashKey);
|
||||
}
|
||||
|
||||
@Override
|
||||
public Long hIncr(String key, String hashKey, Long delta) {
|
||||
return redisTemplate.opsForHash().increment(handleKey(key), hashKey, delta);
|
||||
return redisTemplate.opsForHash().increment(addTenantPrefix(key), hashKey, delta);
|
||||
}
|
||||
|
||||
@Override
|
||||
public Long hDecr(String key, String hashKey, Long delta) {
|
||||
return redisTemplate.opsForHash().increment(handleKey(key), hashKey, -delta);
|
||||
return redisTemplate.opsForHash().increment(addTenantPrefix(key), hashKey, -delta);
|
||||
}
|
||||
|
||||
@Override
|
||||
public Set<Object> sMembers(String key) {
|
||||
return redisTemplate.opsForSet().members(handleKey(key));
|
||||
return redisTemplate.opsForSet().members(addTenantPrefix(key));
|
||||
}
|
||||
|
||||
@Override
|
||||
public Long sAdd(String key, Object... values) {
|
||||
return redisTemplate.opsForSet().add(handleKey(key), values);
|
||||
return redisTemplate.opsForSet().add(addTenantPrefix(key), values);
|
||||
}
|
||||
|
||||
@Override
|
||||
public Long sAdd(String key, long time, Object... values) {
|
||||
String newKey = handleKey(key);
|
||||
String newKey = addTenantPrefix(key);
|
||||
Long count = redisTemplate.opsForSet().add(newKey, values);
|
||||
expire(newKey, time);
|
||||
return count;
|
||||
@ -152,42 +151,42 @@ public class RedisServiceImpl implements RedisService {
|
||||
|
||||
@Override
|
||||
public Boolean sIsMember(String key, Object value) {
|
||||
return redisTemplate.opsForSet().isMember(handleKey(key), value);
|
||||
return redisTemplate.opsForSet().isMember(addTenantPrefix(key), value);
|
||||
}
|
||||
|
||||
@Override
|
||||
public Long sSize(String key) {
|
||||
return redisTemplate.opsForSet().size(handleKey(key));
|
||||
return redisTemplate.opsForSet().size(addTenantPrefix(key));
|
||||
}
|
||||
|
||||
@Override
|
||||
public Long sRemove(String key, Object... values) {
|
||||
return redisTemplate.opsForSet().remove(handleKey(key), values);
|
||||
return redisTemplate.opsForSet().remove(addTenantPrefix(key), values);
|
||||
}
|
||||
|
||||
@Override
|
||||
public List<Object> lRange(String key, long start, long end) {
|
||||
return redisTemplate.opsForList().range(handleKey(key), start, end);
|
||||
return redisTemplate.opsForList().range(addTenantPrefix(key), start, end);
|
||||
}
|
||||
|
||||
@Override
|
||||
public Long lSize(String key) {
|
||||
return redisTemplate.opsForList().size(handleKey(key));
|
||||
return redisTemplate.opsForList().size(addTenantPrefix(key));
|
||||
}
|
||||
|
||||
@Override
|
||||
public Object lIndex(String key, long index) {
|
||||
return redisTemplate.opsForList().index(handleKey(key), index);
|
||||
return redisTemplate.opsForList().index(addTenantPrefix(key), index);
|
||||
}
|
||||
|
||||
@Override
|
||||
public Long lPush(String key, Object value) {
|
||||
return redisTemplate.opsForList().rightPush(handleKey(key), value);
|
||||
return redisTemplate.opsForList().rightPush(addTenantPrefix(key), value);
|
||||
}
|
||||
|
||||
@Override
|
||||
public Long lPush(String key, Object value, long time) {
|
||||
String newKey = handleKey(key);
|
||||
String newKey = addTenantPrefix(key);
|
||||
Long index = redisTemplate.opsForList().rightPush(newKey, value);
|
||||
expire(newKey, time);
|
||||
return index;
|
||||
@ -195,12 +194,12 @@ public class RedisServiceImpl implements RedisService {
|
||||
|
||||
@Override
|
||||
public Long lPushAll(String key, Object... values) {
|
||||
return redisTemplate.opsForList().rightPushAll(handleKey(key), values);
|
||||
return redisTemplate.opsForList().rightPushAll(addTenantPrefix(key), values);
|
||||
}
|
||||
|
||||
@Override
|
||||
public Long lPushAll(String key, Long time, Object... values) {
|
||||
String newKey = handleKey(key);
|
||||
String newKey = addTenantPrefix(key);
|
||||
Long count = redisTemplate.opsForList().rightPushAll(newKey, values);
|
||||
expire(newKey, time);
|
||||
return count;
|
||||
@ -208,13 +207,29 @@ public class RedisServiceImpl implements RedisService {
|
||||
|
||||
@Override
|
||||
public Long lRemove(String key, long count, Object value) {
|
||||
return redisTemplate.opsForList().remove(handleKey(key), count, value);
|
||||
return redisTemplate.opsForList().remove(addTenantPrefix(key), count, value);
|
||||
}
|
||||
|
||||
@Override
|
||||
@SuppressWarnings("unchecked")
|
||||
public BasePage getPageList(String key, long pageNumber, long pageSize) {
|
||||
//获取数据总量
|
||||
Long totalCount = redisTemplate.opsForSet().size(key);
|
||||
if (Objects.isNull(totalCount)) {
|
||||
return new BasePage(new ArrayList(), 0);
|
||||
}
|
||||
//获取当前要取分页数据的游标位置
|
||||
long start = (pageNumber - 1) * pageSize;
|
||||
long end = start + pageSize - 1;
|
||||
//获取当前页分页数据
|
||||
List<Object> list = redisTemplate.opsForList().range(key, start, end);
|
||||
return new BasePage(list, totalCount);
|
||||
}
|
||||
|
||||
|
||||
@Override
|
||||
public Collection<String> getKeys(String key) {
|
||||
return redisTemplate.keys(handleKey(key));
|
||||
return redisTemplate.keys(addTenantPrefix(key));
|
||||
}
|
||||
|
||||
@Override
|
||||
@ -235,9 +250,17 @@ public class RedisServiceImpl implements RedisService {
|
||||
return (T) hGet(key, hashKey);
|
||||
}
|
||||
|
||||
private String handleKey(String key) {
|
||||
@Override
|
||||
public String addTenantPrefix(String key) {
|
||||
StringBuilder sb = new StringBuilder();
|
||||
sb.append("tenant_").append(BaseContext.getTenantId()).append(":").append(key);
|
||||
sb.append(BaseConstant.TENANT_KEY_PREFIX).append(BaseContext.getTenantId()).append(BaseConstant.COLON_JOIN_STR).append(key);
|
||||
return sb.toString();
|
||||
}
|
||||
|
||||
@Override
|
||||
public String removeTenantPrefix(String key) {
|
||||
StringBuilder sb = new StringBuilder();
|
||||
sb.append(BaseConstant.TENANT_KEY_PREFIX).append(BaseContext.getTenantId()).append(BaseConstant.COLON_JOIN_STR);
|
||||
return key.replace(sb.toString(), "");
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user