本章将介绍如何将本地的多语言配置文件,迁移到Apollo配置中心里面。
专栏目录:
欢迎关注个人公众号: Coder编程
欢迎关注个人网站:www.52melrin.com
注:本章不介绍环境,如果环境未搭建成功的可以在专栏中找到相关环境。
一、需求
将本地的多语言(国际化)配置文件,迁移至Apollo配置中心。
二、思路
通过官方文档可知:
Apollo支持4个维度管理Key-Value格式的配置:
- application (应用)
- environment (环境)
- cluster (集群)
- namespace (命名空间)
其中namespace定义:Namespace是配置项的集合,类似于一个配置文件的概念。
- 一个应用下不同配置的分组,可以简单地把namespace类比为文件,不同类型的配置存放在不同的文件中,如数据库配置文件,rpc配置文件,应用自身的配置文件等
- 应用可以直接读取到公共组件的配置namespace,如DAL,RPC等
- 应用也可以通过继承公共组件的配置namespace来对公共组件的配置做调整,如DAL的初始数据库连接数
因此,我们可以将多语言(国际化)配置文件,分别创建不同的namespace。
三、创建namespace
这里我创建一个中文,一个英文namespace。
四、代码
ApolloMessageUtil
/**
* apollo国际化配置文件
*
* @author Merlin
*
*/
@Configuration
public class ApolloMessageUtil implements InitializingBean{
private static Config enPublicConfig = ConfigService.getConfig("TEST1.message_en");
private static Config zhCnPublicConfig = ConfigService.getConfig("TEST1.message_zh_cn");
private static ApolloMessageUtil apolloMessage = null;
public static ApolloMessageUtil getApolloMessage() {
return apolloMessage;
}
@Override
public void afterPropertiesSet() throws Exception {
apolloMessage = this;
}
public static String getString(String key,String lang) {
String msg = null;
if(!StringUtils.isEmpty(key) && !StringUtils.isEmpty(lang)) {
if(lang.equalsIgnoreCase("zh_cn")) {
msg = zhCnPublicConfig.getProperty(key, "");
}else if(lang.equalsIgnoreCase("en")){
msg = enPublicConfig.getProperty(key, "");
}
}else {
msg = zhCnPublicConfig.getProperty(key, "");
}
return msg;
}
}
DemoUtil
@RestController
public class DemoController {
@RequestMapping("/hello")
public String hello(){
String enwelcome = ApolloMessageUtil.getString("welcome", "zh_cn");
String ch_welcome = ApolloMessageUtil.getString("welcome", "en");
return " en_welcome: "+enwelcome + " ch_welcome: "+ch_welcome;
}
}
这样,简单的国际化配置工具类就完成了。
五、测试
可以看到,测试成功!