手把手教你搭建SpringCloudAlibaba之Nacos服务配置中心

SpringCloud Alibaba全集文章目录:

零、手把手教你搭建SpringCloudAlibaba项目

一、手把手教你搭建SpringCloud Alibaba之生产者与消费者

二、手把手教你搭建SpringCloudAlibaba之Nacos服务注册中心

三、手把手教你搭建SpringCloudAlibaba之Nacos服务配置中心

四、手把手教你搭建SpringCloudAlibaba之Nacos服务集群配置

五、手把手教你搭建SpringCloudAlibaba之Nacos服务持久化配置

六、手把手教你搭建SpringCloudAlibaba之Sentinel实现流量实时监控

七、手把手教你搭建SpringCloudAlibaba之Sentinel实现流量控制

八、手把手教你搭建SpringCloudAlibaba之Sentinel服务熔断降级

九、手把手教你搭建SpringCloudAlibaba之Sentinel热点key限流

十、手把手教你搭建SpringCloudAlibaba之Sentinel系统自适应保护

十一、手把手教你搭建SpringCloudAlibaba之Sentinel注解SentinelResource

十二、手把手教你搭建SpringCloudAlibaba之Sentinel规则持久化

十三、手把手教你搭建SpringCloudAlibaba之Seata分布式事务

点击跳转学习 -------------->手把手教你搭建SpringCloud项目

一、如何整合Nacos作为配置中心?

Nacos既然要作为配置中心,我们的配置肯定是要放在Nacos当中,具体怎么配置呢?

即在配置管理下的配置列表进行配置。点击右上角的+,进行添加配置。

 Data ID :如何进行命名呢,命名的规则是什么呢?

配置规则为${prefix}-${spring.profile.active}.${file-extension}

prefix 默认为spring.applaction.name的值,也可以通过配置项spring.cloud.nacos.config.prefix来配置。

spring.profile.active 即为当前环境对应的profile,详情可以参考SpringBoot文档,注意:当spring.profile.active 为空时,对应的连接符 - 也将不存在,dataId的拼接格式变为${prefix}.${spring.cloud.nacos.config.file-extension}

file-extension   为配置内容的数据格式,可以通过项spring.cloud.nacos.config.file-extension 来配置。目前只支持properties和yaml类型。

Nacos Spring Cloud 快速开始Nacos Spring Cloud 快速开始icon-default.png?t=N7T8https://nacos.io/zh-cn/docs/quick-start-spring-cloud.html

Nacos同Springcloudd-config一样,在项目初始化的时候,要保证先从配置中心进行配置拉取,拉取配置之后,才能保证项目的正常启动。

springboot中配置文件的加载是存在优先级顺序的,bootstrap优先级高于applaction。

我们首先就将我们生产者的服务的配置文件放到Nacos的配置列表当中。

1、加入配置中心所需要的jar包

   <dependency>
        <groupId>com.alibaba.cloud</groupId>
        <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
    </dependency>

2、在Nacos当中新建配置文件,命令规则就是上边所说的规则。

 贴出配置文件

server:
  port: 8001 #服务端口
spring:
  datasource:
    type: com.alibaba.druid.pool.DruidDataSource  #当前数据源操作类型
    driver-class-name: org.gjt.mm.mysql.Driver  #数据库驱动包
    url: jdbc:mysql://localhost:3306/test?autoReconnect=true&useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=false
    username: root
    password: 123456

management:
  endpoints:
    jmx:
      exposure:
        include: '*'

#mybatis:配置
mybatis:
  mapperLocations: classpath:dao/*.xml
  type-aliases-package: com.buba.springcloud.pojo    # 所有pojo别名类所在包

3、我们在resources下新建bootstrap.yml配置文件

spring:
  application:
    name: mcroservice-payment  #服务名
  cloud:
    nacos:
      config:
        server-addr: localhost:8848
        # 配置中心配置文件的后缀名格式
        file-extension: yaml
        # 是否动态刷新,默认为false
        refresh: true
      discovery:
        server-addr: localhost:8848
 # 当前环境对应的profile
  profiles:
    active: dev

我们的项目目录结构就成了

4、在我们启动类上加上注解

@RefreshScope 该注解支持nacos的动态刷新的功能,Springcloud原生的注解,实现配置自动更新

 5、启动服务,在控制就可以看到我们的服务启动的时候加载了nacos数据,数据ID:“mcroservice-payment-dev.yaml”,组:“DEFAULT_GROUP”,对应的profile是dev,也读取到我们配置的端口号8081。

 6、我们访问http://localhost:8001/payment/get/1,可以返回数据,说明我们的配置中心就配置成功啦。


有时候我们会在配置文件中配置一些信息,比如我们与第三方的集成的时候,会在配置文件加上对方的配置的域名、ip端口啥的,当这些信息发生改变的话,我们使用nacos的话就可以直接修改我们nacos中的配置文件,不用动我们项目中的配置,也不用重新打包、启动。

 在PaymentControler的类上加上@RefreshScope注解,类中加入如下代码,看能否获取到我们新增的配置信息

    @Value("${config.info}")
    private  String configInfo;

    @GetMapping("/config/info")
    public String getConfigInfo(){
        System.out.println(configInfo);
        return configInfo;
    }

访问http://localhost:8001/config/info可以成功获取到我们刚刚配置的信息,如下图:

可以动态的刷新配置,那我们修改其配置的信息,看看不重启服务,会不会获取到修改后的信息。将端口修改成了8003。

在我们发布的时候,控制台也有日志记录,说我们config.info这个key发生了更改。

 

我们访问http://localhost:8001/config/info可以看到已经获取到我们修改的的端口8003。

二、了解Nacos中的分类设计思想

1、一个大型分布式微服务会有很多的的微服务子项目,每个微服务项目又都有响应的开发环境、测试环境、正式环境,那怎么对这些微服务配置进行管理呢?

Nacos为我们提供了命令空间(NameSpace)+分组(Group)+dataid的分类设计思想,我们可以看到在Nacos的界面有命名空间,且有默认的值为public,是不能删除的,可以看到当前空间只有一个配置文件。

NameSpace主要是用来隔离的,比如我们不同的环境,就可以新建不同的命名空间,不同的命名空间是隔离的。

而看我们刚才的配置文件就是在public这个命名空间当中,且是默认的分组DEFAULT_GROUP,可以把不同的微服务划分到同一个分组中去。

那我们就接下来新建一个命名空间看一下,我们新建命名空间为test,可以看到dadataid是自动生成的,也可以自己写dadataid,是需要唯一的。

 可以看到新的命名空间就新建成功了。

我们分别在test的命名空间下新建两个文件,分别在不同的分组下,如下图:

这是DEFAULT_GROUP默认分组下的mcroservice-payment-test.yaml的配置文件                                                                       

这是在DEV_GROUP下的 mcroservice-payment-dev.yaml配置文件

然后我们先测试一下再test命名空间下的DEV_GROUP分组下的mcroservice-payment-test.yaml的配置文件,如下图:

访问 http://localhost:8001/config/info,如下图,获取到了DEFAULT_GROUP默认分组下我们配置的info信息。

 我们再测试一下再test命名空间下的DEFAULT_GROUP默认分组下的mcroservice-payment-test.yaml的配置文件,如下图:

访问 http://localhost:8001/config/info,如下图,获取到了DEV_GROUP分组下我们配置的info信息。

  • 6
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
### 回答1: Spring Cloud Alibaba 是一个基于 Spring Cloud 的开源框架,用于构建分布式应用程序。Nacos 是一个开源的服务发现、配置管理和服务管理平台,可以帮助开发人员更好地管理和维护分布式应用程序。 要搭建 Spring Cloud AlibabaNacos,需要按照以下步骤进行操作: 1. 下载和安装 JDK 和 Maven。 2. 创建一个 Spring Boot 项目,并添加 Spring Cloud AlibabaNacos 的依赖。 3. 在 Nacos 中创建一个命名空间和一个服务。 4. 在 Spring Boot 项目中配置 Nacos 的地址和服务信息。 5. 编写代码并运行应用程序。 具体的步骤可以参考 Spring Cloud AlibabaNacos 的官方文档,或者参考其他相关的程和资料。 ### 回答2: SpringCloudAlibaba是一款非常流行的分布式系统框架,它提供了一个非常方便的方式来搭建高可扩展的分布式应用程序。当使用SpringCloudAlibaba构建分布式应用程序时,我们常常需要使用Nacos作为服务注册中心和配置中心。本文将介绍如何使用SpringCloudAlibaba搭建Nacos。 首先,我们需要在本地安装Nacos。 步骤如下: 1. 下载Nacos:https://github.com/alibaba/nacos/releases 2. 解压下载的文件,进入bin目录 3. 运行startup.cmd(如果是在Linux系统下,运行startup.sh) 当我们成功启动Nacos后,我们需要在我们的应用程序中添加Nacos的依赖项。可以在pom.xml文件中添加如下代码: ``` <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId> </dependency> ``` 这个依赖项将会自动添加Spring Cloud Nacos Discovery的类和配置。 接下来,我们需要为我们的应用程序添加Nacos配置。可以在application.properties或者application.yml文件中添加如下代码: ``` spring.cloud.nacos.discovery.server-addr=localhost:8848 ``` 当我们的应用程序启动时,它将会自动注册到Nacos。 最后,我们需要在我们的应用程序中使用Nacos作为配置中心。可以在配置文件中添加如下配置: ``` spring.cloud.nacos.config.server-addr=localhost:8848 ``` 这个配置项将会告诉我们的应用程序从Nacos中加载配置项。 当我们成功完成这些步骤后,我们的应用程序就已经成功地搭建Nacos。现在我们可以使用Nacos作为服务注册中心和配置中心来管理我们的应用程序了。 ### 回答3: SpringCloudAlibaba是阿里巴巴团队推出的微服务框架,其中的nacos作为注册中心、配置中心以及服务发现组件,是使用SpringCloudAlibaba搭建微服务架构的重要组成部分。 下面是搭建nacos的详细步骤: 1.安装Java环境和Maven环境。在安装之前需要确保已经正确配置好Java和Maven的环境变量。 2.下载nacos的安装包。从nacos的官网中下载最新版的nacos安装包,解压缩到任意目录下。 3.启动nacos server。通过命令行进入nacos安装包所在的bin目录下,使用以下命令启动nacos: Linux/Unix/Mac: sh startup.sh –m standalone Windows: cmd startup.cmd 启动成功后通过访问http://localhost:8848/nacos/访问nacos的管理控制台,管理员账号和密码默认为nacos/nacos。 4.配置nacos客户端。在pom.xml文件中添加nacos的依赖: <dependency> <groupId>com.alibaba.cloud</groupId> <artifactId> spring-cloud-starter-alibaba-nacos-discovery </artifactId> </dependency> 在配置文件application.yml中配置nacos信息: spring: cloud: nacos: discovery: server-addr: localhost:8848 # nacos服务的地址 application: name: service-provider # 微服务的名称 5.发布和发现微服务。使用@EnableDiscoveryClient注解启用服务发现功能,在微服务启动时自动注册到nacos中,nacos管理控制台会显示注册的微服务信息。其他微服务可以通过调用nacos的API或者使用Ribbon等工具进行服务发现。 至此,使用SpringCloudAlibaba搭建nacos的过程就结束了。nacos提供的服务注册、配置管理和服务发现功能,为微服务的构建和部署提供了更方便、更高效、更可靠的方案。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值