利用RMI实现在多台服务器之间的资源共享

    RMI(Remote Method Invocation),RMI是分布式对象软件包,它简化了在多台计算机上的JAVA应用之间的通信。JDK1.2以上都支持这个功能。有了RMI就可以实现不同服务器之间的通信。也就是多个JVM(Java Virtual Machine)之间的通信。操作远程服务器的对象就像操作本地对象那么简单。

    在规模稍大的应用中,一般都会有多台AP服务器。但我们的数据服务器,邮件服务器,文件服务器可能只有一台。因此数据服务器,邮件服务器,文件服务器的负荷可能会比较大。

    为了控制有限资源,比如同一时间的送信数不能够超过100封,数据库的访问连接数不能超过100个等等。这个如何实现呢?如果没有RMI的话,是比较难以想象的。因为怎么样才能够取到另外一个JVM的对象,或者怎么样才能把自己的对象交给另外一个JVM。

    比如上面的送信数的控制,我们所有的AP服务器上发生的送信动作都通过RMI把任务交给一台发送中心(固定为某台服务器)。发送中心通过线程POOL来实现同时送信数的控制。数据库的连接控制也一样,在AP服务器想要访问数据库的话,通过RMI从连接控制中心(固定为某台服务器)取得连接,然后访问数据库。

 

   RMI主要用到的类

      java.rmi.Remote 所有可以被远程调用的对象都必须实现该接口

      java.rmi.server.UnicastRemoteObject 所有可以被远程调用的对象都必须扩展该类

 

   一般开发的时候,创建RMI的步骤大概有以下几步。

  1、定义一个远程接口的接口,该接口中的每一个方法必须声明它将产生一个RemoteException异常。

  2、定义一个实现该接口的类。

  3、使用RMIC程序生成远程实现所需的辅助类。

  4、创建一个服务器,用于发布2中写好的类。

  5. 创建一个客户程序进行RMI调用。

  6、启动rmiRegistry并运行远程服务器和客户程序。

你可能感兴趣的:(java,jvm,jdk,数据库,服务器,邮件服务器)