java

关注公众号 jb51net

关闭
首页 > 软件编程 > java > springboot 整合 nacos

springboot 整合 nacos 配置实现多个环境不同配置

作者:风兮雨露

本文介绍了Nacos配置中心的优势,包括与Apollo的性能对比,Nacos服务端的安装与配置,以及如何在SpringBoot项目中集成Nacos进行多环境配置,提供了详细的步骤,包括下载、安装、配置中心的创建和项目集成,旨在帮助开发者更好地使用Nacos进行项目配置管理

1、描述

一个项目一般会有中心配置文件,现在简单上手主流有Apollo,nacos config ,从性能对比可知,nacos 相比于Apollo 更高效率,更好

2、Nacos服务端安装

  修改application 数据库连接:

 在 nacos-server-1.1.4\nacos\target\nacos-server.jar ,用解压工具打开,找到nacos-default.properties ,修改里面的数据库连接就可以

    将里面的SQL 执行到部署的服务器上

如果是window 双击启动bin 里面的 startup.cmd

如果是linux 则进入bin 执行:sh startup.sh

输入 http://localhost:8848/nacos/index.html , 输入 用户名/密码:nacos/nacos ,有以下图像就代表成功了

3、创建dataId 配置中心

其中Data ID 必需要跟代码的dataId 保存一致,group 可以默认就可以

在nacos 平台创建一个YAML配置:

命名空间:dev-local 

Data ID:com-member-service.yml

Group:DEFAULT_GROUP

配置内容为:

server:
  servlet:
    context-path: /member/api
custom:
  test:
    data: 用于测试的没什么用

4、创建一个springboot 项目

项目使用的是bootstrap 进行配置

(1)引入mevan 包:

      <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
            <version>2.2.1.RELEASE</version>
        </dependency>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-bootstrap</artifactId>
            <version>3.0.4</version>
        </dependency>

(2)创建bootstrap.yml 引入读取配置中心

​server:
  port: 9087   #端口号
spring:
  application:
    name: com-member-service  # nacos 平台配置的名称Data ID
  cloud:
    nacos:
      config:
        enabled: true
        server-addr: legrand.nacos.com:8848  # nacos 地址端口
        file-extension: yml  # 指定文本后缀
        namespace: dev-local   # nacos 命名空间
        group: DEFAULT_GROUP   # nacos Group
        refresh-enabled: true

其中dataId 必需跟nacos 客户创建的dataID 一致

(3)创建controller ,引入获取nacos 的配置

package com.example.demo.controller;
import com.example.demo.service.AbstractService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
/**
 * @project: demo
 * *
 * @className: AbstractController
 * *
 * @description:
 **/
@RestController
@RequestMapping("/abstract")
public class AbstractController {
    @Autowired
    private AbstractService abstractService;
    @RequestMapping("/test")
    public String test(){
        return abstractService.test();
    }
    @Value("${custom.test.data}")
    private String cloud_secret_key;
    @RequestMapping("/nacos")
    public String nacos(){
        return cloud_secret_key;
    }
}

(5)启动服务:会发现端口号是8099,而且输入http://localhost:9087/member/api/abstract/nacos是 用于测试的没什么用,说明基本成功

5、重点:不同的springboot 读取不同application

如果我们按以上的操作,只能读取到一个nacos配置文件的,但是对于很多程序来说,有开发环境,测试环境,正式环境等等,这样的话就不能操作了。但是我发现nacos 还有个 空间namespace 可以用,那么我们可不可以用namespace

来区别不同的配置呢?

(1)在nacos 平台创建2个命名空间,test,dev

(2)在nacos  配置不同命名空间的值,在dev,test 分别创建 member ,里面的内容对应test.properties-version=testing_nacos_dev ,test.properties-version=testing_nacos_test

(4)在 springboot 的bootstrap.yml选择对应的启动配置spring.cloud.nacos.config.namespace,分别选择dev 和 test

server:
  port: 9087   #端口号
spring:
  application:
    name: com-member-service  # nacos 平台配置的名称Data ID
  cloud:
    nacos:
      config:
        enabled: true
        server-addr: legrand.nacos.com:8848  # nacos 地址端口
        file-extension: yml  # 指定文本后缀
        namespace: dev-local   # nacos 命名空间(修改这里)
        group: DEFAULT_GROUP   # nacos Group
        refresh-enabled: true

6、总结

通过以上学习,可以简单的用nacos 做配置中心。

到此这篇关于springboot 整合 nacos 配置实现多个环境不同配置的文章就介绍到这了,更多相关springboot 整合 nacos内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文