`

Java 分布式处理技术

 
阅读更多

1.1 RMI 的基本概念

1.1.1 什么是RMI

RMI(Remote Method Invocation) 远程方法调用是一种计算机之间对象互相调用对方函数,启动对方进程的一种机制,使用这种机制,某一台计算机上的对象在调用另外一台计算机上的方法时,使用的程序语法规则和在本地机上对象间的方法调用的语法规则一样。

1.1.2 RMI 的用途

1、 分布式体系结构

我们为什么要使用分布式计算呢?

Ø         当我们想与多个用户或客户机共享一个中央资源(如一个数据库)时,就会使用分布式计算。

Ø         分布式计算用来利用多个系统的组合计算能力,以便比在单个系统上更有效或更快地解决问题。

可以用多种方法配置多个计算机系统以共享处理,包括共享内存、共享磁盘或只是共享一条公共通信通道。最新的技术允许物理上相隔很远的系统能够在处理计算问题时协同工作。

关于利用计算能力这一主题,因特网及伴随的通信协议 TCP/IP 的出现已使无数的计算机系统史无前例地连接起来。对一些应用程序来说,能够利用如此多的计算功能来解决问题是令人满意的。甚至更吸引人的是,大多数计算机系统都有充足的空闲时间,可以帮助解决其它问题。将来,网格计算会利用分布式计算能力进行出售,这与电力行业出售电能非常相似。

2、 Java 分布式对象编程技术

RMI 是 Enterprise JavaBeans 的支柱,是建立分布式 Java 应用程序的方便途径。只要按照 RMI 规则设计程序,可以不必再过问在 RMI 之下的网络细节了,如: TCP 和 Socket 等等。任意两台计算机之间的通讯完全由 RMI 负责。调用远程计算机上的对象就像本地对象一样方便。

1.1.3 RMI 应用程序分类

依据 RMI 应用程序各部分职责,可对应用程序进行如下分类:

Ø         服务器程序:服务器程序将创建多个远程对象,并使每个对象能够被引用。等待客户端调用创建好的远程对象上的方法。

Ø         客户端程序:从服务端程序中得到一个或多个远程对象的引用。客户端能用此引用调用远程对象上的方法。

Ø         对等计算程序:双方地位相等,互为对方的服务器和客户端。

1.2 创建 RMI 应用程序步骤

1、 定义远程接口

在 Java 中,远程对象是实现远程接口的类的实例 , 远程接口声明每个要远程调用的方法。在需要创建一个远程对象的时候,我们通过传递一个接口来隐藏基层的实施细节,客户通过接口句柄发送消息即可。远程接口具有如下特点:

Ø         远程接口必须为 public 属性。如果不这样,除非客户端与远程接口在同一个包内,否则当试图装入实现该远程接口的远程对象时,调用会得到错误结果。

Ø         远程接口必须扩展接口 java.rmi.Remote 。

Ø         除与应用程序本身特定的例外之外,远程接口中的每个方法都必须在自己的 throws 从句中 声明 java.rmi.RemoteException 。(或 RemoteException 的父类)。

代码范例 1

package com.itjob;

import java.rmi.*;

 

public interface RmiSample extends Remote{

       public int sum(int a,int b) throws RemoteException;

      

}

 

2、 实现远程接口

远程对象实现类必须扩展远程对象 java.rmi.UnicastRemoteObject 类,并实现所定义的远程接口。远程对象的实现类中包含实现每个远程接口所指定的远程方法的代码。这个类也可以含有附加的方法,但客户只能使用远程接口中的方法。因为客户是指向接口的一个句柄,而不是它的哪个类。必须为远程对象定义构造函数,即使只准备定义一个默认构造函数,用它调用基础类构造函数。因为基础类构造函数可能会抛出 java.rmi.RemoteException ,所以即使别无它用必须抛出 java.rmi.RemoteException 例外。

代码范例 2

package com.itjob.rmi;

import java.rmi.*;

import java.rmi.server.*;

import com.itjob.RmiSample ;

public class RmiSampleImpl extends UnicastRemoteObject implements RmiSample{

    // 覆盖默认构造函数并抛出 RemoteException

       public RmiSampleImpl() throws RemoteException{

              super();

       }

    // 所有远程实现方法必须抛出 RemoteException

       public int sum(int a,int b) throws RemoteException{

              return a+b;

       }

}

 

3、 编写服务器类

包含 main 方法的类可以是实现类自身,也可以完全是另一个类。下面通过 RmiSampleServer 来创建一个远程对象的实例,并通过 java.rmi.registry.LocateRegistry 类的 createRegistry 方法从指定端口号启动注册服务程序,也可以通过执行 rmiregistry 命令启动注册服务程序,注册服务程序的缺省运行端口为 1099 。

代码范例 3

package com.itjob.rmi;

 

import java.rmi.*;

import java.rmi.registry.*;

 

public class RmiSampleServer{

       public static void main(String[] args){

               

              try{

                     LocateRegistry.createRegistry(8808);

                     RmiSampleImpl server=new RmiSampleImpl();

                     Naming.rebind("//localhost:8808/SAMPLE-SERVER",server);

                     System.out.println (" 远程对象注册成功, RMI 服务已经启动,等待客户端调用 ....");

              }catch(java.net.MalformedURLException me){

                     System.out.println ("Malformed URL:"+me.toString());

              }catch(RemoteException re){

                     System.out.println ("Remote exception:"+re.toString());

              }catch(AlreadyBoundException abe){

            System.out.println (" (AlreadyBound exception:"+ abe .toString());

}

       }

}

 

Ø         代码范例 3 中将将远程对象名字绑定到对远程对象的引用上:

LocateRegistry.createRegistry(8808); 指定本 RMI 服务程序不使用默认端口 1099, 而是使用自己指定的端口 8808 。

Naming.rebind("//localhost:8808/SAMPLE-SERVER" , Server); 将远程对象在服务器上注册并指定了将查找远程对象引用的 URL , URL 格式为 //host:port/name 。其中 host 是注册表所在的主机(远程或本地), port 是注册表接受调用的端口号, name 是未经注册表解释的简单字符串。 host 和 port 两者都是可选项。如果省略了 host ,则主机默认为本地主机。如果省略了 port ,则端口默认为 1099 ,该端口是 RMI 的注册表 rmiregistry 使用的“著名”端口。

代码范例 3 的运行结果如图所示:

 

14.1 代码范例 3 运行结果

 

4、 编写使用远程服务的客户机类

客户机类的主要功能有两个,一是通过 Naming.lookup 方法来构造注册服务程序 stub 程序实例,二是调用服务器远程对象上的远程方法。

代码范例 4

package com.itjob.rmi;

import java.rmi.*;

  import java.rmi.server.*;

  public class RmiSampleClient {

     public static void main(String[] args)

     {

         try {

             String url = "//localhost:8808/SAMPLE-SERVER";

            RmiSample RmiObject = (RmiSample)Naming.lookup(url);

            System.out.println(" 1 + 2 = " + RmiObject.sum(1,2) );

         } catch (RemoteException exc) {

             System.out.println("Error in lookup: " + exc.toString());

         } catch (java.net.MalformedURLException exc) {

             System.out.println("Malformed URL: " + exc.toString());

         } catch (java.rmi.NotBoundException exc) {

             System.out.println("NotBound: " + exc.toString());

         }

      }

  }

 

5、 为远程对象实现创建根和干

客户端是通过 Naming.lookup 方法来构造注册服务程序 stub 程序实例,通过该实例的引用来发起对远程对象方法调用的,所以在运行运行客户端应用前必须为远程对象实现创建根 (stub) 和干 (Skeleton) 。要创建存根程序和骨架文件,应以包含远程对象实现的已编译类包全名运行 rmic 编译器。存根( Stub )是远程对象在客户端的代理,它将 RMI 调用传递给服务器端的骨架( Skeleton ),后者负责将该调用传递给实际的远程方法。在命令行模块下运行 RMIC 调用:

 

14. 2 RMIC 命令

调用 RMIC 命令运行结果如图所示:

 

14.3 RMIC 运行结果

Ø         我们可以看系统帮我们生成了存根 (stub)RmiSampleImpl_Stub.class 但系统并没有帮我们生成骨架( Skeleton ) RmiSampleImpl_ Skeleton .class 。这与 JDK 的版本有关:

采用 JDK1.4 版本运行 rmic com.itjob.rmi. RmiSampleImpl 命令系统将会生成存根 (stub)RmiSampleImpl_Stub.class 和骨架( Skeleton ) RmiSampleImpl_ Skeleton .class 两个类文件;

采用 JDK1.5 版本运行 rmic com.itjob.rmi. RmiSampleImpl 命令系统将只会生成存根 (stub)RmiSampleImpl_Stub.class ,骨架( Skeleton ) RmiSampleImpl_ Skeleton .class 的功能将通反射技术由系统在运行时自动实现;

6、 运行程序

依次做完上述步骤后,我们现在来运行一下我们的 RMI 应用。先运行服务端程序,运行结果如图 14.1 所示。

接下来我们运行客户端程序(代码范例 4 ),运行结果如图所示:

 

图 14.4 客户端程序运行结果

看到上面结果说明我们客户端程序进行 RMI 远程调用已经成功了。

1.3 RMI 接口和类简介

负责指定 rmi 系统远程对象行为的接口和类在 java.rmi 包中定义的,接下来我们了解一下几个核心接口和类:

1、 Java.rmi.Remote 接口

在 rmi 中,远程接口声明了可从远程 java 虚拟机中调用的方法集,远程接口必须满足下列条件:

Ø         远程接口必须至少直接或间接的扩展 java.rmi.Remote 接口。

Ø         远程接口中的方法申明必须满足:远程方法申明在其 throws 子句中除了要包含与应用程序有关的异常之外,还必须包括 RemoteException 异常 ( 或她的父类 ) ;在远程方法申明中,作为参数或返回值申明的远程对象必须申明为远程接口,而非该接口的实现类。

2、 Java.rmi.RemoteException

RemoteException 类是在远程方法调用期间由 RMI 运行所抛出的异常,在使用了 rmi 系统的应用程序中,远程接口中申明的远程方法在其 throws 子句中必须指定 RemoteException 或者其超类。

Ø         当远程方法调用由于某种原因失败时,将抛出 RemoteException 异常。

Ø         RemoteException 类是一个已检验的异常,而不是 RuntimeException 。

3、 Java.rmi.server.RemoteObject

Ø         RMI 服务器函数由 RemoteObject 类及其子类 RemoteServer,UnicastRemoteObject 和 Activatabble 提供。

Ø         RemoteObject 为远程对象敏感的 Object 方法 ,hashCode,equals 和 toString 方法提供实现。

Ø         创建远程对象并将其导出,所需的方法由类 UnicastRemoteObject 和 Activatable 提供,子类可以识别远程方法。

Ø         UnicastRemoteObject 定义了单个调用的远程对象,其引用只有在服务器进程运行时才有效。

Ø         类 Activatable 是抽象类,它定义的 activatable 远程对象在其远程方法被调用时开始执行,并在必要时自己关闭。

4、 Java.rmi.registry.LocateRegistry

LocateRegistry 类用于获得对特定主机的引导远程对象注册服务程序的引用 ( 创建 stub), 或者创建能在特定端口接受调用的远程对象注册服务程序,注册服务程序实现将远程对象名与远程对象引用关联的简单命名语法,服务器重新启动不会记住这些名字和远程对象之间的绑定。

LocateRegistry 类中的方法:

public static Registry getRegistry() throws RemoteException

Public static Registry getRegistry(int port ) throws RemoteException

Public static Registry getRegistry(String host ) throws RemoteException

Public static Registry getRegistry(String host , int port) throws RemoteException

Public static Registry getRegistry(String host, int port ,RMIClientSocketFactory csf ) throws RemoteException

Public static Registry createRegistry(int port )throws RemoteException

Public static Registry createRegistry(int port, RMIClientSocketFactory csf, RMIServerSocketFactory ssf) throws RemoteException

5、 Java.rmi.Naming

Naming 类提供了存储和获得远程对象注册服务程序中的远程对象进行引用的方法

Ø         Naming 类中的方法以 url 的形式作为其中的一个参数, //host:port/name

Ø         当远程对象使用 rmi 注册服务程序在本地主机上进行过注册后,远程主机上的调用程序就可以按名称查询远程对象,获得其引用,然后在对象上调用远程方法。

Public static Remote lookup(String name) throws NotBoundException, MalformedURException, RemoteException

Public static void bind(String name, Remote obj) throws AlreadyBoundException, MalforedURException, RemoteException

Public static void unbind (String name) throws RemoteException, NotBoundException,MalformedURLException

Public static void rebind(String name, Remote obj) throws RemoteException, MalformedURLException

6、 Java.rmi.server.UnicastRemoteObject

类 UnicastRemoteObject 创建并导出远程对象,该类实现的远程服务具有以下特点:

Ø         将这种对象的引用至多仅在创建该远程对象的进程生命周期内有效。

Ø         通过 TCP 传输与远程对象通信调用,参数和结果使用流协议在客户端和服务器之间进行通信。

7、 Stub 和 skeleton

在远程对象的通信过程中, rmi 使用标准机制: stub 和 skeleton

 

图 14.5 Stub 和 Skeleton

Ø         Stub 的功能

初始化与包含远程对象的远程机器的连接。

对远程机器参数进行编组(写入并传输)。

等待方法调用结果。

读取返回值或返回的异常。

将值返回给调用程序。

Ø         Skeleton 的功能

在远程机器中,每个远程对象都可以有相应的 skeleton , skeleton 负责将调用分配给实际的远程对象实现,他的主要功能如下:

读取远程方法的参数。

调用实际远程对象实现上的方法。

将结果(返回值或异常)编组(写入并传输)给调用程序。

1.4 JNDI 基本概念

JNDI 诞生的理由似乎很简单。随着分布式应用的发展,远程访问对象访问成为常用的方法。虽然说通过 Socket 等编程手段仍然可实现远程通信,但按照模式的理论来说,仍是有其局限性的。 RMI 技术, RMI-IIOP 技术的产生,使远程对象的查找成为了技术焦点。 JNDI 技术就应运而生。 JNDI 技术产生后,就可方便的查找远程或是本地对象。

1、 JNDI 是什么 ?

JNDI(The Java Naming and Directory Interface , Java 命名和目录接口 ) 是一组在 Java 应用中访问命名和目录服务的 API 。为开发人员提供了查找和访问各种命名和目录服务的通用、统一的方式。借助于 JNDI 提供的接口,能够通过名字定位用户、机器、网络、对象服务等。

Ø         命名服务:就像 DNS 一样,通过命名服务器提供服务,大部分的 J2EE 服务器都含有命名服务器。

Ø         目录服务:一种简化的 RDBMS 系统,通过目录具有的属性保存一些简单的信息。目录服务通过目录服务器实现,比如微软 ACTIVE DIRECTORY 等。

2、 JNDI 的好处 :

Ø         包含大量命名和目录服务,可以使用相同 API 调用访问任何命名或目录服务。

Ø         可以同时连接多个命名和目录服务。

Ø         允许把名称同 JAVA 对象或资源关联起来,不必知道对象或资源的物理 ID 。

Ø         使用通用接口访问不同种类的目录服务

Ø         使得开发人员能够集中使用和实现一种类型的命名或目录服务客户 API 上。

1.5 JNDI 应用程序结构

JNDI 的结构由一个 API 和一个 SPI 组成, Java 应用程序实用 JNDI API 访问各种各样的命名和目录服务。

 

图 14.6 JNDI 应用程序结构

1、 JNDI 上下文

前面提到命名服务是将名称与对象相关联。这种关联被称为绑定。一组这样的绑定被称为上下文, Jndi 上下文可以用来查找,捆绑 / 解除捆绑,创建或者破坏绑定名称操作在 JNDI 中,上下文是使用 javax.naming.Context 接口来表示的,而这个接口也正是与命名服务进行交互的主要接口。

Context 接口中的每个命名方法都有两种重载的形式:

lookup(String name): 接受一个字符串名称参数,查找绑定远程对象。

lookup(javax.naming.Name): 接受一个结构化的名称,查找绑定远程对象。

2、 初始化上下文

InitialContext 是一个实现了 Context 接口的类。使用这个类作为您到命名服务的入口点 。创建一个 InitialContext 对象构造器需要采用一组属性,形式为 java.util.Hashtable 或其子类之一,比如:

代码范例 5

Properties props = new Properties();

props.setProperty("java.naming.factory.initial", "org.jnp.interfaces.NamingContextFactory");

props.setProperty("java.naming.provider.url", "localhost:1099");

InitialContext   = new InitialContext(props);

要通过 JNDI 进行资源访问,我们必须设置初始化上下文的参数,主要是设置 JNDI 驱动的类名 (java.naming.factory.initial) 和提供命名服务的 URL(java.naming.provider.url) 。因为 Jndi 的实现产品有很多。所以 java.naming.factory.initial 的值因提供 JNDI 服务器的不同而不同, java.naming.provider.url 的值包括提供命名服务的主机地址和端口号。

下表列出了用于所支持的服务提供程序的工厂类。

表 : Context.INITIAL_CONTEXT_FACTORY 的值

名称

服务提供程序工厂

文件系统

com.sun.jndi.fscontext.RefFSContextFactory

LDAP

com.sun.jndi.ldap.LdapCtxFactory

RMI

com.sun.jndi.rmi.registry. RegistryContextFactory

CORBA

com.sun.jndi.cosnaming.CNCtxFactory

DNS

com.sun.jndi.dns.DnsContextFactory

 

1.6 RMI 与 JNDI 集成

通过上面对 JNDI 的了解我们可以利用 JNDI 来管理 RMI 远程对象的注册服务,我们将代码范例 3 进行如下改写:

代码范例 6

package com.itjob.rmi;

 

import java.rmi.*;

import java.rmi.registry.*;

import javax.naming.*;

 

public class RmiSampleServerJndi{

       public static void main(String[] args) throws Exception{

             

              LocateRegistry.createRegistry(8808);

              RmiSampleImpl server=new RmiSampleImpl();         System.setProperty(Context.INITIAL_CONTEXT_FACTORY,"com.sun.jndi.rmi.registry.RegistryContextFactory");

              System.setProperty(Context.PROVIDER_URL,"rmi://localhost:8808");

              InitialContext ctx=new InitialContext();

              ctx.bind("java:comp/env/SampleDemo",server);

              ctx.close();

      

       }

}

启动服务端程序如图所示:

 

图 14.7 JNDI 服务程序启动

表示服务端程序已经将远程对象在 JNDI 是进行了注册,等待客户端进行调用。

接下来我们改写客户端程序采用 JNDI 方式来调用远程对象

代码范例 7

package com.itjob.rmi;

import java.rmi.*;

import java.rmi.server.*;

import javax.naming.*;

  public class RmiSampleClientJndi {

     public static void main(String[] args) throws Exception

     {         

            System.setProperty(Context.INITIAL_CONTEXT_FACTORY,"com.sun.jndi.rmi.registry.RegistryContextFactory");

              System.setProperty(Context.PROVIDER_URL,"rmi://localhost:8808");

              InitialContext ctx=new InitialContext();

 

         String url = "java:comp/env/SampleDemo";

        RmiSample RmiObject = (RmiSample)ctx.lookup(url);

        System.out.println(" 1 + 2 = " + RmiObject.sum(1,2) );

       

      }

   }

运行客户端程序如图所示:

 

图 14.8 客户端 JNDI 程序运行结果

表示客户端已经通过 JNDI 调用服务端远程对象成功。

1.7 学习总结

Ø         RMI 运行在一个 java 虚拟机上的对象调用运行在另一个 java 虚拟机上的对象的方法 . 。 RMI 的用途就是为 java 程序之间的远程通信提供服务。

Ø         RMI 的编程思想

n         对客户端:需要一些特定的代码来引用远程对象,一旦客户端的代码拥有对远程对象的引用,对远程对象上的调用与对本地对象方法的调用除了速度以外没什么区别。

n         对服务端:必须定义类并实例化类的远程对象,服务器的代码必须能够登记对象并向客户端导出它们的方法,这样,这些方法就能够被远程调用了。

n         客户端和服务端的代码都必须定义或能够访问一个接口,该接口中申明了可以远程调用的方法,并且两者还可以设置一个安全管理器。

n         当调用远程对象上的方法时,客户端可以将对象作为参数来传递,并且,远程对象上的方法可以返回对象,这些是通过序列化来实现的。

Ø         JNDI 为开发人员提供了查找和访问各种命名和目录服务的通用、统一的方式。

Ø         JNDI 的结构由一个 API 和一个 SPI 组成, Java 应用程序实用 JNDI API 访问各种各样的命名和目录服务

分享到:
评论

相关推荐

    Java分布式处理技术

    ### Java分布式处理技术详解 #### 一、引言 随着互联网技术的发展,现代网站和应用面临的用户数量呈指数级增长,这导致了单一服务器难以承受大量并发请求的问题。因此,分布式处理技术应运而生,成为了解决高并发...

    Java分布式处理技术RMI,JNDI,

    Java 分布式处理技术 RMI,JNDI Java 分布式处理技术是指在 Java 平台上实现分布式计算和对象之间的交互的技术。其中,RMI(Remote Method Invocation)是 Java 分布式处理技术的核心组件之一。RMI 允许在不同的 ...

    java分布式事务demo

    在实际的"java分布式事务demo"中,可能会包含以上各种技术的实例代码,用于展示如何在Java项目中配置和使用分布式事务,以及如何处理可能出现的问题。通过学习和理解这些示例,开发者可以更好地掌握Java分布式事务的...

    Java分布式实战指南.pdf

    《Java分布式实战指南》这本书详细介绍了如何构建一个完整的Java分布式系统,主要涵盖了技术选型、分布式基础设施环境构建以及项目运营与部署环境等多个方面。在Java微服务领域,它提供了丰富的实践经验和理论指导。...

    java分布式系统架构源码

    Java分布式系统架构是一种将应用程序分布在多个计算节点上运行的技术,以提高系统的可伸缩性、容错性和性能。源码分析对于理解这种架构至关重要,尤其是对于开发者来说,它提供了深入学习和自定义系统的机会。本资源...

    Java分布式架构设计实战视频课程(2022最新版,13章全)

    最后,课程将介绍Docker容器化技术和Kubernetes集群管理,讲解如何部署和管理Java分布式应用。 这套课程以实践为主,结合理论知识,通过具体项目实例,帮助开发者全面掌握Java分布式架构的设计与开发,无论是初学者...

    Java分布式开发与集群技术.pdf

    在阅读了提供的文件内容后,可以提炼出以下Java分布式开发与集群技术相关的知识点: 1. 分布式开发和集群技术的需求:文档提到了Web服务器和移动互联网软件对分布式开发和集群技术的需求,这表明随着互联网服务的...

    一款Java分布式KV存储系统源码.zip

    Java分布式KV(Key-Value)存储系统是现代互联网服务中不可或缺的一部分,其高效、可扩展的特性使其在大数据处理、缓存服务等领域广泛应用。本篇文章将深入剖析一款基于Java实现的分布式KV存储系统的源码,帮助...

    Java 分布式应用程序设计代码

    以上知识点涵盖了Java分布式应用程序设计的核心概念和技术。通过深入理解和熟练运用这些技术,开发者可以构建出强大且可靠的分布式系统。压缩包文件"soft.studa.com Java 分布式应用程序设计"可能包含了实现这些技术...

    Java 分布式应用程序设计

    以上各点涵盖了Java分布式应用程序设计的核心概念和技术。通过深入学习和实践这些知识点,开发者可以构建出强大且可靠的分布式系统。压缩包中的章节可能涵盖这些主题的部分内容,例如第2章可能涉及Java EE基础,第10...

    JAVA分布式程序设计

    Java分布式程序设计是Java开发中的一个重要领域,它涉及到多个计算机节点通过网络进行协作,共同完成一个复杂的任务。在Java中,分布式系统可以实现负载均衡、高可用性、可扩展性和数据共享等功能,广泛应用于云计算...

    Java分布式应用学习笔记

    本笔记将深入探讨Java分布式应用的核心概念、技术和实践。 1. 分布式Java应用基础 分布式Java应用的核心在于组件之间的远程方法调用(Remote Procedure Call, RPC)。Java RMI(Remote Method Invocation)是Java...

    Java分布式ETL框架

    Java分布式ETL(Extract, Transform, Load)框架是用于大数据处理的一种关键技术,它涉及从各种数据源抽取数据,经过转换处理后,加载到目标存储系统的过程。在Java中,实现分布式ETL可以利用多线程、分布式计算以及...

    教案Java分布式技术

    Java分布式技术是现代企业级应用开发中的重要组成部分,它允许应用程序在多个计算机上协同工作,以提高系统的可扩展性、可靠性和性能。本教案聚焦于Java在分布式环境下的核心技术,帮助学习者掌握如何构建和管理...

    Java分布式项目实战视频

    根据提供的文件信息,我们可以深入探讨有关“Java分布式项目实战”的一系列关键知识点。下面将围绕该主题展开详细讨论,包括但不限于分布式系统的定义、Java在分布式系统中的应用、分布式系统设计原则与模式、实战...

    java 分布式存储实例

    Java分布式存储是一个重要的技术领域,尤其在大数据处理和云计算中占据着核心地位。在这个实例中,我们看到一个基于Java实现的分布式存储系统,这可能是基于某个特定的框架或设计模式,比如Hadoop HDFS(Hadoop...

    Java【分布式】学习笔记01分布式Java应用

    从给定的文件信息来看,标题和描述都指向了“Java分布式学习笔记01分布式Java应用”,这显然是关于Java在分布式环境下的应用和技术的学习资料。虽然提供的部分内容由于格式问题难以直接解析,但我们可以根据标题、...

    详解Java分布式IP限流和防止恶意IP攻击方案

    Java分布式IP限流和防止恶意IP攻击方案 本文主要介绍了Java分布式IP限流和防止恶意IP攻击方案,通过示例代码详细介绍了限流和防止恶意IP攻击的实现方式。 一、分布式IP限流 分布式IP限流是分布式系统设计中经常...

Global site tag (gtag.js) - Google Analytics