[转帖]服务注册与发现:Nacos Discovery
目录
一、概述
Nacos是一个更易于构建云原生应用的动态服务发现、配置管理和服务管理平台。
特性:
(1)服务发现与服务健康检测
(2)动态配置服务
(3)动态 DNS 服务
(4)服务及其元数据管理
二、Nacos discovery——服务的注册与发现
Nacos Discovery Starter 可以帮助您将服务自动注册到 Nacos 服务端,并且能够动态感知和刷新某个服务实例的服务列表。除此之外,Nacos Discovery Starter 也将服务实例自身的一些元数据信息-例如 host,port,健康检查URL,主页等-注册到 Nacos 。
1. 版本关系
关于Spring Cloud Alibaba与Spring boot, Spring Cloud Alibaba 与其他微服务组件之间的版本对应关系:Home · alibaba/spring-cloud-alibaba Wiki · GitHub
这里截取部分对应关系,我使用的 Spring Cloud Alibaba 版本为 2.2.9.RELEASE。


2. 下载安装
(1)下载
Nacos 下载地址:Releases · alibaba/nacos (github.com)
这里我下载的Windows版本:

(2)启动
将压缩包放至文件夹解压即可,运行bin目录下startup.cmd脚本即可启动:


注意:这里启动的是单机模式,默认是集群模式。

(3)浏览器访问
默认用户名和密码都是 nacos

三、Nacos服务注册与发现实战
说明:这里先构建一个父工程,父工程下分别有两个微服务模块,一个是订单模块,一个是库存模块,订单要调用库存模块的接口,下面演示如何调用,以及使用Nacos进行服务的注册与发现。
1. 构建Spring Cloud Alibaba工程
(1)创建父工程


(2)创建子项目
创建订单服务模块:


创建库存服务模块:


搭建父子关系:
更改父工程 pom.xml 的打包方式,并引入子模块:
-
<packaging>pom</packaging>
-
<modules>
-
<module>order-nacos</module>
-
<module>stock-nacos</module>
-
</modules>
在子模块中指定父模块:
-
<parent>
-
<groupId>com.example</groupId>
-
<artifactId>nacos-learn-parent</artifactId>
-
<version>0.0.1-SNAPSHOT</version>
-
</parent>
2. 编写测试Controller
在order启动类中引入RestTemplate,用于微服务之间的接口调用
-
@SpringBootApplication
-
public class OrderNacosApplication {
-
public static void main(String[] args) {
-
SpringApplication.run(OrderNacosApplication.class, args);
-
}
-
-
@Bean
-
public RestTemplate restTemplate(RestTemplateBuilder builder) {
-
RestTemplate restTemplate = builder.build();
-
return restTemplate;
-
}
-
}
在订单的微服务模块下创建 OrderController:
@RestController @RequestMapping("/order") public class OrderController { @Autowired RestTemplate restTemplate; @RequestMapping("/add") public String add() { System.out.println("下单成功!"); String msg = restTemplate.getForObject("http://stock-service/stock/reduct", String.class); return "下订单了!" + msg; } }
在库存的微服务模块下创建 StockController:
-
@RestController
-
@RequestMapping("/stock")
-
public class StockController {
-
-
@Value("${server.port}")
-
String port;
-
-
@RequestMapping("/reduct")
-
public String reduct() {
-
System.out.println("扣减库存");
-
return "库存-1,调用的库存服务的端口号为:" + port;
-
}
-
}
3. 服务注册与发现的配置
订单模块Application.yml 配置:
-
server:
-
port: 8020 #订单服务启动的端口
-
spring:
-
application:
-
name: order-service #nacos会将该名称当作服务名称
-
cloud:
-
nacos:
-
server-addr: 127.0.0.1:8848 #nacos服务地址
-
discovery:
-
username: nacos #登录到nacos管理平台的用户名
-
password: nacos #登录到nacos管理平台的密码
-
namespace: public #服务的命名空间,就相当于一个文件夹,用来区分服务实例
库存模块Applicaion.yml 配置:
-
server:
-
port: 8021 #库存服务启动的端口号
-
spring:
-
application:
-
name: stock-service #nacos会将该名称当作服务名称
-
cloud:
-
nacos:
-
server-addr: 127.0.0.1:8848 #nacos服务地址
-
discovery:
-
username: nacos #登录到nacos管理平台的用户名
-
password: nacos #登录到nacos管理平台的密码
-
namespace: public #服务的命名空间,就相当于一个文件夹,用来区分服务实例
启动两个服务:

访问浏览器测试调用接口是否成功:

-
@Bean
-
@LoadBalanced
-
public RestTemplate restTemplate(RestTemplateBuilder builder) {
-
RestTemplate restTemplate = builder.build();
-
return restTemplate;
-
}
查看Nacos 管理面板:
可以看到两个服务以及注册到nacos。

补充:关于 Nacos Starter 更多的配置项信息
| 配置项 | Key | 默认值 | 说明 |
|---|---|---|---|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
4. 验证负载均衡配置
Nacos 默认使用的是 Ribbon 提供的负载均衡机制,Ribbon 属于客户端的负载均衡,默认使用的方式是轮询。
(1)在RestTemplate配置上加 @LoadBalanced注解
-
@Bean
-
@LoadBalanced
-
public RestTemplate restTemplate(RestTemplateBuilder builder) {
-
RestTemplate restTemplate = builder.build();
-
return restTemplate;
-
}
(2)在StockController 的/reduct接口被调用时,返回该服务的端口号
-
@RestController
-
@RequestMapping("/stock")
-
public class StockController {
-
-
@Value("${server.port}")
-
String port;
-
-
@RequestMapping("/reduct")
-
public String reduct() {
-
System.out.println("扣减库存");
-
return "库存-1,调用的库存服务的端口号为:" + port;
-
}
-
}
(3)启动两个库存服务,右键点击 Copy Configuration 选项,选择启动的端口号为8022:
就是库存服务要在多个端口启动时,这样来操作


可以看到在Nacos服务列表中,stock-service多了一个实例:

验证负载均衡:



[转帖]服务注册与发现:Nacos Discovery的更多相关文章
- Alibaba Nacos 学习(三):Spring Cloud Nacos Discovery - FeignClient,Nacos 服务注册与发现
Alibaba Nacos 学习(一):Nacos介绍与安装 Alibaba Nacos 学习(二):Spring Cloud Nacos Config Alibaba Nacos 学习(三):Spr ...
- Spring Cloud Alibaba基础教程:使用Nacos实现服务注册与发现
自Spring Cloud Alibaba发布第一个Release以来,就备受国内开发者的高度关注.虽然Spring Cloud Alibaba还没能纳入Spring Cloud的主版本管理中,但是凭 ...
- Spring Cloud Alibaba | Nacos服务注册与发现
目录 Spring Cloud Alibaba | Nacos服务注册与发现 1. 服务提供者 1.1 pom.xml项目依赖 1.2 配置文件application.yml 1.3 启动类Produ ...
- Spring Cloud Alibaba(一) 如何使用nacos服务注册和发现
Nacos介绍 Nacos 致力于帮助您发现.配置和管理微服务.Nacos 提供了一组简单易用的特性集,帮助您快速实现动态服务发现.服务配置.服务元数据及流量管理. Nacos 帮助您更敏捷和容易地构 ...
- nacos 的服务注册与发现
nacos的服务注册于发现. 这个要求服务统一注册到注册中心,然后调用的时候就不需要通过ip来调用,直接通过服务名即可. 服务提供者 pom.xml配置,需要spring-cloud-starter- ...
- Spring Cloud Alibaba 实战 之 Nacos 服务注册和发现
服务注册与发现,服务发现主要用于实现各个微服务实例的自动化注册与发现,是微服务治理的核心,学习 Spring Cloud Alibaba,首先要了解框架中的服务注册和发现组件——Nacos. 一.Sp ...
- 2021升级版微服务教程4—Nacos 服务注册和发现
2021升级版SpringCloud教程从入门到实战精通「H版&alibaba&链路追踪&日志&事务&锁」 默认文件1610014380163 教程全目录「含视 ...
- Spring Cloud Alibaba Nacos 服务注册与发现功能实现!
Nacos 是 Spring Cloud Alibaba 中一个重要的组成部分,它提供了两个重要的功能:服务注册与发现和统一的配置中心功能. 服务注册与发现功能解决了微服务集群中,调用者和服务提供者连 ...
- Nacos服务注册与发现的2种实现方法!
Spring Cloud Alibaba 技术体系中的 Nacos,提供了两个重要的功能:注册中心(服务注册与发现)功能和配置中心功能. 其中注册中心解决了微服务调用中,服务提供者和服务调用者的解耦, ...
- Spring Cloud进阶之路 | 一:服务注册与发现(nacos)
转载请注明作者及出处: 作者:银河架构师 原文链接:https://www.cnblogs.com/luas/p/12068846.html 1.版本 最新稳定版本为1.1.4,也可以从发版说明.博客 ...
随机推荐
- CUDA C编程权威指南:1.2-CUDA基础知识点梳理
主要整理了N多年前(2013年)学习CUDA的时候开始总结的知识点,好长时间不写CUDA代码了,现在LLM推理需要重新学习CUDA编程,看来出来混迟早要还的. 1.闭扫描和开扫描 对于一个二元 ...
- 火山引擎DataLeap如何解决SLA治理难题(三): 平台架构与未来展望
更多技术交流.求职机会,欢迎关注字节跳动数据平台微信公众号,回复[1]进入官方交流群 平台架构总结 火山引擎 DataLeap SLA平台整体主要分为基础组件.规划式治理服务.响应式治理服务三大块,系 ...
- 如何删除PPT中工具栏口袋动画
口袋动画官网无法打开 http://www.papocket.com/ 插件无法使用 卸载 在[程序和功能]中卸载后,打开PPT,菜单还是存在 选项--加载项,点击以p开头的一串代码(com加载项), ...
- PPT 模仿力,看到好的设计随意为我所用
PPT 模仿力,看到好的设计随意为我所用 网上搜索一些作品 Q1: 这一页的设计亮点在哪? Q2: 我能不能用在PPT里面? Q3: 我能不能用PPT模仿出来? 举例 思源黑体
- web自动化-selenium携带cookie免密登录
在我们做web自动化的时候,经常会遇到含有登录的页面,我们必须登录之后才能够对我们想要操作的页面元素进行定位,也就是说所有的操作都在登录前提下,其实没必要每次请求都先登录,当我们登录成功了,会在coo ...
- TypeError: this.libOptions.parse is not a function
安装完node.js运行项目后,报错: TypeError: this.libOptions.parse is not a function at ESLint8Plugin.<anonymou ...
- 【CJsonObject】C++ JSON 解析器使用教程
能选封装的尽量不使用底层的 一.CJsonObject 简介 CJsonObject 是 Bwar 基于 cJSON 全新开发一个 C++ 版的 JSON 库. CJsonObject 的最大优势是轻 ...
- 在 Ubuntu 20.04 上安装 Visual Studio Code
Visual Studio Code 是一个由微软开发的强大的开源代码编辑器.它包含内建的调试支持,嵌入的 Git 版本控制,语法高亮,代码自动完成,集成终端,代码重构以及代码片段功能. Visual ...
- 如果很好说出finalize用法,面试官会认为你很资深
我在面试Java候选人的时候,有时候会通过finalize问及候选人在JVM方面的技能,一般的问法是:你知不知道finalize方法,在项目里有没有重写过这个方法?在本文里就将详细来说下这个知识点. ...
- 基于函数计算自定义运行时快速部署一个 springboot 项目 什么是函数计算?
什么是函数计算? 函数计算是事件驱动的全托管计算服务.使用函数计算,您无需采购与管理服务器等基础设施,只需编写并上传代码.函数计算为您准备好计算资源,弹性地可靠地运行任务,并提供日志查询.性能监控和报 ...
