0


Nacos、Eureka和Zookeeper有什么区别

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

标签: java

本文转载自: https://blog.csdn.net/IamBird/article/details/130839124
版权归原作者 码视野 所有, 如有侵权,请联系我们删除。

“Nacos、Eureka和Zookeeper有什么区别”的评论:

还没有评论