Nacos服务配置中心

本文介绍了如何使用Nacos作为配置中心来解决微服务配置管理的问题。Nacos提供服务发现、动态配置、DNS服务和元数据管理等功能。通过Docker部署Nacos,并演示了如何配置公共配置、服务模块以及实现配置自动刷新。使用Nacos简化了服务管理和配置更新,尤其在复杂分布式项目中具有显著优势。
摘要由CSDN通过智能技术生成

Nacos服务配置中心

目前,基于微服务框架的大量使用,我们对于各个独立的微服务的配置也增多,所有的配置文件都放在项目中,如果需要修改配置文件内容,则需要登陆服务器重启服务,这些问题都可以引入配置中心来解决。

目前已有的配置中心

  1. Apollo:数据保存在mysql中,支持命名空间和分发更新配置
  2. springcloud config:必须使用git保存配置信息
  3. Nacos

Nacos

Nacos是阿里巴巴集团开源的一个易于使用的平台,专为动态服务发现,配置和服务管理而设计。

Nacos 的关键特性包括:

  • 服务发现和服务健康监测
  • 动态配置服务
  • 动态 DNS 服务
  • 服务及其元数据管理

使用 Nacos 简化服务发现、配置管理、服务治理及管理的解决方案,让微服务管理、共享、组合更加容易

部署过程

  1. 在docker中部署nacos
    可以坐在本地服务器或阿里云服务器上通过运行nacos文件夹里的docker-compose.yaml文件,在docker容器中注册nacos
 version: "3"
services:
  nacos:
    image: nacos/nacos-server:latest
    container_name: nacos-standalone
    environment:
    - PREFER_HOST_MODE=hostname
    - MODE=standalone
    volumes:
    - ./standalone-logs/:/home/nacos/logs
    - ./init.d/custom.properties:/home/nacos/init.d/custom.properties
    ports:
    - 8848:8848
  prometheus:
    container_name: prometheus
    image: prom/prometheus:latest
    volumes:
      - ./prometheus/prometheus-standalone.yaml:/etc/prometheus/prometheus.yml
    ports:
      - 9090:9090
    depends_on:
      - nacos
    restart: on-failure
  grafana:
    container_name: grafana
    image: grafana/grafana:latest
    ports:
      - 3000:3000
    restart: on-failure
  1. 之后可通过8848端口访问nacos管理界面
    在这里插入图片描述
    3.将各个微服务的配置类application.yml中相同配置提取出来,在nacos中配置all-service.yml作为公共配置
    在这里插入图片描述
    4.在nacos中配置各个微服务的模块,如shop-user-dev.yml,配置模块的端口
    在这里插入图片描述
    5.配置gateway.yml,作为nacos服务配置中心
    在这里插入图片描述
    1. 将各个模块application.yml注释后,配置新的配置bootstrap.yml
spring:
  application:
    name: shop-user
  cloud:
    nacos:
      config:
        server-addr: localhost:8848
        file-extension: yml
        shared-configs[0]:
          data-id: all-service.yml
          refresh: true
  profiles:
    active: dev # 环境标识

保存发布,然后启动springboot服务,根据gateway.yml的端口7000和各个模块名进行访问模块资源,如
http://localhost:7000/shop-user/swagger-ui.html

配置自动刷新

在配置的类增加@RefreshScope就可以实现自动刷新配置,当nacos中的配置修改后,项目无需重启就可以自动生效,这个在实际生产环境中是很有用的,有时候你需要修改线上的配置,如果没有配置中心,你需要重启服务

配置中心一般用于管理复杂的配置,比如在分布式项目中的配置管理,虽然配置中心可以简化配置,但如果是很小的项目就没有必要把配置单独出来,其实就放在项目中还方便一些

Nacos服务配置中心Nacos提供的一项功能,用于统一管理和读取微服务的配置信息。在微服务架构中,每个微服务都有自己的配置文件,而配置中心则负责集中管理这些配置文件。通过配置中心,我们可以方便地对各个微服务的配置进行统一维护和管理。 要使用Nacos配置中心功能,首先需要在服务端配置好服务的配置文件。在Nacos服务端中,可以创建不同的命名空间用于隔离开发环境,生产环境和测试环境等。默认情况下,Nacos提供了一个名为"public"的命名空间,如果没有单独配置命名空间,所有的配置信息都会在public命名空间中。 为了实现微服务客户端拉取配置中心的信息,需要在客户端项目中添加Nacos配置中心的依赖。具体依赖配置可以在项目的pom.xml文件中添加如下代码: ```xml <dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId> </dependency> ``` 在客户端的bootstrap.yml文件中,需要配置Nacos配置中心的相关信息,包括Nacos注册中心地址、配置中心地址、文件扩展名和命名空间等。示例如下: ```yaml spring: cloud: nacos: discovery: server-addr: 39.100.116.73:80 config: server-addr: 39.100.116.73:8851 file-extension: yaml namespace: 507945ce-1b37-4d59-90aa-f2707fee0013 ``` 其中,`server-addr`指定了Nacos注册中心和配置中心的地址,`file-extension`指定了配置文件的扩展名,`namespace`指定了命名空间ID。 通过以上配置,客户端就可以从Nacos配置中心中获取配置信息,并应用到相应的微服务中。这样,不同的微服务就可以共享配置中心中的配置文件,实现了配置的统一管理和读取。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值