目录
一、前言
二、服务注册
三、服务管理
一、前言
Nacos是一个开源的、易于构建云原生应用的动态服务发现、配置管理和服务管理平台。从0到1实战微服务架构之Nacos下载安装 介绍了Nacos的架构、下载安装,本文将介绍服务发现、配置和管理。
二、服务注册
第一步:springboot整合nacos,增加pom依赖
<?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 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.fd.learn</groupId>
<artifactId>nacosserver</artifactId>
<version>1.0.0-SNAPSHOT</version>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
<version>2.7.2</version>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-autoconfigure</artifactId>
<version>2.7.2</version>
</dependency>
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
<version>2021.0.4.0</version>
</dependency>
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
<version>2021.0.4.0</version>
</dependency>
<dependency>
<groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-core</artifactId>
<version>2.14.1</version>
</dependency>
<dependency>
<groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-databind</artifactId>
<version>2.14.1</version>
</dependency>
<dependency>
<groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-annotations</artifactId>
<version>2.14.1</version>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-bootstrap</artifactId>
<version>3.1.1</version>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-commons</artifactId>
<version>3.1.1</version>
</dependency>
</dependencies>
</project>
第二步:添加service服务
package com.fd.learn.controller;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
/**
* @Author: thinkpad
* @Date: 2024-01-21 10:03
*/
@RestController
@RequestMapping("/user")
public class UserController {
@PostMapping("/query")
public String query(){
return "query user success";
}
}
第三步:增加main函数, 必须添加@EnableDiscoveryClient,注册服务到nacos上
package com.fd.learn;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
/**
* @Author: thinkpad
* @Date: 2024-01-14 21:36
*/
@SpringBootApplication(scanBasePackages = "com.fd.learn")
@EnableDiscoveryClient
public class Application {
public static void main(String[] args) {
SpringApplication.run(Application.class, args);
}
}
第四步:添加properties
spring.application.name=nacosserver
spring.cloud.nacos.discovery.server-addr=127.0.0.1
spring.cloud.nacos.discovery.port=8848
spring.cloud.nacos.discovery.service=nacosserver
spring.cloud.nacos.discovery.group=DEFAULT_GROUP
spring.cloud.nacos.discovery.register-enabled=true
第五步:启动服务,服务启动成功,查看nacos的服务注册信息
三、服务管理
服务注册后,可以通过服务编辑,对服务进行权重配置。Nacos 为用户提供了流量权重控制的能力,同时开发了服务流量的阈值保护,以帮助用户更好的保护服务不被意外打垮。如下图所示,可以点击实例的 “编辑” 按钮,修改实例的权重。如果想增加实例的流量,可以将权重调大,如果不想实例接收流量,则可以将权重设为0;
服务元数据管理:Nacos 提供了多个维度的服务元数据暴露,帮助用户存储自定义的信息。这些信息都是以 K-V的数据结构存储,在控制台上,会以 k1=v1 这样的格式展示。在服务详细页面,也能看到添加的元数据信息。
服务优雅上下线:Nacos 还提供服务实例的上下线操作,在服务详细页面,可以点击实例的 “上线” 或者 “下线” 按钮,被下线的实例,将不会包含在健康的实例列表里。