美文网首页
01-Nacos统一配置管理

01-Nacos统一配置管理

作者: wshsdm | 来源:发表于2022-12-19 11:13 被阅读0次

1 Nacos配置中心简介

Nacos架构包含两个模块,分别是Config Service和Naming Service;其中Config Service用于实现配置中的核心模块,它实现了对配置的CRUD、版本管理、灰度管理、监听管理、推送轨迹、聚合数据等功能。

1.1 Nacos集成Spring Boot实现统一配置管理

  • 创建父容器,修改pom.xml
<packaging>pom</packaging>
    <!--统一版本-->
    <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
        <java.version>1.8</java.version>
        <!-- spring boot -->
        <spring-boot.version>2.4.2</spring-boot.version>
        <!-- spring cloud -->
        <spring-cloud.version>2020.0.1</spring-cloud.version>
        <spring-cloud-alibaba.version>2021.1</spring-cloud-alibaba.version>
        <!-- db && orm -->
        <mysql.version>8.0.19</mysql.version>
        <druid.version>1.2.4</druid.version>
        <mybatis-plus.version>3.4.3</mybatis-plus.version>
        <!-- tools -->
        <lombok.version>1.18.24</lombok.version>
        <hutool.version>5.8.5</hutool.version>
        <!--自定义依赖库版本-->
        <project.version>1.0-SNAPSHOT</project.version>
    </properties>
    <dependencies>
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <version>${lombok.version}</version>
        </dependency>
        <dependency>
            <groupId>cn.hutool</groupId>
            <artifactId>hutool-all</artifactId>
            <version>${hutool.version}</version>
        </dependency>
    </dependencies>
    <dependencyManagement>
        <dependencies>
            <!--Spring Cloud 相关依赖-->
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-dependencies</artifactId>
                <version>${spring-cloud.version}</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
            <!--Spring Cloud & Alibaba 相关依赖-->
            <dependency>
                <groupId>com.alibaba.cloud</groupId>
                <artifactId>spring-cloud-alibaba-dependencies</artifactId>
                <version>${spring-cloud-alibaba.version}</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
            <!-- SpringBoot 依赖配置 -->
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-dependencies</artifactId>
                <version>${spring-boot.version}</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
            <!--持久层依赖配置-->
            <dependency>
                <groupId>mysql</groupId>
                <artifactId>mysql-connector-java</artifactId>
                <version>${mysql.version}</version>
            </dependency>
            <dependency>
                <groupId>com.alibaba</groupId>
                <artifactId>druid-spring-boot-starter</artifactId>
                <version>${druid.version}</version>
            </dependency>
            <dependency>
                <groupId>com.baomidou</groupId>
                <artifactId>mybatis-plus-boot-starter</artifactId>
                <version>${mybatis-plus.version}</version>
            </dependency>
            <!--自定义通用模块-->
        </dependencies>
    </dependencyManagement>
    <build>
        <plugins>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-compiler-plugin</artifactId>
                <configuration>
                    <source>${java.version}</source>
                    <target>${java.version}</target>
                    <encoding>${project.build.sourceEncoding}</encoding>
                </configuration>
            </plugin>
        </plugins>
        <resources>
            <resource>
                <directory>src/main/java</directory>
                <includes>
                    <include>**/*.xml</include>
                </includes>
                <filtering>true</filtering>
            </resource>
            <resource>
                <directory>src/main/resources</directory>
                <filtering>true</filtering>
            </resource>
        </resources>
    </build>
  • 创建自定义模块,修改pom.xml
<dependencies>
        <!-- 配置读取 -->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-configuration-processor</artifactId>
        </dependency>
        <!-- Spring Cloud & Alibaba -->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-bootstrap</artifactId>
        </dependency>
        <!-- 注册中心 -->
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-loadbalancer</artifactId>
        </dependency>
        <!-- 配置中心 -->
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>       
    </dependencies>
    <build>
        <finalName>${project.artifactId}</finalName>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>
  • 创建配置文件 resources/bootstrap.yml
server:
  port: 8001
spring:
  application:
    # 应用程序名称
    name: pingsp-security
  cloud:
    nacos:
      discovery:
        # 服务发现
        server-addr: localhost:8848
      config:
        # 配置服务器
        server-addr: localhost:8848
  • 启动类
package com.pingsp.security;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
@EnableDiscoveryClient
@SpringBootApplication
public class SecurityApplication {
    public static void main(String[] args) {
        SpringApplication.run(SecurityApplication.class,args);
    }
}

1.2 读取nacos配置信息

  • nacos创建配置内容


    image.png
  • 修改配置文件
server:
  port: 8001
spring:
  application:
    # 应用程序名称
    name: pingsp-security
  cloud:
    nacos:
      discovery:
        # 服务发现
        server-addr: localhost:8848
      config:
        # 配置服务器
        server-addr: localhost:8848
        shared-configs:
          - dataId: ds.yaml
            refresh: true
  • 创建读取nacos配置自定义类
package com.pingsp.security.cfg;
import lombok.Data;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.cloud.context.config.annotation.RefreshScope;
import org.springframework.stereotype.Component;
@Data
// 刷新配置
@RefreshScope
@Component
public class RdNacos {
    @Value("${info}")
    private String info;
}
  • 创建自定义控制器
package com.pingsp.security.controller;
import com.alibaba.nacos.api.config.annotation.NacosConfigurationProperties;
import com.alibaba.nacos.api.config.annotation.NacosProperty;
import com.alibaba.nacos.api.config.annotation.NacosValue;
import com.pingsp.security.cfg.RdNacos;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
@RequestMapping("/user")
@RestController
public class UserController {
    @Autowired
    private RdNacos rdNacos;
    @GetMapping("/ok")
    public String ok(){
        return "ok:"+rdNacos.getInfo();
    }
}

相关文章

  • 01-Nacos统一配置管理

    1 Nacos配置中心简介 Nacos架构包含两个模块,分别是Config Service和Naming Serv...

  • (三十一)java版spring cloud+spring bo

    电子商务平台源码请加企鹅求求:一零三八七七四六二六。创建配置管理服务器及实现分布式配置管理应用,实现统一配置管理。...

  • 一起搭建 Spring Cloud Finchley (一)

    目的 Preview 统一Spring Cloud 环境配置管理 作用 Effect 让聚群的微服务统一配置 (M...

  • Zookeeper笔记

    应用 统一命名服务image.png 统一配置管理image.png 统一集群管理 服务器动态上下线image.p...

  • Zookeeper理解

    ZooKeeper可以来做:统一配置管理、统一命名服务、分布式锁、集群管理。ZooKeeper的数据结构,跟Uni...

  • 【Spring Cloud 系列 七】Spring Cloud

    一 为什么要使用统一配置管理 对于传统的单体应用,一般使用的都是配置文件进行配置管理,并在应用启动的时候通过指定 ...

  • 超简单 - centos7搭建zookeeper集群

    :zookeeper是为其它分布式程序提供:主从协调、服务器节点动态上下线、统一配置管理、分布式共享锁、统一名称 ...

  • Ansible Role WEB 之【confd】

    Ansible Role: confd 安装confd confd是一个统一配置管理工具,目前仍在开发中,基于本地...

  • zookeeper

    zookeeper是什么? zookeeper能够解决什么问题? 统一的配置管理,同步更新到所有zk节点,所有ap...

  • Nacos基本应用

    Nacos的功能:统一配置管理,服务的注册发现(相当于eureka+config) nacos-server是一个...

网友评论

      本文标题:01-Nacos统一配置管理

      本文链接:https://www.haomeiwen.com/subject/yvdyqdtx.html