SpringCloud安装Nacos完成配置中心

2022-11-13 12:11:10 配置 安装 中心

eureka注册中心

1. Nacos介绍

官网说明:Nacos 致力于帮助您发现、配置和管理微服务。Nacos 提供了一组简单易用的特性集,帮助您快速实现动态服务发现、服务配置、服务元数据及流量管理。

2. docker安装Nacos

基于liunx Centos7,镜像nacos/nacos-server:v2.1.0

2.1 docker-compose.yaml

version: '3.7'
services:
  nacos01:
    image: nacos/nacos-server:v2.1.0
    container_name: nacos01
#    restart: always
    ports:
    - "8848:8848"
    environment:
    - TZ=Asia/Shanghai
    - MODE=standalone
    - JVM_XMS=128m
    - JVM_XMX=512M
    networks:
    - my-net
networks:
  #新增的网络 内部服务名调用
  my-net:
    external: true

如果需要配置本地数据库的可以参考这篇文章

2.2 启动后访问控制台

访问Http://192.168.0.221:8848/nacos/,账号密码都是nacos

添加一个orderservice-dev.yaml配置,内容如下。

接下来在springboot中集成Nacos

3.Springboot集成Nacos

3.1 pom依赖

父依赖

<parent>
	<groupId>org.springframework.boot</groupId>
	<artifactId>spring-boot-starter-parent</artifactId>
	<version>2.6.8</version>
</parent>

SpringCloud版本管理包

<dependencyManagement>
	<dependencies>
		<dependency>
			<groupId>org.springframework.cloud</groupId>
			<artifactId>spring-cloud-dependencies</artifactId>
			<version>2021.0.3</version>
			<type>pom</type>
			<scope>import</scope>
		</dependency>
	</dependencies>
</dependencyManagement>

nacos配置依赖

<!--引入cloud config-->
<dependency>
	<groupId>org.springframework.cloud</groupId>
	<artifactId>spring-cloud-starter-config</artifactId>
</dependency>
<!--引入nacos config依赖-->
<dependency>
	<groupId>com.alibaba.cloud</groupId>
	<artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
	<version>2021.0.1.0</version>
</dependency>
<!--cloud2021.x版本后 不在支持bootstrap No spring.config.import set-->
<dependency>
	<groupId>org.springframework.cloud</groupId>
	<artifactId>spring-cloud-starter-bootstrap</artifactId>
</dependency>

一定要注意依赖,不然很多问题

3.2 yaml配置

特别注意加载配置文件的顺序 bootstrap -> application,所以不要在application.yml写任何配置,不存在最好。新建一个bootstrap.yml

spring:
  application:
    #这个名词需要和nacos配置的一致
    name: orderservice
  profiles:
    #指定环境
    active: dev
  cloud:
    #不使用默认的config 使用nacos
    config:
      enabled: false
    nacos:
      config:
        server-addr: 192.168.0.221:8848
        file-extension: yaml

接下来从启动日志看下读取配置的规则:

Ignore the empty nacos configuration and get it based on dataId[orderservice] & group[DEFAULT_GROUP]
Ignore the empty nacos configuration and get it based on dataId[orderservice.yaml] & group[DEFAULT_GROUP]
Located property source: [BootstrapPropertySource {name='bootstrapProperties-orderservice-dev.yaml,DEFAULT_GROUP'}, BootstrapPropertySource {name='bootstrapProperties-orderservice.yaml,DEFAULT_GROUP'}, BootstrapPropertySource {name='bootstrapProperties-orderservice,DEFAULT_GROUP'}]

  • 服务名+配置的文件后缀(默认properties后缀)最优先,orderservice.${file-extension}
  • 根据环境配置,orderservice-${spring.profiles.active}.${file-extension}

3.3 测试配置动态化

//开启配置动态刷新
@RefreshScope
@Slf4j
@RestController
public class OrderController {
	@Value("${hello.world}")
    private String hello;
    @GetMapping("/test")
    public String test() throws Exception {
        log.info("config -- {}", hello);
        return hello;
    }
}

3.4 测试日志

c.e.order.controller.OrderController     : config -- 1345671234567887654
//修改为jack再次访问
c.e.order.controller.OrderController     : config -- hello my name is jack

到此这篇关于SprinGCloud安装Nacos完成配置中心的文章就介绍到这了,更多相关SpringCloud Nacos配置中心内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!

相关文章