(基础)SpringCloud Alibaba Nacos作为多环境配置中心

本文详细介绍了如何在分布式系统中通过Nacos进行配置管理,涉及日志级别调整、线程池配置、数据库容灾切换等,并演示了如何在不同环境(开发、预发、生产)中灵活配置。通过Spring Cloud集成Nacos,实现实时配置刷新和动态变更。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

配置 (Configuration)

配置的目录

为未知留下退路

举个简单的例子

logLevel = INFO

系统正常飞行的时候,我们希望其只输出INFO级别的日志信息,在生产环境中我们甚至希望只输出WARNING/ERROR级别的日志,系统出毛病了,再将日志输出动态的调整成包含诊断信息的DEBUG级别或者TRACE级别。

肯定不能所有应用都修改日志级别,不然当降低系统日志输出级别时,会出现大部分系统资源用于打印日志了。

这一般用于预发布环境出现BUG时,这时一般只有灰度发布的几台机器调低日志级别。之前京东某系统就因不小心调低了日志级别导致整个系统所有链路监控报警。

配置文件

在那个单机即系统的时代,我们基本都是在用配置文件来存储配置项,一个配置项,就是如上面的logLevel那样的一个含有 = 表达式。
而一个配置文件一般是一组配置项的集合或者叫配置集,一个系统根据逻辑模块划分,可以有1到多个配置文件。如下图 :
在这里插入图片描述

分布式系统给系统配置管理带来的挑战

毫无疑问今天阿里的系统就是一个大型的、服务化的、复杂的、分布式系统实现之一。在这个领域有3本书值得反复阅读<<分布式系统概念与设计>> <<分布式系统原理与泛型>> 以及 Distributed Systems For System Architects,有意思的是这三本书只有最后一本在21.3小节简单的提了一下 Configuration Of Distributed Systems,里面简单的说了一下静态配置和动态配置的概念和区别 “…System configuration may be static or dynamic…”. 这说明什么? 这说明我们阿里技术人包括我们中间件今天面临的很多问题和领域已经进入深水区,已经没有人会直接给你提供这个领域清晰的解决方案,我们自己正站在前沿,而我们的成功的或者失败的探索,其经验和成果都应该总结并分享给整个业界。

配置与环境

  1. 线程池、连接池大小
  2. 开关、预案、限流配置
  3. 数据源主备容灾切换(目前一般数据库都是采用域名访问)
  4. 路由规则(如网关)

“在开发环境中将logLevel设置为DEBUG,在预发环境logLevel设置为INFO,生产环境里logLevel设置为WARNING”

“在日常环境执行线程池的最大线程数应该设置为15,而生产环境上这个值应该大一点,默认设为150”

“在线上环境中,中心机房,应用数据源需要连接A库,而S机房,应用应该就近连接使用B库”

“只有在T环境,双向同步开关才应该关闭”

“这次的改动有点大,新的特性仅在线上的H单元把该特性开放出来,其它的单元环境先不要开放出来”

Nacos环境搭建

先通过链接可以下载Nacos的最新发行版,这里我们选择1.1.4版本的Nacos

https://github.com/alibaba/nacos/releases

在这里插入图片描述
下载后解压:
我是直接用的1.3的当时在家下载github上的东西太慢了就懒得下直接用1.3的也是没问题滴。
接着双击下面的键就可以运行了。

在这里插入图片描述
但是我们还是配成自己的数据库安全方便一点他也给出了sql文件在conf文件夹下面。
在这里插入图片描述
然后我们配置下连接数据的配置打开application.properties。
在这里插入图片描述
填上自己的数据库配置信息就行。
在这里插入图片描述
接着启动nacos启动好的状态如下图。

unzip nacos-server-$version.zip 或者 tar -xvf nacos-server-$version.tar.gz
cd nacos/bin
#启动
sh startup.sh -m standalone

在这里插入图片描述

使用springcloud整合nacos

在这里插入图片描述
在这里插入图片描述

<?xml version="1.0" encoding="UTF-8"?>

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>1.5.15.RELEASE</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>
    <groupId>lyj</groupId>
    <artifactId>nacos-config</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <name>nacos-config</name>
    <description>Demo project for Spring Boot</description>

    <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
        <java.version>1.8</java.version>
        <spring-cloud.version>Edgware.SR4</spring-cloud.version>
    </properties>

    <dependencies>

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

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>

       <!-- <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-eureka</artifactId>
        </dependency>-->

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <version>1.18.2</version>
            <optional>true</optional>
        </dependency>
    </dependencies>

    <dependencyManagement>
        <dependencies>
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-dependencies</artifactId>
                <version>${spring-cloud.version}</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-alibaba-dependencies</artifactId>
                <version>0.2.2.RELEASE</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
        </dependencies>
    </dependencyManagement>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>

</project>

项目结构

在这里插入图片描述
boostrap.yml的配置:记住一定要是bootstrap.yml而不是application.yml

注意:这里必须使用bootstrap.properties。同时,spring.application.name值必须与上一阶段Nacos中创建的配置Data Id匹配(除了.properties或者.yaml后缀)。

spring:
  application:
    name: nacos-config
  cloud:
    nacos:
      config:
        server-addr: 127.0.0.1:8848
        prefix: nacos-config
        file-extension: yaml
  profiles:
    active: dev
server:
  port: 8081

集成

package lyj;

import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.context.config.annotation.RefreshScope;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;


@SpringBootApplication
public class NacosConfigApplication {


    public static void main(String[] args) {
        SpringApplication.run(NacosConfigApplication.class, args);
    }


    @Slf4j
    @RestController
    @RefreshScope
    static class TestController{


        @Value("${didispace.title:}")
        private String title;
        
        @GetMapping("/test")
        public String hello() {
            log.info("title:" + title);
            return title;
        }
    }
    
}

@SpringBootApplication定义是个Spring Boot应用;还定义了一个Controller,其中通过@Value注解,注入了key为didispace.title的配置(默认为空字符串),这个配置会通过/test接口返回,后续我们会通过这个接口来验证Nacos中配置的加载。另外,这里还有一个比较重要的注解@RefreshScope,主要用来让这个类下的配置内容支持动态刷新,也就是当我们的应用启动之后,修改了Nacos中的配置内容之后,这里也会马上生效。

启动项目,接着进入Nacos的控制页面,在配置列表功能页面中,点击右上角的“+”按钮,进入“新建配置”页面,如下图填写内容:
在这里插入图片描述
照着图中填写完发布即可。

Data ID:填入nacos-config.yaml
Group:不修改,使用默认值DEFAULT_GROUP
配置格式:选择yaml
配置内容:应用要加载的配置内容,这里仅作为示例,做简单配置,比如:didispace: title: iclyj

访问接口:
在这里插入图片描述
可以看到已经读取到nacos配置信息中的title数据,接着我们不重启项目改动nacos中配置中的didispace: title: 数据为 “lyj” 点击发布 然后 再访问接口:
在这里插入图片描述
在这里插入图片描述
可以看到信心已经动态的更新了。到此nacos搭建和基本的使用就已经完成了。整合项目已经上传到github欢迎大家给个star谢谢各位大佬。

git@github.com:CXLYJ/nacos-config.git

集成2

package org.spring.springboot;

import com.alibaba.nacos.api.config.annotation.NacosValue;
import com.alibaba.nacos.spring.context.annotation.config.NacosPropertySource;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.bind.annotation.RestController;

import static org.springframework.web.bind.annotation.RequestMethod.GET;

/**
 * Spring Boot 应用启动类
 *
 * Created by bambo on 19/2/7.
 */
// Spring Boot 应用的标识
@SpringBootApplication
@RestController
@NacosPropertySource(dataId = "bamboo.test", autoRefreshed = true)
public class Application {

    public static void main(String[] args) {
        SpringApplication.run(Application.class,args);
    }

    @NacosValue(value = "${service.name:1}", autoRefreshed = true)
    private String serverName;

    @RequestMapping(value = "/test", method = GET)
    @ResponseBody
    public String get() {
        return serverName;
    }


}


配置文件:application.properties

nacos.config.server-addr=127.0.0.1:8848

配置中心配置
这里直接配置管理新增,注意默认group不变哦
在这里插入图片描述
保存发布,然后启动springboot服务,访问http://localhost:8080/test可以看到结果如下,说明成功了,如果修改这个值再发布,刷新url值也会更接着变化。自动刷新的基本功能就实现了。
bamboo

Nacos功能

在这里插入图片描述

nacos server的集群部署

集群部署架构图
官方的推荐部署架构图:
[外链图片转存失败(img-x4go827X-1568616387514)(https://nacos.io/img/deployDnsVipMode.jpg)]
推荐用户把所有服务列表放到一个vip(虚拟IP,主机宕机后可以自动漂移到备用机器上)下面,然后挂到一个域名下面
http://ip1:port/openAPI 直连ip模式,机器挂则需要修改ip才可以使用。
http://VIP:port/openAPI 挂载VIP模式,直连vip即可,下面挂server真实ip,可读性不好。
http://nacos.com:port/openAPI 域名+VIP模式,可读性好,而且换ip方便,推荐模式

具体操作实践
注:目前器群模式下不采用mysql作为配置文件的存储方式,所以需要先配置为采用mysql数据源模式,我在上一篇博客中已经说明了,这里不再介绍,直接配置集群。

步骤如下:
1.conf文件夹下的文件如下图所示,其中下载的压缩包解压出来是没有cluster.conf的,通过复制cluster.conf-example并修改文件名得来。
修改cluster.conf,将部署nacos server的三台服务器ip地址写上即可
三台服务器cluster.conf文件相同,都是协商这三个IP地址即可
#it is ip
#example
114.116.137.***
132.232.159.***
47.107.122.***

2.分别启动三台nacos server
修改客户端,在客户端的bootstrap.properties文件中修改server的IP地址
注:修改成自己的三台服务器ip地址,用逗号分隔
spring.cloud.nacos.config.server-addr=114.116.137.***:8848,132.232.159.***:8848,47.107.122.***:8848

参考

https://www.sohu.com/a/116745628_466839
https://spring.io/blog/2011/02/15/spring-3-1-m1-unified-property-management/
https://www.jianshu.com/p/d78fa8412cbf
https://blog.csdn.net/zjcjava/article/details/88316190
https://www.mayi888.com/archives/57402(重点)
https://www.cnblogs.com/joker-dj/p/12768975.html
https://www.cnblogs.com/nijunyang/p/12313572.html(nacos相关概念及数据模型)
https://edu.csdn.net/course/detail/25600/310603(nacos视频学习,墙裂推荐)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值