关于java RMI分布式程序开发实例

关于java RMI分布式程序开发实例

 

作者: javaboy2012
Email:yanek@163.com
qq:    1046011462

 

一. 服务器端

    接口定义:注意必须继承Remote接口

package com.yanek.rmi.server;

import java.rmi.Remote;
import java.rmi.RemoteException;
import java.util.List;

public interface ChannelManager extends Remote {
 
 public List<Channel> getChannels() throws RemoteException;

}

接口传输的对象:注意必须实现Serializable接口。

package com.yanek.rmi.server;

import java.io.Serializable;

public class Channel implements Serializable{
 
 
 private int id;
 private String name;
 public int getId() {
  return id;
 }
 public void setId(int id) {
  this.id = id;
 }
 public String getName() {
  return name;
 }
 public void setName(String name) {
  this.name = name;
 }
 public Channel(int id, String name) {
  super();
  this.id = id;
  this.name = name;
 }
 

}

 

    接口实现: 注意继承UnicastRemoteObject类

package com.yanek.rmi.server;

import java.rmi.RemoteException;
import java.rmi.server.UnicastRemoteObject;
import java.util.ArrayList;
import java.util.Date;
import java.util.List;

public class ChannelManagerImpl extends UnicastRemoteObject implements ChannelManager {

 /**
  *
  */
 private static final long serialVersionUID = 1L;

 /**
  * @param args
  */
 public static void main(String[] args) {
  
  
  
  try {
   ChannelManager cm=ChannelManagerImpl.getInstance();
   
   ChannelManager cm1=ChannelManagerImpl.getInstance();
   ChannelManager cm2=ChannelManagerImpl.getInstance();
   System.out.println(cm1);
   System.out.println(cm2);
   System.out.println(cm);
   
   List<Channel> channels=cm.getChannels();
   
   for(int i=0;i<channels.size();i++)
   {
    Channel c=channels.get(i);
    
    System.out.println(c.getId()+"-"+c.getName());
   }
   
  } catch (RemoteException e) {
   e.printStackTrace();
  }

 }
 
 private static final Object lock = new Object();
 private static ChannelManager instance;
 
 public static ChannelManager getInstance() throws RemoteException {
  if (instance == null) {
   synchronized (lock) {
    if (instance == null)
     instance = new ChannelManagerImpl();
   }
  }
  return instance;
 }
 
 private ChannelManagerImpl() throws RemoteException {
 }

 @Override
 public List<Channel> getChannels() throws RemoteException {
  List<Channel> channels=new ArrayList<Channel>();
  channels.add(new Channel(1,"java"));
  channels.add(new Channel(2,"php"));
  channels.add(new Channel(3,"C"));
  channels.add(new Channel(4,"ASP"));
  System.out.println(new Date()+" getChannels method called!");
  return channels;
 }

}

服务启动类:

package com.yanek.rmi.server;

import java.net.MalformedURLException;
import java.rmi.Naming;
import java.rmi.RMISecurityManager;
import java.rmi.RemoteException;
import java.rmi.registry.LocateRegistry;

public class RMIServer {

 /**
  * @param args
  */
 public static void main(String[] args) {

  
  System.out.println("RMI Server starting ...");
  
  
  if (System.getSecurityManager() == null) {
   //System.setSecurityManager(new RMISecurityManager());
  }
  
  
  try {
   LocateRegistry.createRegistry(1099);
   try {
    Naming.rebind("ChannelManager", ChannelManagerImpl.getInstance());
   } catch (MalformedURLException e) {
    e.printStackTrace();
   }
  } catch (RemoteException e) {
   // TODO Auto-generated catch block
   e.printStackTrace();
  }
  
  System.out.println("RMI Server ready...");

 }

}

将如上四个类打包为server.jar

将如上ChannelManager和Channel类打包为server_4client.jar

二. 客户端

package com.yanek.rmi.client;

import java.rmi.Naming;
import java.rmi.RMISecurityManager;
import java.rmi.Remote;
import java.rmi.RemoteException;
import java.util.List;

import com.yanek.rmi.server.Channel;
import com.yanek.rmi.server.ChannelManager;

public class ClientUtil {

 /**
  * @param args
  */
 public static void main(String[] args) {

  ChannelManager cm = (ChannelManager) ClientUtil.renewRMI("ChannelManager");

  List<Channel> channels;
  try {
   channels = cm.getChannels();
   
   for (int i = 0; i < channels.size(); i++) {
    Channel c = channels.get(i);

    System.out.println(c.getId() + "-" + c.getName());
   }
   
  } catch (RemoteException e) {
   // TODO Auto-generated catch block
   e.printStackTrace();
  }

 

 }

 public static Remote renewRMI(String name) {
  try {

   if (System.getSecurityManager() == null) {
    //System.setSecurityManager(new RMISecurityManager());
   }
   return Naming.lookup("rmi://192.168.136.1:1099/" + name);
  } catch (Exception re) {
   throw new IllegalStateException("bind " + name + " failure . ");
  }

 }

}

 

package com.yanek.rmi.client;

import java.rmi.RemoteException;
import java.util.ArrayList;
import java.util.List;

import com.yanek.rmi.server.Channel;
import com.yanek.rmi.server.ChannelManager;

public class ClientTest {

 /**
  * @param args
  */
 public static void main(String[] args) {

  
  ChannelManager cm = (ChannelManager) ClientUtil.renewRMI("ChannelManager");

  List<Channel> channels=new ArrayList<Channel>();
  try {
   channels = cm.getChannels();
   
   for (int i = 0; i < channels.size(); i++) {
    Channel c = channels.get(i);

    System.out.println(c.getId() + "-" + c.getName());
   }
   
  } catch (RemoteException e) {
   // TODO Auto-generated catch block
   e.printStackTrace();
  }

 }

}

将如上两个类打包为client.jar

三. 发布和部署

  服务端发布: 引用server.jar包,执行RMIServer类的Main方法

  客户端调用: 引用server_4client.jar和client.jar

 

 如下为windows下bat方式调用批处理脚本

client.bat

@echo off

set cp=config

for %%i in (lib\*.jar) do call a.bat %%i

set cp=%cp%;

echo %cp%;

java -cp %cp%  com.yanek.rmi.client.ClientTest

pause

server.bat

@echo off

set cp=config

for %%i in (lib\*.jar) do call a.bat %%i

set cp=%cp%;

echo %cp%;

java -cp %cp%  com.yanek.rmi.server.RMIServer

pause

 

辅助文件 a.bat

set cp=%cp%;%1

服务端启动截图

 

 

客户端调用:

 

 

 

 

 代码和部署文件下载地址: http://download.csdn.net/detail/5iasp/5093357 (不需要积分)

时间: 2025-01-01 09:09:25

关于java RMI分布式程序开发实例的相关文章

基于SharpMap扩展程序开发实例

SharpMap是基于.Net平台开发的GIS地图渲染组件.在SharpMap的内部设计了基于OGC 标准的几何模型 构架,设计了IProvider策略模式的多源矢量地图数据适配器接口,地图要素渲染的底层主要通过几何变 换将Geometry转换为.Net支持的几何模型如System.Drawing.Point.System.Drawing.Rectangle. System.Drawing.Drawing2D.GraphicsPath等,然后调用System.Drawing.Graphics类的

使用ADO封装类的数据库程序开发实例[第二版](上)

从上次在VC知识库发表<使用ADO封装类的数据库程序开发实例>一文后,得到许多网友的响应,甚觉欣慰.但由于我对ADO也非完全精通,所以上次写的类很不完美,甚至可能给某些朋友带来麻烦,因此一直想把它写得更完善一点. 现在写的这个类功能应该说比较完善了,基本上封装了ADO组件的大部分方法,并扩展了一些人们常用到的方法,如把文件或图片写到数据库中,从数据库中读出位图字段,字段的值的智能转换等等. 因为实在是时间不够,我几乎没有对command类做任何有效的测试,也没有写相关的文档,而对connect

《电子尺》V1.02程序开发实例

程序功能 有时在制作网页或一些多媒体时,需要插入一些自制的图片和flash动画,在制作之前一定需要先确定图片的高和宽,用这个软件就可以轻松的量出你所需要的高和宽. 总体介绍 程序在开始测量时要锁定整个屏幕,包括任务栏等.原先计划利用钩子(Hook)来截取所有的鼠标消息,实现屏幕的锁定.但是无论使用WH_MOUSE或WH_GETMESSGAE都无法完全截获所有消息.所以我就利用了一个占据整个屏幕的透明窗口来实现.虽然是透明的窗口,但是一旦窗口创建以后,实际屏幕的更新就不会再对窗口中显示的内容进行影

微信小程序开发实例详解_其它综合

"小程序"破解IDE + Demo:https://github.com/gavinkwoe/weapp-ide-crack.git 资源汇总:https://github.com/Aufree/awesome-wechat-weapp 官方简易教程·MINA:http://wxopen.notedown.cn/ Hello小程序 - 非官方:http://www.helloxcx.com 微信应用号开发教程:https://my.oschina.net/wwnick/blog/750

使用ADO封装类的数据库程序开发实例(上)

源代码运行效果图如下: 开发实例(上)-vc数据库编程实例ado"> 一.前言 用过ADO的人都知道, 调用ADO要处理很多"麻烦"的事情,如异常处理等,要写很多try - catch块. 有点不甚其烦.我干脆把常用的函数都封装起来,免去老是要写try - catch块的麻烦.做起来虽然没有什么技术含量,但也比较烦琐,所以只完成了一部分,且由于时间及个人水平有限,没有对封装的东西作全面测试,并必定有很多错误,但想到对某些朋友可能有用.所以先"捐"出来

Java桌面应用程序开发简介

Java对于服务器,个人电脑和移动设备来说是一项伟大的技术.由于需要java的跨平台的特性,因此java在服务器和移动设备方面的应用是非常成功的.但java在个人电脑应用方面的情况和在服务器及移动设备方面的应用有所不同,但是这很快就会有所改变,至少比你想象得要快.在这篇文章中,我会分析一下java在桌面环境中的应用将怎样得到提升,然后具体说一下java GUI(用户图形接口)的三个主要的工具:AWT, Swing, 和SWT..在下文中,我将会开发一个完整的java桌面应用程序. Java与桌面

使用ADO封装类的数据库程序开发实例(下)

五.开始编写ADO应用程序. 使用ADO之前,我们另外还需要添加下面的语句,如此把ADO的库引入到工程中 . #import "c:\program files\common files\system\ado\msado15.dll" no_namespace rename("EOF","adoEOF") 根据机器安装时候的设置不同具体的路径可能不一样. 另外编译的时候会出现如下的警告信息: msado15.tlh(405) : warning

使用ADO封装类的数据库程序开发实例[第二版](下)

CAdoRecordSet class: CAdoRecordSet: CAdoRecordSet::CAdoRecordSet() CAdoRecordSet::CAdoRecordSet(CAdoConnection *pConnection) void CAdoRecordSet::SetAdoConnection(CAdoConnection *pConnection) 创建Connection对象. Params: [pConnection]: 连接对象指针. Open 方法: BOO

富盛Sbo Add-on程序开发框架及开发实例

一.问题的提出 Sbo是一套具有非常不错业务架构.并且很好支持了二次开发的企业http://www.aliyun.com/zixun/aggregation/13617.html">信息管理系统--对不起,我还不称之为Erp,因为如果不进行二次开发,Sbo可以支持的业务面还是太窄太小,业务之间约束关系也太简单.是的,我的观点是,如果没有很好的二次开发,Sbo是无法支撑不断发展变化的中国企业的业务需要的. 那么,进行Sbo二次开发是不是很简单? 应该说,不太复杂!不过,对于初学者或者刚涉足这