文档章节

JAVA 动态配置 (配置源={properties,redis})

l
 lykin1972
发布于 2016/04/14 17:21
字数 342
阅读 73
收藏 4

每次修改配置还得重启,感觉很麻烦

卤主现在用的是properties,redis做配置,因为没有用到mysql等关系型数据库

贴代码

全局Application Config 代码

package com.shield.device;
import java.util.HashMap;
import java.util.Map;
import com.shield.cache.CacheKey;
import com.shield.cache.CacheService;
import com.shield.cache.springredis.RedisService;
import com.shield.springcontext.ContextUtils;
import com.shield.springcontext.CustomizedPropertyConfigurer;
import com.shield.util.JsonUtil;
public class AppConfig {
private static final AppConfig appconfig = new AppConfig() ;
private CacheService redisService ;
private final Map<String,Object> cache = new HashMap<String, Object>();
private AppConfig(){
redisService = ContextUtils.getBean(RedisService.class);
}
public static boolean getBoolean(String key) {
Object o = getObject(key);
if(o instanceof Boolean){
return (Boolean)o ;
}
return Boolean.parseBoolean(key);
}
public static String getString(String key){
Object o = getObject(key);
if(o instanceof String){
return (String)o ;
}
return o.toString();
}
public static float getFloat(String key) {
Object o = getObject(key);
if(o instanceof Float){
return (float)o ;
}
if(o instanceof String){
return Float.parseFloat((String)o) ;
}
return Float.parseFloat(o.toString());
}
public static int getInt(String key){
Object o = getObject(key);
if(o instanceof Integer){
return (int)o ;
}
if(o instanceof String){
return Integer.parseInt((String)o) ;
}
return Integer.parseInt(o.toString());
}
public static void put(String key, String value) {
appconfig.redisService.setHashValue(CacheKey.APP_CONFIG, key, value);
appconfig.cache.put(key, value);
}
public static String cacheToString() {
return JsonUtil.objectToJson(appconfig.cache);
}
public static String contextPropertyToString() {
return JsonUtil.objectToJson(CustomizedPropertyConfigurer.getContextPropertyMap());
}
public static Object getObject(String key){
Object o = appconfig.cache.get(key);
if(o == null){
o = appconfig.redisService.getHashValue(CacheKey.APP_CONFIG, key);
if(o != null){
appconfig.cache.put(key, o);
}
}
if(o == null){
o = CustomizedPropertyConfigurer.getContextProperty(key);
if(o != null){
appconfig.cache.put(key, o);
}
}
if(o == null){
throw new RuntimeException("Properties key: "+key +" value is empty, please check it.");
}
return o;
}
public static void flushAll(){
appconfig.cache.clear();
}
}

  flushAll就是清除掉数据,比如redis的配置修改了。

  推荐在http访问时候调用 

 如: 

     curl localhost:8080/config/reload


© 著作权归作者所有

共有 人打赏支持
l
粉丝 0
博文 8
码字总数 3986
作品 0
岳阳
私信 提问
【死磕Sharding-jdbc】—orchestration简介&使用

原文作者:阿飞Javaer 原文链接:https://www.jianshu.com/p/c33191385767 orchestration简介 sharding-jdbc2.x核心功能之一就是orchestration,即编排治理,什么意思呢?官方文档介绍--2.0...

飞哥-Javaer
08/09
0
0
用于 Java 开发的配置工具 - Simple Configuration Facade

SCF: 简单配置门面 Simple Configuration Facade, 简写为 SCF。是 代码 和 外部配置 (properties文件, 环境变量,系统/命令行参数, yaml文件, 等等)之间的一层抽象。命名上和另一个著名组件 ...

koqizhao
08/30
0
0
翻译:Gradle之 Java插件

原文地址 http://www.gradle.org/docs/current/userguide/java_plugin.html 要使用Java插件,在脚本里加入: Example 23.1. Using the Java plugin Java插件引入了一个概念:源集(source se...

davelet
2014/02/14
0
0
【死磕Sharding-jdbc】—–基于ssm

原文作者:阿飞Javaer 原文链接:https://www.jianshu.com/p/602e24845ed3 本篇文章讲解如何在ssm(spring、springmvc、mybatis)结构的程序上集成sharding-jdbc(版本为1.5.4.1)进行分库分...

飞哥-Javaer
05/05
0
0
Quartz任务监控管理 (1)

Quartz任务监控管理,类似Windows任务管理器,可以获得运行时的实时监控,查看任务运行状态,动态增加任务,暂停、恢复、移除任务等。对于动态增加任务,可以参加我的前一篇文章《Quartz如何...

光石头
2011/06/12
0
1

没有更多内容

加载失败,请刷新页面

加载更多

Mariadb二进制包安装,Apache安装

安装mariadb 下载二进制包并解压 [root@test-a src]# wget https://downloads.mariadb.com/MariaDB/mariadb-10.2.6/bintar-linux-glibc_214-x86_64/mariadb-10.2.6-linux-glibc_214-x86_64.t......

野雪球
16分钟前
0
0
ConcurrentHashMap 高并发性的实现机制

ConcurrentHashMap 的结构分析 为了更好的理解 ConcurrentHashMap 高并发的具体实现,让我们先探索它的结构模型。 ConcurrentHashMap 类中包含两个静态内部类 HashEntry 和 Segment。HashEnt...

TonyStarkSir
今天
3
0
大数据教程(7.4)HDFS的java客户端API(流处理方式)

博主上一篇博客分享了namenode和datanode的工作原理,本章节将继前面的HDFS的java客户端简单API后深度讲述HDFS流处理API。 场景:博主前面的文章介绍过HDFS上存的大文件会成不同的块存储在不...

em_aaron
昨天
2
0
聊聊storm的window trigger

序 本文主要研究一下storm的window trigger WindowTridentProcessor.prepare storm-core-1.2.2-sources.jar!/org/apache/storm/trident/windowing/WindowTridentProcessor.java public v......

go4it
昨天
6
0
CentOS 生产环境配置

初始配置 对于一般配置来说,不需要安装 epel-release 仓库,本文主要在于希望跟随 RHEL 的配置流程,紧跟红帽公司对于服务器的配置说明。 # yum update 安装 centos-release-scl # yum ins...

clin003
昨天
9
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部