前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Nacos做配置中心经常被问到的问题

Nacos做配置中心经常被问到的问题

作者头像
猿天地
发布2019-07-23 10:22:24
1.9K0
发布2019-07-23 10:22:24
举报
文章被收录于专栏:猿天地猿天地

今天来说说Nacos做配置中心经常被问到的问题

加载多个配置文件怎么处理?

配置修改了如何监听?

支持多语言吗?

跟Apollo对比哪个更好?

部署简单吗?

↓↓

-

1

-

加载多个配置文件怎么处理?

通过@NacosPropertySource可以注入一个配置文件,如果我们需要将配置分类存储或者某些配置需要共用,这种需求场景下,一个项目中需要加载多个配置文件,可以可以直接使用多个@NacosPropertySource注解即可。

代码语言:javascript
复制
@NacosPropertySource(dataId = "nacos-springboot", autoRefreshed = true)
@NacosPropertySource(dataId = "redis", autoRefreshed = true)
@SpringBootApplication
public class NacosSpringBootApp {
    public static void main(String[] args) {
        SpringApplication.run(NacosSpringBootApp.class, args);
    }
}

或者@NacosPropertySources

代码语言:javascript
复制
@NacosPropertySources({
    @NacosPropertySource(dataId = "nacos-springboot", autoRefreshed = true),
    @NacosPropertySource(dataId = "redis", autoRefreshed = true)
})

后面我们会讲解在Spring Cloud中使用,可以直接用配置文件的方式指定多个data-id。

-

2

-

配置修改了如何监听?

先介绍一种比较古老的方式,太繁琐了,如下:

代码语言:javascript
复制
@NacosInjected
private ConfigService configService;

@PostConstruct
public void init() {
    try {
        onMessage();
    } catch (NacosException e) {
        e.printStackTrace();
    }
}

public void onMessage() throws NacosException {
    configService.addListener("nacos-springboot", "DEFAULT_GROUP", new AbstractListener() {
        public void receiveConfigInfo(String config) {
            System.err.println(config);
        }
    });
}

通过ConfigService添加一个监听器,监听具体的配置文件

下面使用注解方式来监听,既简单又方便很直接,如下:

代码语言:javascript
复制
@NacosConfigListener(dataId = "nacos-springboot")
public void onMessage(String config) {
    System.out.println(config);
}

当然配置监听还支持多类型的转换,上面的示列只是简单的获取整个配置的字符串,关于更多的类型转换后面我们单独讲解。

-

3

-

支持多语言吗?

Nacos本身是提供Http接口的,通过接口我们可以对配置进行操作。只是目前SDK这块只支持Java,其他语言的后面会支持,只是目前还没开发,通过后台的示列代码我们可以看到有支持多语言的计划。

其他语言目前可以使用API来对接:https://nacos.io/zh-cn/docs/open-api.html

-

4

-

跟Apollo对比哪个更好?

对比这块大家可以根据自身的需求去做一个比对,只要符合你的需求,那对你来说这个框架就是好的。

如果说你目前已经在使用Apollo,那么我建议还是不要换,太折腾。

如果你还没使用Apollo,在对配置中心做选型,这个时候可以去做下详细的对比。从功能点,稳定性,使用,部署等方面去比较。

如果你公司内部用了dubbo的话,我觉得Nacos可以考虑用起来,这样既然替代ZK,又能增加一个配置中心的功能,可以说是比较好的方式了。

-

5

-

部署简单吗?

Nacos部署非常简单,可以直接下载官方编译好的包,解压改改配置文件即可启动,集群部署也是一样的,后面我们会单独讲解集群部署。

同时还支持Docker部署,熟悉Docker的朋友就方便了。

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2019-07-22,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 猿天地 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
容器镜像服务
容器镜像服务(Tencent Container Registry,TCR)为您提供安全独享、高性能的容器镜像托管分发服务。您可同时在全球多个地域创建独享实例,以实现容器镜像的就近拉取,降低拉取时间,节约带宽成本。TCR 提供细颗粒度的权限管理及访问控制,保障您的数据安全。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档