java

关注公众号 jb51net

关闭
首页 > 软件编程 > java > SpringCloud 注册中心

SpringCloud两种注册中心的实现

作者:Annaday

本文主要介绍了SpringCloud两种注册中心的实现,包括服务注册、服务拉取、负载均衡和实例权重配置等,具有一定的参考价值,感兴趣的可以了解一下

基本概念

系统架构

我们之前做的所有的项目都属于单体架构,下面我们将要学习更适合大型项目的分布式架构

单体架构: 将业务的所有功能几种在一个项目中开发,打成一个包部署。

优点:架构简单、部署成本低
缺点:耦合度高

分布式架构: 根据业务功能对系统进行拆分、每个业务模块作为独立项目开发,称为一个服务。

优点:降低服务耦合、有利于服务升级拓展。
缺点:架构复杂、运维、监控、部署难度高。

微服务

微服务是一种经过良好的架构设计的分布式架构方案。

微服务架构特征:

级联问题常涉及数据的关联性操作引发的一系列连锁变化。

微服务结构:

最知名的两种技术架构:SpringCloud、阿里巴巴Dubbo

SpringCloud集成了各种微服务功能组件。

并基于SpringBoot实现了这些组件的自动装配,从而提供了良好的体验。

服务的拆分总结:

远程调用

案例:有两个服务分别是用户服务和订单服务,要求根据订单ID查询订单的同时,把订单所属的用户信息一起返回。

前面知道不同服务之间数据库互相独立,所以我们就只能在后端再发一次http请求,去调用其他服务的接口。

这就需要在Java代码中,发起HTTP请求,此处使用 RestTemplate

RestTemplate 是 Spring 框架提供的一个同步的 HTTP 客户端工具,用于在 Java 应用程序中发送 HTTP 请求并处理响应。

// 我们需要在配置类中声明一个Bean,启动类也属于配置类,所以此方法也可写入启动类中。

/**
 * 创建RestTemplate并注入Spring容器
 * @return
 */
@Bean
public RestTemplate restTemplate(){
    return new RestTemplate();
}

然后就可以在Java代码中发送请求了

@Service
public class OrderService {

    @Autowired
    private OrderMapper orderMapper;
    @Autowired
    private RestTemplate restTemplate;

    public Order queryOrderById(Long orderId) {
        // 1.查询订单
        Order order = orderMapper.findById(orderId);

        String url = "http://localhost:8081/user/" + order.getUserId();
        //使用RestTemplate发送请求,第一个参数为请求地址,第二个参数为序列化返回对象
        User user = restTemplate.getForObject(url, User.class);
        order.setUser(user);
        // 4.返回
        return order;
    }
}

提供者与消费者

服务调用关系:

Eureka注册中心

前面书写存在一些问题,有硬编码的部分,请求地址是写死了。

Eureka作用

消费者该如何获取服务提供者具体信息?

如果有多个服务提供者,消费者该如何选择?

消费者如何感知服务提供者健康状态?

在Eureka架构中,微服务角色有两类:

EurekaServer : 服务端,注册中心

EurekaClient : 客户端

搭建Eureka Server服务端

第一步:创建新的Maven模块,引入eureka-server依赖

<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
</dependency>

第二步:为启动类添加启动注解

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

第三步:添加配置信息

server:
  port: 10086
spring:
  application:
    name: eurekaserver

eureka:
  client:
    service-url: #eureka地址信息
      defaultZone: http://127.0.0.1:10086/eureka

注册user-service

第一步:在需要注册的服务中引入eureka-client依赖

<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
</dependency>

第二步:在配置文件中,添加配置

spring:
  application:
    name: userserver

eureka:
  client:
    service-url: #eureka地址信息
      defaultZone: http://127.0.0.1:10086/eureka

同理也可以注册order-service

复制服务,右键要copy的服务,点击Copy Configuration
起一个名称,然后在VM options中配置一个新的端口
-Dserver.port=8082

服务拉取

服务拉取是基于服务器名称获取服务列表,然后在对服务列表做负载均衡

String url = "http://userservice/user/" + order.getUserId();
@Bean
@LoadBalanced
public RestTemplate restTemplate(){
    return new RestTemplate();
}

Ribbon负载均衡

Nacos注册中心

启动方式:

startup.cmd -m standalone

服务注册

在父工程中添加spring-cloud-alibaba的管理依赖

<!-- Nacos 管理依赖-->
<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-alibaba-dependencies</artifactId>
    <version>2.2.5.RELEASE</version>
    <type>pom</type>
    <scope>import</scope>
</dependency>

注释原有的eureka依赖,添加nacos的客户端依赖

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

修改配置文件

spring:
  application:
    name: orderservice
  cloud:
    nacos:
      server-addr: localhost:8848 #nacos服务地址

Nacos服务分级存储模型

一个服务可以有多个实例,大型公司会将实例部署在不同的服务器内。一个服务器机房就称为一个集群。
服务调用尽可能调用本地集群的服务,跨集群调用延迟较高,只有当本地集群不可访问时,再去访问其他的集群。

配置服务集群属性,修改yml

spring:
  cloud:
    nacos:
      server-addr: localhost:8848 # Nacos 服务端地址
      discovery:
        cluster-name: HB # 配置集群名称,机房位置

如果想要设置优先访问同集群服务,则需要修改负载均衡的IRule

userservice: # 要做配置的微服务名称
  ribbon:
    NFLoadBalancerRuleClassName: com.alibaba.cloud.nacos.ribbon.NacosRule # 负载均衡规则

注意将user-service的权重都设置为1

小结NacosRule负载均衡策略:

根据权重负载均衡

实际部署中会出现这样的场景:
服务器设备性能有差异,部分实例所在机器性能较好,另一些较差,我们希望性能好的机器承担更多的用户请求

Nacos提供了权重配置来控制访问频率,权重越大访问频率越高。
在Nacos控制台可以设置实例的权重值,点击编辑按钮

小结:实例的权重控制

环境隔离 - namespace

Nacos 中服务存储和数据存储的最外层都是一个名为namespace的东西,用来做最外层隔离
注意:服务只能访问当前命名空间,无法访问其他命名空间的服务

Namespace 下有 Group 下有 Service / Data

新建命名空间:在Nacos控制台中 - > 命名空间 -> 新建命名空间
在代码中修改服务到新的命名空间:

spring:
  cloud:
    nacos:
      server-addr: localhost:8848 #nacos服务地址
      discovery:
        cluster-name: HB # 集群名称
        namespace: xxxx # 命名空间id

Nacos环境隔离

临时实例与非临时实例

服务注册到Nacos时,可以选择注册为临时或非临时实例,通过下面的配置来设置

spring:
  cloud:
    nacos:
      server-addr:
      discovery:
        namespace:
        ephemeral: false #是否为临时实例

临时实例宕机时,会从nacos的服务列表中剔除,而非临时实例则不会

与Eureka的对比

Nacos与eureka的共同点

Nacos与Eureka的区别

AP 可用性保证
CP 一致性保证

 到此这篇关于SpringCloud两种注册中心的实现的文章就介绍到这了,更多相关SpringCloud 注册中心内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文