欢迎来到飞鸟慕鱼博客,开始您的技术之旅!
当前位置: 首页知识笔记正文

Spring Cloud Alibaba nacos配置中心

终极管理员 知识笔记 110阅读
系列文章目录

第一章 Java线程池技术应用
第二章 CountDownLatch和Semaphone的应用
第三章 Spring Cloud 简介
第四章 Spring Cloud Netflix 之 Eureka
第五章 Spring Cloud Netflix 之 Ribbon
第六章 Spring Cloud 之 OpenFeign
第七章 Spring Cloud 之 GateWay
第八章 Spring Cloud Netflix 之 Hystrix
第九章 代码管理gitlab 使用
第十章 SpringCloud Alibaba 之 Nacos discovery
第十一章 SpringCloud Alibaba 之 Nacos Config

文章目录 系列文章目录[TOC](文章目录) 前言1、Nacos配置中心配置信息2、项目里配置2.1、添加依赖配置pom.xml2.2、添加bootstrap.yml2.3、添加bootstrap.yml2.3.1、增加Nacos配置 2.4、动态刷新配置验证2.5、网关与配置中心2.5.1、添加依赖配置pom.xml2.5.2、添加bootstrap.yml文件2.5.3、Nacos添加配置2.5.4、添加类 前言

Nacos 提供用于存储配置和其他元数据的 key/value 存储为分布式系统中的外部化配置提供服务器端和客户端支持。使用 Spring Cloud Alibaba Nacos Config您可以在 Nacos Server 集中管理你 Spring Cloud 应用的外部属性配置。
Spring Cloud Alibaba Nacos Config 是 Config Server 和 Client 的替代方案客户端和服务器上的概念与 Spring Environment 和 PropertySource 有着一致的抽象在特殊的 bootstrap 阶段配置被加载到 Spring 环境中。当应用程序通过部署管道从开发到测试再到生产时您可以管理这些环境之间的配置并确保应用程序具有迁移时需要运行的所有内容。

1、Nacos配置中心配置信息

准备配置nacos server中新建nacos-config.properties

2、项目里配置 2.1、添加依赖配置pom.xml
<dependen®cy>    <groupId>com.alibaba.cloud</groupId>    <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>    <version>2021.0.4.0</version></dependency><dependency>    <groupId>org.springframework.cloud</groupId>    <artifactId>spring-cloud-starter-bootstrap</artifactId></dependency>
2.2、添加bootstrap.yml
spring:  profiles:    #开发环境dev测试环境test生产环境prod    active: dev  application:    name: app-api-service #服务名  cloud:    nacos:      config:        server-addr: 127.0.0.1:8848        group: DEFAULT_GROUP        file-extension: yml #指定yaml格式的配置        refresh-enabled: true
2.3、添加bootstrap.yml
server:  port: 80spring:    cloud:    nacos:      discovery:        server-addr: localhost:8848  #Nacos server 的地址feign:  client:    config:      default:        #建立连接所用的时间适用于网络状况正常的情况下两端连接所需要的时间        ConnectTimeOut: 3000        #指建立连接后从服务端读取到可用资源所用的时间        ReadTimeOut: 5000kelvin:  address: cat
2.3.1、增加Nacos配置

备注Data ID为服务名-环境名称.yml

2.4、动态刷新配置验证
RestControllerRequestMapping(/user)//DefaultProperties(defaultFallback  userInfoListFallBack)RefreshScopepublic class UserController {        Value(${kelvin.address})    private String url;       GetMapping(/url)    public String url(){        return url;    }}
2.5、网关与配置中心 2.5.1、添加依赖配置pom.xml
<dependency>    <groupId>com.alibaba.cloud</groupId>    <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>    <version>2021.0.4.0</version></dependency><dependency>    <groupId>org.springframework.cloud</groupId>    <artifactId>spring-cloud-starter-bootstrap</artifactId></dependency>
2.5.2、添加bootstrap.yml文件
server:  port: 80spring:  application:    name: drp-gateway-service  profiles:    #开发环境dev测试环境test生产环境prod    active: dev  jackson:    time-zone: GMT8  cloud:    loadbalancer:      ribbon:        enabled: false    nacos:      discovery:        server-addr: localhost:8848  #Nacos server 的地址      config:        server-addr: localhost:8848        name: gateway-router        namespace: public        group: DEFAULT_GROUP        #file-extension: json #指定yaml格式的配置        refresh-enabled: true #支持刷新
2.5.3、Nacos添加配置
[{    id: user-router,    order: 0,    predicates: [{        args: {            pattern: /user/userInfoList/**        },        name: Path    }],    uri: lb://user-service }  ]
2.5.4、添加类
package com.kelvin.drp.gateway.config;import com.alibaba.fastjson.JSON;import com.alibaba.fastjson.JSONObject;import com.alibaba.nacos.api.NacosFactory;import com.alibaba.nacos.api.config.ConfigService;import com.alibaba.nacos.api.config.listener.Listener;import com.alibaba.nacos.api.exception.NacosException;import lombok.extern.slf4j.Slf4j;import org.slf4j.Logger;import org.slf4j.LoggerFactory;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.beans.factory.annotation.Value;import org.springframework.cloud.context.config.annotation.RefreshScope;import org.springframework.cloud.gateway.event.RefreshRoutesEvent;import org.springframework.cloud.gateway.route.RouteDefinition;import org.springframework.cloud.gateway.route.RouteDefinitionWriter;import org.springframework.context.ApplicationEventPublisher;import org.springframework.context.ApplicationEventPublisherAware;import org.springframework.stereotype.Component;import reactor.core.publisher.Mono;import javax.annotation.PostConstruct;import java.util.ArrayList;import java.util.List;import java.util.concurrent.Executor;RefreshScopeComponentSlf4jpublic class DynamicRouteConfig implements ApplicationEventPublisherAware {    /**     * nacos 配置dataId     */    Value(${config.dynamic.route.dataId:gateway-router})    private String dataId  gateway-router;    /**     * nacos 配置group     */    Value(${config.dynamic.route.group:DEFAULT_GROUP})    private String group  DEFAULT_GROUP;    /**     * nacos 配置地址     */    Value(${spring.cloud.nacos.config.server-addr})    private String serverAddr;    Autowired    private RouteDefinitionWriter routeDefinitionWriter;    private ApplicationEventPublisher applicationEventPublisher;    private static final List<String> ROUTE_LIST  new ArrayList<>();    PostConstruct    public void dynamicRouteByNacosListener() {        try {            ConfigService configService  NacosFactory.createConfigService(serverAddr);// 程序首次启动, 并加载初始化路由配置            String initConfigInfo  configService.getConfig(dataId, group, 5000);            this.addAndPublishBatchRoute(initConfigInfo);//添加监听路由变化            configService.addListener(dataId, group, new Listener() {                Override                public void receiveConfigInfo(String configInfo) {                    clearRoute();                    try {                        List<RouteDefinition> gatewayRouteDefinitions  JSONObject.parseArray(configInfo, RouteDefinition.class);                        for (RouteDefinition routeDefinition : gatewayRouteDefinitions) {                            addRoute(routeDefinition);                        }                        publish();                    } catch (Exception e) {                        e.printStackTrace();                    }                }                Override                public Executor getExecutor() {                    return null;                }            });        } catch (NacosException e) {            e.printStackTrace();        }    }    private void publish() {        this.applicationEventPublisher.publishEvent(new RefreshRoutesEvent(this.routeDefinitionWriter));    }    Override    public void setApplicationEventPublisher(ApplicationEventPublisher applicationEventPublisher) {        this.applicationEventPublisher  applicationEventPublisher;    }    /**     * 批量 添加及发布 路由     *     * param configInfo 配置文件字符串, 必须为json array格式     */    private void addAndPublishBatchRoute(String configInfo) {        try {            clearRoute();            List<RouteDefinition> gatewayRouteDefinitions  JSONObject.parseArray(configInfo, RouteDefinition.class);            for (RouteDefinition routeDefinition : gatewayRouteDefinitions) {                addRoute(routeDefinition);            }            publish();            log.info(Dynamic config gateway route finished. {}, JSON.toJSONString(gatewayRouteDefinitions));        } catch (Exception e) {            e.printStackTrace();        }    }    /**     * 清除路由信息     */    private void clearRoute() {        for (String id: ROUTE_LIST) {            this.routeDefinitionWriter.delete(Mono.just(id)).subscribe();        }        ROUTE_LIST.clear();    }    /**     * 添加路由     *     * param definition     */    private void addRoute(RouteDefinition definition) {        try {            routeDefinitionWriter.save(Mono.just(definition)).subscribe();            ROUTE_LIST.add(definition.getId());        } catch (Exception e) {            e.printStackTrace();        }    }}

标签:
声明:无特别说明,转载请标明本文来源!