【微服务】Nacos注册中心

news/2024/11/22 21:36:09/

目录

1.服务间如何进行远程调用

2.什么是服务治理

3.常见注册中心

4.Nacos 简介

5.Nacos实战入门


1.服务间如何进行远程调用

        上篇文章搭建了订单服务和商品服务【微服务】-微服务环境搭建_MXin5的博客-CSDN博客,商品微服务已经提供了数据接⼝了,订单微服务应该如何去调⽤呢?
       
        其实就是如何通过Java代码去调⽤⼀个http的接⼝地址,我们可以使⽤RestTemplate来进⾏调⽤
1.在启动类上添加RestTemplatebean配置
@SpringBootApplication
public class OrderServer {public static void main(String[] args) {SpringApplication.run(OrderServer.class,args);}@Beanpublic RestTemplate restTemplate(){return new RestTemplate();}
}
2.OrderServiceImpl中注⼊RestTemplate并实现远程调⽤
@Service
@Slf4j
public class OrderServiceImpl implements OrderService {@Autowiredprivate OrderDao orderDao;@Autowiredprivate RestTemplate restTemplate;@Overridepublic Order createOrder(Long productId,Long userId) {log.info("接收到{}号商品的下单请求,接下来调⽤商品微服务查询此商品信息",
productId);//远程调⽤商品微服务,查询商品信息Product product = restTemplate.getForObject("http://localhost:8081/product/"+productId,Product.class);log.info("查询到{}号商品的信息,内容是:{}", productId,
JSON.toJSONString(product));//创建订单并保存Order order = new Order();order.setUid(userId);order.setUsername("mxin5");order.setPid(productId);order.setPname(product.getPname());order.setPprice(product.getPprice());order.setNumber(1);orderDao.save(order);log.info("创建订单成功,订单信息为{}", JSON.toJSONString(order));return order;}
}
虽然我们已经可以实现微服务之间的调⽤。但是我们把服务提供者的⽹络地址(ip,端⼝)等硬编码到了代码中,这种做法存在许多问题:
⼀旦服务提供者地址变化,就需要⼿⼯修改代码
⼀旦是多个服务提供者,⽆法实现负载均衡功能
⼀旦服务变得越来越多,⼈⼯维护调⽤关系困难
那么应该怎么解决呢, 这时候就需要通过注册中⼼动态的实现服务治理,这时候就引入了Nacos进行实现服务治理。

2.什么是服务治理

服务治理是微服务架构中最核⼼最基本的模块。⽤于实现各个微服务的⾃动化注册与发现
服务注册:在服务治理框架中,都会构建⼀个注册中⼼,每个服务单元向注册中⼼登记⾃⼰提供服
务的详细信息。并在注册中⼼形成⼀张服务的清单,服务注册中⼼需要以⼼跳的⽅式去监测清单中
的服务是否可⽤,如果不可⽤,需要在服务清单中剔除不可⽤的服务。
服务发现:服务调⽤⽅向服务注册中⼼咨询服务,并获取所有服务的实例清单,实现对具体服务实
例的访问。

通过上⾯的调⽤图会发现,除了微服务,还有⼀个组件是服务注册中⼼,它是微服务架构⾮常重要
的⼀个组件,在微服务架构⾥主要起到了协调者的⼀个作⽤。注册中⼼⼀般包含如下⼏个功能:
1. 服务发现:
服务注册:保存服务提供者和服务调⽤者的信息
服务订阅:服务调⽤者订阅服务提供者的信息,注册中⼼向订阅者推送提供者的信息
2. 服务健康检测
检测服务提供者的健康情况,如果发现异常,执⾏服务剔除。

3.常见注册中心

Zookeeper
Zookeeper是⼀个分布式服务框架,是Apache Hadoop 的⼀个⼦项⽬,它主要是⽤来解决分布式
应⽤中经常遇到的⼀些数据管理问题,如:统⼀命名服务、状态同步服务、集群管理、分布式应⽤
配置项的管理等。
Eureka
EurekaSpringcloud Netflflix中的重要组件,主要作⽤就是做服务注册和发现。但是现在已经闭
Consul
Consul是基于GO语⾔开发的开源⼯具,主要⾯向分布式,服务化的系统提供服务注册、服务发现
和配置管理的功能。Consul的功能都很实⽤,其中包括:服务注册/发现、健康检查、Key/Value
存储、多数据中⼼和分布式⼀致性保证等特性。Consul本身只是⼀个⼆进制的可执⾏⽂件,所以
安装和部署都⾮常简单,只需要从官⽹下载后,在执⾏对应的启动脚本即可。
Nacos
Nacos是⼀个更易于构建云原⽣应⽤的动态服务发现、配置管理和服务管理平台。它是 Spring
Cloud Alibaba 组件之⼀,负责服务注册发现和服务配置。

4.Nacos 简介

Nacos 致⼒于帮助您发现、配置和管理微服务。Nacos 提供了⼀组简单易⽤的特性集,帮助您快速
实现动态服务发现、服务配置、服务元数据及流量管理。
从上⾯的介绍就可以看出,Nacos的作⽤就是⼀个注册中⼼,⽤来管理注册上来的各个微服务。
核心功能点:
服务注册: Nacos Client会通过发送REST请求想Nacos Server注册⾃⼰的服务,提供⾃身的元数
据,⽐如IP地址,端⼝等信息。Nacos Server接收到注册请求后,就会把这些元数据存储到⼀个双
层的内存Map中。
服务⼼跳: 在服务注册后,Nacos Client会维护⼀个定时⼼跳来维持统治Nacos Server,说明服务⼀
致处于可⽤状态,防⽌被剔除,默认5s发送⼀次⼼跳
服务同步: Nacos Server集群之间会相互同步服务实例,⽤来保证服务信息的⼀致性。
服务发现: 服务消费者(Nacos Client)在调⽤服务提供的服务时,会发送⼀个REST请求给Nacos
Server,获取上⾯注册的服务清单,并且缓存在Nacos Client本地,同时会在Nacos Client本地开启⼀
个定时任务拉取服务最新的注册表信息更新到本地缓存。
服务健康检查: Nacos Server 会开启⼀个定时任务来检查注册服务实例的健康情况,对于超过15s
没有收到客户端⼼跳的实例会将他的healthy属性设置为false(客户端服务发现时不会发现),如果某
个实例超过30s没有收到⼼跳,直接剔除该实例(被剔除的实例如果恢复发送⼼跳则会重新注册)

5.Nacos实战入门

接下来,我们就在现有的环境中加⼊nacos,并将我们的两个微服务注册上去。
1 搭建Nacos环境
1. 安装Nacos
下载地址: https://github.com/alibaba/nacos/releases
下载zip格式的安装包,然后进⾏解压缩操作,上课使⽤的Nacos Server版本是1.3.2

2. 启动Nacos

#切换⽬录
cd nacos/bin
#命令启动
startup.cmd -m standalone
3. 访问Nacos
打开浏览器输⼊http://localhost:8848/nacos,即可访问服务, 默认密码是nacos/nacos

2 将商品服务注册到Nacos

接下来开始修改 shop-product-server 模块的代码, 将其注册到nacos服务上
1. pom.xml中添加Nacos的依赖
<!--nacos客户端-->
<dependency>
        <groupId>com.alibaba.cloud</groupId>
        <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency

2. 在主类上添加@EnableDiscoveryClient注解

@SpringBootApplication
@EnableDiscoveryClient
public class ProductServer {
public static void main(String[] args) {
        SpringApplication.run(ProductServer.class,args);
        }
}

3. application.yml中添加Nacos服务的地址

spring:
  cloud:
   nacos:
    discovery:
     server-addr: localhost:8848

4. 启动服务, 观察Nacos的控制⾯板中是否有注册上来的商品微服务

3 将订单服务注册到Nacos

接下来开始修改 shop-order-server 模块的代码, 将其注册到nacos服务上
1. pom.xml中添加Nacos的依赖
<!--nacos客户端-->
<dependency>
        <groupId>com.alibaba.cloud</groupId>
        <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>

2. 在主类上添加@EnableDiscoveryClient注解

@SpringBootApplication
@EnableDiscoveryClient
public class OrderServer {
public static void main(String[] args) {
        SpringApplication.run(OrderServer.class,args);
        }
}

3. application.yml中添加Nacos服务的地址

spring:
 cloud:
  nacos:
   discovery:
    server-addr: localhost:8848

4. 启动服务, 观察Nacos的控制⾯板中是否有注册上来的订单微服务

 

5. 修改OrderServiceImpl, 实现微服务调⽤

@Service
@Slf4j
public class OrderServiceImpl implements OrderService {@Autowiredprivate OrderDao orderDao;@Autowiredprivate DiscoveryClient discoveryClient;@Autowiredprivate RestTemplate restTemplate;@Overridepublic Order createOrder(Long productId,Long userId) {log.info("接收到{}号商品的下单请求,接下来调⽤商品微服务查询此商品信息",
productId);//从nacos中获取服务地址ServiceInstance instance = discoveryClient.getInstances("product-service").get(0);String url = instance.getHost()+":"+instance.getPort();//远程调⽤商品微服务,查询商品信息Product product = restTemplate.getForObject("http://"+url+"/product/"+productId,Product.class);log.info("查询到{}号商品的信息,内容是:{}", productId,JSON.toJSONString(product));//创建订单并保存Order order = new Order();order.setUid(userId);order.setUsername("叩丁狼教育");order.setPid(productId);order.setPname(product.getPname());order.setPprice(product.getPprice());order.setNumber(1);orderDao.save(order);log.info("创建订单成功,订单信息为{}", JSON.toJSONString(order));return order;}
}


http://www.ppmy.cn/news/29390.html

相关文章

C语言函数阐述

C 函数 函数是一组一起执行一个任务的语句。每个 C 程序都至少有一个函数&#xff0c;即主函数 main() &#xff0c;所有简单的程序都可以定义其他额外的函数。 您可以把代码划分到不同的函数中。如何划分代码到不同的函数中是由您来决定的&#xff0c;但在逻辑上&#xff0c…

【项目实战】32G的电脑启动IDEA一个后端服务要2min,谁忍的了?

一、背景 本人电脑性能一般&#xff0c;但是拥有着一台高性能的VDI&#xff08;虚拟桌面基础架构&#xff09;&#xff0c;以下是具体的配置 二、问题描述 但是&#xff0c;即便是拥有这么高的性能&#xff0c;每次运行基于Dubbo微服务架构下的微服务都贼久&#xff0c;以下…

如何用Python把篮球和鸡联系起来

文章目录画个球让球转起来画个球 不管篮球和不和鸡联系起来&#xff0c;都首先得有个球&#xff0c;或者说要有一个球面&#xff0c;用参数方程可以表示为 xrcos⁡ϕcos⁡θyrcos⁡ϕsin⁡θzrsin⁡ϕ\begin{aligned} x & r\cos\phi\cos\theta\\ y & r\cos\phi\sin\th…

JavaSe第4次笔记

1.转义字符和编程语言无关。 2.斜杠(\)需要转义&#xff0c;反斜杠(/)不需要转义。 3.不能做switch的参数的数据类型&#xff1a;long float double boolean( String可以)。 4.输入的写法&#xff1a;Scanner(回车自动带头文件(import java.util.Scanner;)) Scanner scan …

经验分享-如何使用http调用chatGPT-3.5-turbo模型API

今天上午&#xff0c;就在工作群里收到了关于openAI发布chatGPT官方模型的消息分享。openAI这次的动作真的很快啊&#xff0c;没想到这么快就直接发布了chatGPT目前所使用的模型api。据Open AI在官方消息&#xff0c;本次开放了ChatGPT和Whisper的模型API&#xff0c;可以供用户…

【相关分析-高阶绘图】MATLAB实现皮尔逊相关分析-散点直方图

虽然皮尔逊相关分析很常见,但如何更好的展现相关性、散点分布、柱状分布,以提升研究结果的美感和冲击感呢?本文拟通过MATLAB绘制包含散点分布、柱状分布、线性展示的散点直方图,有助于审稿人眼前一亮。 1、Pearson相关系数原理 Pearson相关系数(Pearson Correlation Co…

【Spring】八种常见Bean加载方式

&#x1f6a9;本文已收录至专栏&#xff1a;Spring家族学习 一.引入 (1) 概述 ​ 关于bean的加载方式&#xff0c;spring提供了各种各样的形式。因为spring管理bean整体上来说就是由spring维护对象的生命周期&#xff0c;所以bean的加载可以从大的方面划分成2种形式&#xff…

LeetCode 面试题 05.02. 二进制数转字符串

【LetMeFly】面试题 05.02.二进制数转字符串 力扣题目链接&#xff1a;https://leetcode.cn/problems/bianry-number-to-string-lcci/ 二进制数转字符串。给定一个介于0和1之间的实数&#xff08;如0.72&#xff09;&#xff0c;类型为double&#xff0c;打印它的二进制表达式…