Nacos、Eureka和Zookeeper有什么区别

2023-11-14

    Nacos、Eureka和Zookeeper都是服务注册中心,它们的主要功能是管理分布式系统中各个微服务实例的注册与发现。它们之间的主要区别在于:

1. 语言支持:Nacos是用Java语言开发的,Eureka是用Java语言开发的,Zookeeper则是用C语言开发的。

2. 功能特性:Nacos支持服务发现、配置管理、流量管理、DNS、动态DNS等多种特性,而Eureka只支持服务注册和发现功能,Zookeeper可以实现可靠的数据存储和协调。

3. 应用场景:Nacos适用于Kubernetes、Service Mesh、Spring Cloud等云原生场景,Eureka适用于Spring Cloud生态系统,Zookeeper适用于Hadoop分布式集群等大规模分布式系统场景。

4. CAP理论:Nacos支持使用Raft和Paxos来保证分布式一致性,可以实现CP(Consistency and Partition tolerance),也可以实现AP(Availability and Partition tolerance)。Eureka支持实现AP模型,而Zookeeper是CP模型。

5. 运行模式:Nacos和Eureka都支持自主部署和集群模式,而Zookeeper需要独立部署和启动集群。

总的来看,Nacos是一个全栈解决方案,支持服务发现、配置管理和流量管理等多个功能。Eureka专注于服务注册和发现,适用于Spring Cloud场景。Zookeeper则是一个通用的分布式数据存储和协调系统,适用于大规模分布式系统的场景。

public class RegistryService {
    public static void main(String[] args) {
        // Nacos注册中心
        NamingService naming = NacosFactory.createNamingService("localhost:8848");
        try {
            naming.registerInstance("service", "127.0.0.1", 8080);
            List<Instance> instances = naming.getAllInstances("service");
            for (Instance instance : instances) {
                System.out.println(instance.getIp() + ": " + instance.getPort());
            }
        } catch (NacosException e) {
            e.printStackTrace();
        }

        // Eureka注册中心
        EurekaClientConfig eurekaConfig = new DefaultEurekaClientConfig();
        eurekaConfig.setRegistryUrl("http://localhost:8761/eureka/");
        PeerAwareInstanceRegistry registry = new PeerAwareInstanceRegistryImpl(
                new InMemoryInstanceRepository(),
                eurekaConfig,
                new Provider<HealthCheckHandler>() {
                    @Override
                    public HealthCheckHandler get() {
                        return null;
                    }
                });
        Applications applications = new Applications();
        Application application = new Application("service");
        InstanceInfo serviceInstance = InstanceInfo.Builder.newBuilder()
                .setAppName("service")
                .setIPAddr("127.0.0.1")
                .setPort(8080)
                .build();
        application.addInstance(serviceInstance);
        applications.addApplication(application);
        registry.register(serviceInstance, true);

        // Zookeeper注册中心
        ZooKeeper zk = new ZooKeeper("localhost:2181", 3000, null);
        zk.create("/services/service", "".getBytes(), ZooDefs.Ids.OPEN_ACL_UNSAFE, CreateMode.EPHEMERAL);
        List<String> instances = zk.getChildren("/services/service", false);
        for (String instance : instances) {
            byte[] data = zk.getData("/services/service/" + instance, false, null);
            System.out.println(new String(data));
        }
    }
}

603dfb918946416ab13b6fcbe802a91d.jpg

 

 

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

Nacos、Eureka和Zookeeper有什么区别 的相关文章

  • 日期语句之间的 JPQL SELECT [关闭]

    Closed 这个问题是无法重现或由拼写错误引起 help closed questions 目前不接受答案 我想将此 SQL 语句转换为等效的 JPQL SELECT FROM events WHERE events date BETWE
  • 如何通过 javaconfig 使用 SchedulerFactoryBean.schedulerContextAsMap

    我使用 Spring 4 0 并将项目从 xml 移至 java config 除了访问 Service scheduleService 带注释的类来自QuartzJobBean executeInternal 我必须让它工作的 xml 位
  • 如何循环遍历所有组合,例如48 选择 5 [重复]

    这个问题在这里已经有答案了 可能的重复 如何在java中从大小为n的集合中迭代生成k个元素子集 https stackoverflow com questions 4504974 how to iteratively generate k
  • 使用 LinkedList 实现下一个和上一个按钮

    这可能是一个愚蠢的问题 但我很难思考清楚 我编写了一个使用 LinkedList 来移动加载的 MIDI 乐器的方法 我想制作一个下一个和一个上一个按钮 以便每次单击该按钮时都会遍历 LinkedList 如果我硬编码itr next or
  • 如何获取之前的URL?

    我需要调用我的网络应用程序的 URL 例如 如果有一个从 stackoverflow com 到我的网站 foo com 的链接 我需要 Web 应用程序 托管 bean 中的 stackoverflow 链接 感谢所有帮助 谢谢 并不总是
  • 如何更改javaFX中按钮的图像?

    我正在使用javaFX 我制作了一个按钮并为此设置了图像 代码是 Image playI new Image file c Users Farhad Desktop icons play2 jpg ImageView iv1 new Ima
  • 在接口中使用默认方法是否违反接口隔离原则?

    我正在学习 SOLID 原则 ISP 指出 客户端不应被迫依赖于他们所使用的接口 不使用 在接口中使用默认方法是否违反了这个原则 我见过类似的问题 但我在这里发布了一个示例 以便更清楚地了解我的示例是否违反了 ISP 假设我有这个例子 pu
  • 帮助将图像从 Servlet 获取到 JSP 页面 [重复]

    这个问题在这里已经有答案了 我目前必须生成一个显示字符串文本的图像 我需要在 Servlet 上制作此图像 然后以某种方式将图像传递到 JSP 页面 以便它可以显示它 我试图避免保存图像 而是以某种方式将图像流式传输到 JSP 自从我开始寻
  • Hibernate 的 PersistentSet 不使用 hashCode/equals 的自定义实现

    所以我有一本实体书 public class Book private String id private String name private String description private Image coverImage pr
  • 内部类的构造函数引用在运行时失败并出现VerifyError

    我正在使用 lambda 为内部类构造函数创建供应商ctx gt new SpectatorSwitcher ctx IntelliJ建议我将其更改为SpectatorSwitcher new反而 SpectatorSwitcher 是我正
  • 如何对不同的参数类型使用相同的java方法?

    我的问题 我有 2 个已定义的记录 创建对象请求 更新对象请求 必须通过实用方法进行验证 由于这两个对象具有相同的字段 因此可以对这两种类型应用相同的验证方法 现在我只是使用两种方法进行重载 但它很冗长 public record Crea
  • java for windows 中的文件图标叠加

    我正在尝试像 Tortoise SVN 或 Dropbox 一样在文件和文件夹上实现图标叠加 我在网上查了很多资料 但没有找到Java的解决方案 Can anyone help me with this 很抱歉确认您的担忧 但这无法在 Ja
  • 使用 AsyncTask 传递值

    我一直在努力解决这个问题 但我已经到了不知道该怎么办的地步 我想做的是使用一个类下载文件并将其解析为字符串 然后将该字符串发送到另一个类来解析 JSON 内容 所有部件都可以单独工作 并且我已经单独测试了所有部件 我只是不知道如何将值发送到
  • java.io.Serialized 在 C/C++ 中的等价物是什么?

    C C 的等价物是什么java io Serialized https docs oracle com javase 7 docs api java io Serializable html 有对序列化库的引用 用 C 序列化数据结构 ht
  • 最新的 Hibernate 和 Derby:无法建立 JDBC 连接

    我正在尝试创建一个使用 Hibernate 连接到 Derby 数据库的准系统项目 我正在使用 Hibernate 和 Derby 的最新版本 但我得到的是通用的Unable to make JDBC Connection error 这是
  • Eclipse 启动时崩溃;退出代码=13

    I am trying to work with Eclipse Helios on my x64 machine Im pretty sure now that this problem could occur with any ecli
  • 我如何在java中读取二进制数据文件

    因此 我正在为学校做一个项目 我需要读取二进制数据文件并使用它来生成角色的统计数据 例如力量和智慧 它的设置是让前 8 位组成一个统计数据 我想知道执行此操作的实际语法是什么 是不是就像读文本文件一样 这样 File file new Fi
  • 干净构建 Java 命令行

    我正在使用命令行编译使用 eclipse 编写的项目 如下所示 javac file java 然后运行 java file args here 我将如何运行干净的构建或编译 每当我重新编译时 除非删除所有内容 否则更改不会受到影响 cla
  • 如何使用mockito模拟构建器

    我有一个建造者 class Builder private String name private String address public Builder setName String name this name name retur
  • 在java中为组合框分配键

    我想添加一个JComboBox在 Swing 中这很简单 但我想为组合中的每个项目分配值 我有以下代码 JComboBox jc1 new JComboBox jc1 addItem a jc1 addItem b jc1 addItem

随机推荐