本章将介绍如何将本地的多语言配置文件,迁移到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; } }
这样,简单的国际化配置工具类就完成了。
五、测试
可以看到,测试成功!