Spring Cloud Nacos 和 Eureka区别解析

 更新时间:2023年08月30日 10:54:17   作者:Web3&Basketball  
Spring Cloud Nacos 和 Spring Cloud Eureka 都是 Spring Cloud 微服务框架中的服务注册和发现组件,用于帮助开发者轻松地构建和管理微服务应用,这篇文章主要介绍了Spring Cloud Nacos 和 Eureka区别,需要的朋友可以参考下

Spring Cloud Nacos 和 Spring Cloud Eureka 都是 Spring Cloud 微服务框架中的服务注册和发现组件,用于帮助开发者轻松地构建和管理微服务应用。它们之间的主要区别在于底层架构、服务发现方式、配置管理和支持的编程语言等方面。

一、Spring Cloud Eureka详解

Spring Cloud Eureka 是基于 Netflix Eureka 的二次封装,用于实现微服务实例自动化注册与发现。它主要负责完成微服务架构中的服务治理功能。以下是 Spring Cloud Eureka 的详解,包括代码示例。

1.添加依赖

在项目的 build.gradle 文件中添加 Spring Cloud Eureka 依赖:

dependencies {  
   implementation 'org.springframework.cloud:spring-cloud-starter-eureka'  
}

2.配置 application.yaml

在 application.yaml 文件中配置 Eureka 服务的相关属性:

server:  
 port: 8080
eureka:  
 client:  
   serviceUrl:  
     defaultZone: http://localhost:8761/eureka/  

3.启动类添加依赖

在启动类上添加 @EnableDiscoveryClient 注解,以启用 Eureka 服务发现功能:

import org.springframework.cloud.client.discovery.EnableDiscoveryClient;  
import org.springframework.boot.SpringApplication;  
import org.springframework.boot.autoconfigure.SpringBootApplication;
@SpringBootApplication  
@EnableDiscoveryClient  
public class EurekaDemoApplication {  
   public static void main(String[] args) {  
       SpringApplication.run(EurekaDemoApplication.class, args);  
   }  
}

4.服务注册与发现

在服务提供者中,通过 @EnableEurekaServer 注解启用 Eureka 服务注册功能,并在启动类上添加 @Value 注解配置 Eureka 服务端口号:

import org.springframework.cloud.netflix.eureka.server.EnableEurekaServer;  
import org.springframework.boot.SpringApplication;  
import org.springframework.boot.autoconfigure.SpringBootApplication;
@SpringBootApplication  
@EnableEurekaServer(port = 8761)  
public class EurekaServerApplication {  
   public static void main(String[] args) {  
       SpringApplication.run(EurekaServerApplication.class, args);  
   }  
}

在服务消费者中,通过 @RestController 和 @RequestMapping 注解暴露一个 REST 接口,并在 @Value 注解中配置 Eureka 服务端口号。同时,使用 RestTemplate 调用其他服务:

import org.springframework.cloud.client.discovery.EnableDiscoveryClient;  
import org.springframework.web.bind.annotation.GetMapping;  
import org.springframework.web.bind.annotation.RestController;  
import org.springframework.boot.SpringApplication;  
import org.springframework.boot.autoconfigure.SpringBootApplication;
@SpringBootApplication  
@RestController  
@EnableDiscoveryClient  
public class EurekaClientApplication {
   @Value("${eureka.client.serviceUrl.defaultZone}")  
   private String defaultZone;
   @GetMapping("/hi")  
   public String home(@RequestParam String name) {  
       String url = defaultZone + "/eureka-client/hello";  
       RestTemplate restTemplate = new RestTemplate();  
       return restTemplate.getForObject(url, String.class, name);  
   }
   public static void main(String[] args) {  
       SpringApplication.run(EurekaClientApplication.class, args);  
   }  
}

5.自定义 Eureka 界面

  • 可以通过修改 Spring Cloud Eureka 的默认界面来实现自定义界面。在 src/main/resources/static 目录下,找到 eureka-dashboard.html 文件,将其复制到项目中的静态资源目录,并进行相应的修改。
  • 综上所述,Spring Cloud Eureka 是一个用于实现微服务实例自动化注册与发现的服务治理组件。通过在项目中添加依赖、配置 application.yaml、启动类添加依赖、服务注册与发现以及自定义 Eureka 界面,可以实现 Spring Cloud Eureka 的基本功能。

二、Spring Cloud Nacos详解

可以参考之前写的文章:https://python-basketball.blog.csdn.net/article/details/132506054?spm=1001.2014.3001.5502

三、Spring Cloud Nacos和Eureka区别

1.底层架构:
Nacos 是一个全新的轻量级动态服务发现、配置管理和服务管理的平台,基于阿里巴巴自研的 Nacos 技术。
Eureka 是 Netflix 开源的一个服务注册和发现框架,基于 RESTful API 进行服务之间的通信。
2.服务发现方式:
Nacos 使用 DNS 方式进行服务发现,将服务注册信息存储在 DNS 服务器中,使得服务发现更加高效和可靠。
Eureka 则使用 HTTP 协议进行服务发现,需要通过请求 Eureka 服务端来获取服务注册信息。
3.配置管理:
Nacos 支持配置的动态管理,可以实现配置的修改和更新,同时支持配置的版本控制。
Eureka 不支持配置的动态管理,需要通过人工的方式进行配置的修改和更新。
4.支持的编程语言:
Nacos 支持多种编程语言,包括 Java、Python、Go、Node.js 等。
Eureka 仅支持 Java 语言。
下面是一个简单的示例来展示如何使用 Spring Cloud Nacos 和 Spring Cloud Eureka:
Nacos
首先,需要在项目中引入 Nacos 的依赖:

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

然后,在启动类上添加 @EnableDiscoveryClient @NacosPropertySource 注解:

import com.alibaba.cloud.spring.boot.context.annotation.config.NacosPropertySource;  
import com.alibaba.cloud.spring.boot.context.annotation.EnableDiscoveryClient;  
import org.springframework.boot.SpringApplication;  
import org.springframework.boot.autoconfigure.SpringBootApplication;
@SpringBootApplication  
@EnableDiscoveryClient  
@NacosPropertySource(dataId = "your-data-id", autoRefreshed = true)  
public class NacosDemoApplication {  
   public static void main(String[] args) {  
       SpringApplication.run(NacosDemoApplication.class, args);  
   }  
}

Eureka

首先,需要在项目中引入 Eureka 的依赖:

<dependency>  
   <groupId>com.netflix</groupId>  
   <artifactId>eureka-client</artifactId>  
</dependency>  

然后,在启动类上添加 @EnableDiscoveryClient 注解,并配置 Eureka 服务端地址:

import org.springframework.cloud.client.discovery.EnableDiscoveryClient;  
import org.springframework.boot.SpringApplication;  
import org.springframework.boot.autoconfigure.SpringBootApplication;
@SpringBootApplication  
@EnableDiscoveryClient(eurekaServerUrl = "http://localhost:8761/eureka/")  
public class EurekaDemoApplication {  
   public static void main(String[] args) {  
       SpringApplication.run(EurekaDemoApplication.class, args);  
   }  
}

综上所述,Spring Cloud Nacos 和 Spring Cloud Eureka 都是服务注册和发现框架,但它们在底层架构、服务发现方式、配置管理和支持的编程语言等方面有所不同。在实际应用中,可以根据项目需求和团队熟悉程度选择合适的框架。

到此这篇关于Spring Cloud Nacos 和 Eureka区别的文章就介绍到这了,更多相关Spring Cloud Nacos 和 Eureka内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • SpringCloud分布式链路跟踪的方法

    SpringCloud分布式链路跟踪的方法

    这篇文章主要介绍了SpringCloud分布式链路跟踪的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2019-03-03
  • java实现图片无损任意角度旋转

    java实现图片无损任意角度旋转

    这篇文章主要为大家详细介绍了java实现图片无损任意角度旋转,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-02-02
  • 将Java程序包打包为.exe文件的操作步骤

    将Java程序包打包为.exe文件的操作步骤

    将Java程序打包为为.exe文件分为俩个步骤:将Java程序打包成Jar包和打包为.exe文件,文中通过图文结合的方式给大家讲解的非常详细,具有一定的参考价值,需要的朋友可以参考下
    2024-06-06
  • Java入门交换数组中两个元素的位置

    Java入门交换数组中两个元素的位置

    在Java中,交换数组中的两个元素是基本的数组操作,下面我们将详细介绍如何实现这一操作,以及在实际应用中这种技术的重要性,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-09-09
  • SpringBoot实体多层嵌套判空字段的方式

    SpringBoot实体多层嵌套判空字段的方式

    这篇文章主要介绍了SpringBoot实体多层嵌套如何判空字段,最近在公司了接了个需求:需要开发一个中间系统,进行三方联调,文中通过代码示例介绍的非常详细,需要的朋友可以参考下
    2024-09-09
  • 深入了解Spring的Bean生命周期

    深入了解Spring的Bean生命周期

    这篇文章主要为大家介绍了Spring的Bean生命周期,文中的示例代码讲解详细,对我们学习或工作有一定的参考价值,感兴趣的可以学习一下
    2022-01-01
  • SpringBoot一个请求的处理全过程分享

    SpringBoot一个请求的处理全过程分享

    本文详细介绍了SpringBoot请求处理的全过程,包括过滤器链、拦截器链、路径映射、参数绑定、Controller方法执行、返回值处理、异常解析和视图解析渲染等步骤,同时,文中还列举了请求处理过程中常见的问题及解决方案
    2024-12-12
  • eclipse怎么引入spring boot项目插件的方法

    eclipse怎么引入spring boot项目插件的方法

    这篇文章主要介绍了eclipse怎么引入spring boot项目插件的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-06-06
  • Java线程池7个参数的详细含义

    Java线程池7个参数的详细含义

    java多线程开发时,常常用到线程池技术,这篇文章是对创建java线程池时的七个参数的详细解释,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-03-03
  • Java 栈与队列超详细分析讲解

    Java 栈与队列超详细分析讲解

    这篇文章主要介绍了Java数据结构中的栈与队列,在Java的时候,对于栈与队列的应用需要熟练的掌握,这样才能够确保Java学习时候能够有扎实的基础能力。本文小编就来详细说说Java中的栈与队列,需要的朋友可以参考一下
    2022-04-04

最新评论