配置 (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…”. 这说明什么? 这说明我们阿里技术人包括我们中间件今天面临的很多问题和领域已经进入深水区,已经没有人会直接给你提供这个领域清晰的解决方案,我们自己正站在前沿,而我们的成功的或者失败的探索,其经验和成果都应该总结并分享给整个业界。
配置与环境
- 线程池、连接池大小
- 开关、预案、限流配置
- 数据源主备容灾切换(目前一般数据库都是采用域名访问)
- 路由规则(如网关)
“在开发环境中将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视频学习,墙裂推荐)