【7.1.4】增加基于redis的config缓存配置

pull/22/head
fengshuonan 2021-10-03 23:13:53 +08:00
parent a4b9056d85
commit 959aeefdc8
6 changed files with 279 additions and 4 deletions

View File

@ -17,7 +17,14 @@
<dependencies>
<!--系统配置表的sdk-->
<!--系统配置表的redis的sdk-->
<dependency>
<groupId>cn.stylefeng.roses</groupId>
<artifactId>config-sdk-redis</artifactId>
<version>${roses.version}</version>
</dependency>
<!--默认系统配置表的sdk-->
<dependency>
<groupId>cn.stylefeng.roses</groupId>
<artifactId>config-sdk-map</artifactId>

View File

@ -24,6 +24,7 @@
*/
package cn.stylefeng.roses.kernel.config.modular.listener;
import cn.hutool.core.convert.Convert;
import cn.hutool.core.util.ObjectUtil;
import cn.hutool.db.DbUtil;
import cn.hutool.db.Entity;
@ -32,6 +33,7 @@ import cn.stylefeng.roses.kernel.config.api.context.ConfigContext;
import cn.stylefeng.roses.kernel.config.api.exception.ConfigException;
import cn.stylefeng.roses.kernel.config.api.exception.enums.ConfigExceptionEnum;
import cn.stylefeng.roses.kernel.config.modular.factory.SysConfigDataFactory;
import cn.stylefeng.roses.kernel.config.redis.RedisConfigContainer;
import cn.stylefeng.roses.kernel.rule.context.ApplicationPropertiesContext;
import cn.stylefeng.roses.kernel.rule.listener.ContextInitializedListener;
import lombok.extern.slf4j.Slf4j;
@ -66,12 +68,27 @@ public class ConfigInitListener extends ContextInitializedListener implements Or
@Override
public void eventCallback(ApplicationContextInitializedEvent event) {
// 初始化Config Api
ConfigContext.setConfigApi(new ConfigContainer());
// 获取environment参数
ConfigurableEnvironment environment = event.getApplicationContext().getEnvironment();
// 是否采用redis进行sys_config缓存的装载和读取true/false
String redisConfigCacheEnable = environment.getProperty("redis.config.cache.enable");
Boolean redisConfigCacheEnableFlag = Convert.toBool(redisConfigCacheEnable, false);
if (redisConfigCacheEnableFlag) {
// 获取Redis的相关配置
String redisHost = environment.getProperty("spring.redis.host");
String redisPort = environment.getProperty("spring.redis.port");
String redisPassword = environment.getProperty("spring.redis.password");
String dbNumber = environment.getProperty("spring.redis.database");
// 初始化Config Api
ConfigContext.setConfigApi(new RedisConfigContainer(redisHost, Convert.toInt(redisPort, 6379), redisPassword, Convert.toInt(dbNumber, 0)));
} else {
// 初始化Config Api内存方式
ConfigContext.setConfigApi(new ConfigContainer());
}
// 初始化ApplicationPropertiesContext
ApplicationPropertiesContext.getInstance().initConfigs(environment);

View File

@ -0,0 +1 @@
基于Redis的系统配置实现

View File

@ -0,0 +1,45 @@
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>cn.stylefeng.roses</groupId>
<artifactId>kernel-d-config</artifactId>
<version>7.1.4</version>
<relativePath>../pom.xml</relativePath>
</parent>
<artifactId>config-sdk-redis</artifactId>
<packaging>jar</packaging>
<dependencies>
<!--config模块的api-->
<dependency>
<groupId>cn.stylefeng.roses</groupId>
<artifactId>config-api</artifactId>
<version>${roses.version}</version>
</dependency>
<!-- redis,使用jedis客户端排除lettuce -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-redis</artifactId>
<exclusions>
<exclusion>
<groupId>io.lettuce</groupId>
<artifactId>lettuce-core</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>redis.clients</groupId>
<artifactId>jedis</artifactId>
</dependency>
</dependencies>
</project>

View File

@ -0,0 +1,204 @@
/*
* Copyright [2020-2030] [https://www.stylefeng.cn]
*
* 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.
*
* GunsAPACHE LICENSE 2.0使
*
* 1.LICENSE
* 2.Guns
* 3.
* 4. https://gitee.com/stylefeng/guns
* 5. https://gitee.com/stylefeng/guns
* 6.
*/
package cn.stylefeng.roses.kernel.config.redis;
import cn.hutool.core.convert.Convert;
import cn.hutool.core.util.ObjectUtil;
import cn.hutool.core.util.StrUtil;
import cn.stylefeng.roses.kernel.config.api.ConfigApi;
import cn.stylefeng.roses.kernel.config.api.exception.ConfigException;
import cn.stylefeng.roses.kernel.config.api.exception.enums.ConfigExceptionEnum;
import lombok.extern.slf4j.Slf4j;
import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPool;
import redis.clients.jedis.JedisPoolConfig;
import java.util.HashMap;
import java.util.HashSet;
import java.util.Map;
import java.util.Set;
/**
* Redis
*
* @author fengshuonan
* @date 2021/10/3 21:18
*/
@Slf4j
public class RedisConfigContainer implements ConfigApi {
private JedisPool pool = null;
private final String CONFIG_PREFIX = "SYS_CONFIG_CACHE:";
public RedisConfigContainer(String redisHost, Integer redisPort, String redisPassword, Integer dbNumber) {
// 设置默认值
if (StrUtil.isEmpty(redisHost)) {
redisHost = "localhost";
}
if (ObjectUtil.isEmpty(redisPort)) {
redisPort = 6379;
}
if (StrUtil.isEmpty(redisPassword)) {
redisPassword = null;
}
if (ObjectUtil.isEmpty(dbNumber)) {
dbNumber = 0;
}
JedisPoolConfig jedisPoolConfig = new JedisPoolConfig();
// jedis实例数
jedisPoolConfig.setMaxTotal(50);
// 最小实例
jedisPoolConfig.setMinIdle(5);
// 最大等待时间,单位毫秒
jedisPoolConfig.setMaxWaitMillis(1000 * 100);
// 获取连接检测
jedisPoolConfig.setTestOnBorrow(true);
jedisPoolConfig.setTestOnReturn(true);
pool = new JedisPool(jedisPoolConfig, redisHost, redisPort, 3000, redisPassword, dbNumber);
}
@Override
public void initConfig(Map<String, Object> configs) {
if (configs == null || configs.size() == 0) {
return;
}
try (Jedis jedis = pool.getResource()) {
for (Map.Entry<String, Object> stringObjectEntry : configs.entrySet()) {
String key = stringObjectEntry.getKey();
Object value = stringObjectEntry.getValue();
if (value != null) {
jedis.set(CONFIG_PREFIX + key, value.toString());
}
}
}
}
@Override
public Map<String, Object> getAllConfigs() {
// 找到缓存所有配置
try (Jedis jedis = pool.getResource()) {
Set<String> keys = jedis.keys(CONFIG_PREFIX + "*");
HashMap<String, Object> result = new HashMap<>();
if (ObjectUtil.isNotEmpty(keys)) {
for (String key : keys) {
result.put(key.substring(CONFIG_PREFIX.length()), jedis.get(key));
}
}
return result;
}
}
@Override
public Set<String> getAllConfigKeys() {
try (Jedis jedis = pool.getResource()) {
Set<String> keys = jedis.keys(CONFIG_PREFIX + "*");
Set<String> result = new HashSet<>();
if (ObjectUtil.isNotEmpty(keys)) {
for (String key : keys) {
result.add(key.substring(CONFIG_PREFIX.length()));
}
}
return result;
}
}
@Override
public void putConfig(String key, Object value) {
try (Jedis jedis = pool.getResource()) {
if (ObjectUtil.isNotEmpty(value)) {
jedis.set(CONFIG_PREFIX + key, value.toString());
}
}
}
@Override
public void deleteConfig(String key) {
try (Jedis jedis = pool.getResource()) {
if (ObjectUtil.isNotEmpty(key)) {
jedis.del(CONFIG_PREFIX + key);
}
}
}
@Override
public <T> T getConfigValue(String configCode, Class<T> clazz) throws ConfigException {
try (Jedis jedis = pool.getResource()) {
String configValue = jedis.get(CONFIG_PREFIX + configCode);
if (ObjectUtil.isEmpty(configValue)) {
String format = StrUtil.format(ConfigExceptionEnum.CONFIG_NOT_EXIST.getUserTip(), configCode);
log.warn(format);
throw new ConfigException(ConfigExceptionEnum.CONFIG_NOT_EXIST.getErrorCode(), format);
} else {
try {
return Convert.convert(clazz, configValue);
} catch (Exception e) {
String format = StrUtil.format(ConfigExceptionEnum.CONVERT_ERROR.getUserTip(), configCode, configValue, clazz.toString());
log.warn(format);
throw new ConfigException(ConfigExceptionEnum.CONVERT_ERROR.getErrorCode(), format);
}
}
}
}
@Override
public <T> T getConfigValueNullable(String configCode, Class<T> clazz) {
try (Jedis jedis = pool.getResource()) {
String configValue = jedis.get(CONFIG_PREFIX + configCode);
if (ObjectUtil.isEmpty(configValue)) {
String format = StrUtil.format(ConfigExceptionEnum.CONFIG_NOT_EXIST.getUserTip(), configCode);
log.warn(format);
return null;
} else {
try {
return Convert.convert(clazz, configValue);
} catch (Exception e) {
String format = StrUtil.format(ConfigExceptionEnum.CONVERT_ERROR.getUserTip(), configCode, configValue, clazz.toString());
log.warn(format);
return null;
}
}
}
}
@Override
public <T> T getSysConfigValueWithDefault(String configCode, Class<T> clazz, T defaultValue) {
T value = this.getConfigValueNullable(configCode, clazz);
if (value == null) {
return defaultValue;
} else {
return value;
}
}
}

View File

@ -18,6 +18,7 @@
<modules>
<module>config-api</module>
<module>config-sdk-map</module>
<module>config-sdk-redis</module>
<module>config-business</module>
<module>config-spring-boot-starter</module>
</modules>