SpringCloud:注册中心nacos

一、Nacos简介

        Nacos 英文全称Dynamic Naming and Configuration Service,Na为naming/nameServer即注册中心,co为configuration即配置中心,service是指该注册/配置中心都是以服务为核心,是阿里巴巴的产品,相较于Eureka也是SpringCloud中的一个组件,但是比Eureka功能更加丰富 ,国内更受欢迎。同时社区和参考文档更加便捷,上手程度相较于其他注册中心(Eureka、consul)更加容易。

二、下载和启动nacos服务

1. 下载安装nacos

        Nacos下载地址:https://github.com/alibaba/nacos/releases

2.启动nacos

        在安装目录中找到bin下面的startup.cmd

        命令:startup.cmd -m standalone

        注:nacos默认是集群cluster模式,启动时会报错:Caused by: java.net.UnknownHostException: jmenv.tbsite.net;目前使用单机模式启动来做使用学习。

 3.访问nacos管理平台

      http://localhost:8848/nacos 

 默认的账户密码:nacos/nacos

三、引入包和配置

1.在master项目中管理maven依赖

(pom中管理包在<dependencyManagement></dependencyManagement>)

        在项目master的pom文件中管理了各开源包的pom管理

        <spring-cloud-alibaba.version>2.2.7.RELEASE</spring-cloud-alibaba.version>

<dependencyManagement>
	<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>
</dependencyManagement>

其中springboot版本是<spring-boot.version>2.4.2</spring-boot.version>
springcloud的版本是<spring-cloud.version>2020.0.2</spring-cloud.version>

<!-- 核心依赖 -->
<!--spring boot-->
<dependency>
	<groupId>org.springframework.boot</groupId>
	<artifactId>spring-boot-dependencies</artifactId>
	<version>${spring-boot.version}</version>
	<type>pom</type>
	<scope>import</scope>
</dependency>
<!--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>

2.在微服务各个子模块中添加nacos依赖 (引入包在pom中<dependencies></dependencies>)

discovery依赖是用来服务的注册和发现

# 引用nacos依赖
<dependency>
  <groupId>com.alibaba.cloud</groupId>
  <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>

config依赖是用来配置中心的参数配置

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

3.在模块项目中配置nacos

spring:
  cloud:
    nacos:
      discovery:  # 服务注册发现
        server-addr: 127.0.0.1:8848
        group: Cx  # 自定义组
        namespace: a5c6e38b-e973-49a3-92b1-5f1811ca531a # nacos中自定义的命名空间对应id
        username: nacos
        password: nacos
      config:  # 配置中心
        server-addr: ${spring.cloud.nacos.discovery.server-addr}
        group: Cx
        namespace: a5c6e38b-e973-49a3-92b1-5f1811ca531a # nacos中自定义的命名空间对应id
        file-extension: yaml
        username: ${spring.cloud.nacos.discovery.username}
        password: ${spring.cloud.nacos.discovery.password}
        timeout: 3000
        refresh-enabled: true # 开启自动刷新
        max-retry: 10

4.注意事项

        在使用config配置中心的时候需要注意,配置需在bootstrap.yml中。需要引入bootstrap包

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

四、配置中心的使用

Demo

1.编写访问controller,添加注释@Vaulue

注:由于有些配置没有写在程序的yml配置文件中,仅在nacos配置中有,使用@Value时会出错提示,如name不能解析不存在等问题,所以在name后面加上:符号,表示初始化默认值,避免启动报错。

package com.cx;

import org.springframework.beans.factory.annotation.Value;
import org.springframework.cloud.context.config.annotation.RefreshScope;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

@RestController
@RequestMapping("/config")
@RefreshScope
public class ConfigController {
	
	@Value("${name:}")
    public String name;
	
	@Value("${gloab:}")
    public String gloab;

	@RequestMapping("/name")
	public String name(){
		return name;
	}
	
	@RequestMapping("/gloab")
	public String gloab(){
		return gloab;
	}
}

2.在nacos中添加配置文件

        在nacos管理后台,添加配置文件,如下图:

 注:Data Id命名:应该与springboot项目中应用名相同(spring.application.name=Cx),且配置多个文件时如-dev、-prod等,用-隔开,原理同springboot中application.yml、application-dev.yml相同。

大家可以注意在启动springboot项目时,控制台会输出:(大家可以留意一下)

Ignore the empty nacos configuration and get it based on dataId[Cx] & group[Cx]
Ignore the empty nacos configuration and get it based on dataId[Cx.yaml] & group[Cx]
Ignore the empty nacos configuration and get it based on dataId[Cx-dev.yaml] & group[Cx]

3. 测试效果

        启动上述demo,并访问ip:port/config/name,获取配置的name查看返回结果,同时也可以试试当nacos配置文件中name值发生改变后,再次访问接口,结果也发生改变。

        注:@RefreshScope这个注解需要加上,刷新缓存配置。

五、服务发现和注册

        在springboot项目中添加了discovery包后,并在配置文件yml或properties中配置了discovery的地址和相关信息。在启动类中加入注解@EnableDiscoveryClient,开始启动。(所述相关配置在上面都有代码)

         服务启动成功后,打开nacos后台查看服务管理-服务列表,则可以查看到注册上去的服务信息了。        

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值