【微服务】Nacos注册中心

目录

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

2.什么是服务治理

3.常见注册中心

4.Nacos 简介

5.Nacos实战入门


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

        上篇文章搭建了订单服务和商品服务 【微服务】-微服务环境搭建_MXin5的博客-CSDN博客 ,商品微服务已经提供了数据接⼝了,订单微服务应该如何去调⽤呢?
        
        其实就是如何通过Java 代码去调⽤⼀个 http 的接⼝地址,我们可以使⽤ RestTemplate 来进⾏调⽤
1. 在启动类上添加 RestTemplate bean 配置
@SpringBootApplication
public class OrderServer {
 public static void main(String[] args) {
 SpringApplication.run(OrderServer.class,args);
 }
 @Bean
 public RestTemplate restTemplate(){
 return new RestTemplate();
 }
}
2. OrderServiceImpl 中注⼊ RestTemplate 并实现远程调⽤
@Service
@Slf4j
public class OrderServiceImpl implements OrderService {
 @Autowired
 private OrderDao orderDao;
 @Autowired
 private RestTemplate restTemplate;
 @Override
 public 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
Eureka Springcloud 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注解

/**
 * Created by mxin5
 */
@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: 194.168.23.101: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注解

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
import org.springframework.cloud.client.loadbalancer.LoadBalanced;
import org.springframework.cloud.openfeign.EnableFeignClients;
import org.springframework.context.annotation.Bean;
import org.springframework.web.client.RestTemplate;

/**
 * Created by mxin5
 */
@SpringBootApplication
@EnableDiscoveryClient
@EnableFeignClients
public class OrderServer {
    public static void main(String[] args) {
        SpringApplication.run(OrderServer.class,args);
    }

    /**
     * 远程调用通过resttemplate进行调用,直接进行bean的注入,那个业务需要直接autowired进行注入
     * @LoadBalanced就可以实现负载均衡,原理就是一个标记,标记Resttemplate发出的请求要被我们的Ribbon进行拦截和处理
     * */
    @LoadBalanced
    @Bean
    public RestTemplate restTemplate(){
        return new RestTemplate();
    }
}

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

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

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

 

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

@Service
@Slf4j
public class OrderServiceImpl implements OrderService {
    @Autowired
    private OrderDao orderDao;
    @Autowired
    private DiscoveryClient discoveryClient;
    @Autowired
    private RestTemplate restTemplate;

    @Override
    public 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("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;
    }
}

  • 4
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Mxin5

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值