`
gaojingsong
  • 浏览: 1218108 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
文章分类
社区版块
存档分类
最新评论

ZeroICE入门示例

阅读更多

1、编写*.ice 文件

module myHelloWorld{

    interface HelloWorld{

         void say(string s);

     };

 };



 

2、生成存根 ,命令slice2java ice文件



 

 

3、开发服务端

导入生成的存根文件



 

引入ICE安装目录下面相应的jar包:Ice.jar

 

4、开发服务端代码如下

步骤一:编写Servant类即带有Disp的存根文件也就是说继承_HelloWorldDisp 这个类,这个类是个抽象类定义如下:

public abstract class _HelloWorldDisp extends Ice.ObjectImpl implements HelloWorld{}

servant类是ice所定义的接口,在服务器端的实现类。我们在该类中可以编写服务器端对请求的具体处理。

代码如下:

package myHelloWorld.server;

import Ice.Current;

 import myHelloWorld._HelloWorldDisp;

 

  public class HelloWorld_gaojs extends _HelloWorldDisp{

 

      private static final long serialVersionUID = 1L;

 

     public void say(String s, Current __current) {

         System.out.println("Hello World!"+" the string s is " + s);

      }

  }

步骤二:创建远程的服务器类

package myHelloWorld.server;

 

public class ServerStart {

 

/**

* @param args

*/

public static void main(String[] args) {

int status = 0;

// Communicator实例,是ice run time的主句柄

Ice.Communicator ic = null;

try {

// 调用Ice.Util.Initialize()初始化Ice run time

System.out.println("初始化ice run time...");

ic = Ice.Util.initialize(args); // args参数可传可不传

 

// 创建一个对象适配器,传入适配器名字和在10000端口处接收来的请求

System.out.println("创建对象适配器,监听端口10000...");

Ice.ObjectAdapter adapter = ic.createObjectAdapterWithEndpoints(

"SimplePrinterAdapter", "default -p 10000");

 

// 实例化一个PrinterI对象,为Printer接口创建一个servant

System.out.println("为接口创建servant...");

Ice.Object object = new HelloWorld_gaojs();

 

// 调用适配器的add,告诉它有一个新的servant,传递的参数是刚才的servant,这里的“gaojs”是Servant的名字

System.out.println("对象适配器加入servant...");

adapter.add(object, Ice.Util.stringToIdentity("gaojs"));

 

// 调用适配器的activate()方法,激活适配器。被激活后,服务器开始处理来自客户的请求。

System.out.println("激活适配器,服务器等待处理请求...");

adapter.activate();

 

// 这个方法挂起发出调用的线程,直到服务器实现终止为止。或我们自己发出一个调用关闭。

ic.waitForShutdown();

} catch (Ice.LocalException e) {

e.printStackTrace();

status = 1;

} catch (Exception e) {

e.printStackTrace();

status = 1;

} finally {

if (ic != null) {

ic.destroy();

}

}

System.exit(status);

}

 

}

 

 

5、开发客服端,导入存根文件和jar包,其中存根文件可以比服务端少三个。

import myHelloWorld.HelloWorldPrx;

import myHelloWorld.HelloWorldPrxHelper;

public class Client {

public static void main(String[] args) {

int status = 0;

// Communicator实例

Ice.Communicator ic = null;

try {

// 调用Ice.Util.Initialize()初始化Ice run time

ic = Ice.Util.initialize(args);

 

// 根据servant的名称以及服务器ip、端口获取远程服务代理

Ice.ObjectPrx base = ic.stringToProxy("gaojs:default -p 10000");

 

// 将上面的代理向下转换成一个Printer接口的代理

HelloWorldPrx helloWorld = HelloWorldPrxHelper.checkedCast(base);

 

// 如果转换成功

if (helloWorld == null) {

throw new Error("Invalid proxy");

}

 

// 调用这个代理,将字符串传给它

helloWorld.say("客户端测试");

 

} catch (Ice.LocalException e) {

e.printStackTrace();

status = 1;

} catch (Exception e) {

e.printStackTrace();

status = 1;

} finally {

if (ic != null) {

ic.destroy();

}

}

System.exit(status);

}

}

 

6、运行测试

1)启动服务端



 

2)启动客户端



 

  • 大小: 51.3 KB
  • 大小: 30.9 KB
  • 大小: 33.8 KB
  • 大小: 70.4 KB
  • 大小: 62.4 KB
  • 大小: 62.8 KB
0
0
分享到:
评论
2 楼 andot 2016-11-30  
ZeroC ICE 生成的代码有点丑陋。

Hprose 的 [url=
http://github.com/hprose/hprose-java/wiki/Hello-World]Hello World[/url] 比这个简洁多了,也不需要中间语言生成丑陋的代码。而且服务器和客户端还是松耦合关系。

服务器

package hprose.tcphelloexam;

import hprose.server.HproseTcpServer;

public class TCPHelloServer {
    public static String hello(String name) {
        return "Hello " + name + "!";
    }
    public static void main(String[] args) throws Exception {
        HproseTcpServer server = new HproseTcpServer("tcp://localhost:4321");
        server.add("hello", TCPHelloServer.class);
        server.start();
        System.out.println("START");
        System.in.read();
        server.stop();
        System.out.println("STOP");
    }
}


客户端

package hprose.tcphelloexam;

import hprose.server.HproseTcpServer;

public class TCPHelloServer {
    public static String hello(String name) {
        return "Hello " + name + "!";
    }
    public static void main(String[] args) throws Exception {
        HproseTcpServer server = new HproseTcpServer("tcp://localhost:4321");
        server.add("hello", TCPHelloServer.class);
        server.start();
        System.out.println("START");
        System.in.read();
        server.stop();
        System.out.println("STOP");
    }
}


1 楼 andot 2016-11-30  
ZeroC ICE 生成的代码有点丑陋。

Hprose 的 [url=
https://github.com/hprose/hprose-java/wiki/Hello-World]Hello World[/url] 比这个简洁多了,也不需要中间语言生成丑陋的代码。而且服务器和客户端还是松耦合关系。

服务器


package hprose.tcphelloexam;

import hprose.server.HproseTcpServer;

public class TCPHelloServer {
    public static String hello(String name) {
        return "Hello " + name + "!";
    }
    public static void main(String[] args) throws Exception {
        HproseTcpServer server = new HproseTcpServer("tcp://localhost:4321");
        server.add("hello", TCPHelloServer.class);
        server.start();
        System.out.println("START");
        System.in.read();
        server.stop();
        System.out.println("STOP");
    }
}


客户端


package hprose.tcphelloexam;

import hprose.server.HproseTcpServer;

public class TCPHelloServer {
    public static String hello(String name) {
        return "Hello " + name + "!";
    }
    public static void main(String[] args) throws Exception {
        HproseTcpServer server = new HproseTcpServer("tcp://localhost:4321");
        server.add("hello", TCPHelloServer.class);
        server.start();
        System.out.println("START");
        System.in.read();
        server.stop();
        System.out.println("STOP");
    }
}

相关推荐

    c#整合zeroIce - IceBox

    标题 "c#整合zeroIce - IceBox" 涉及的是使用C#语言与ZeroIce框架结合,构建分布式RPC(Remote Procedure Call)服务器的过程。ZeroIce是一个强大的、跨平台的RPC框架,它允许开发者在不同的应用程序之间透明地进行...

    ice官方例了

    `ice-demos-master`是一个包含多个示例项目的压缩包,这些示例展示了ZeroICE如何在实际开发中运行和操作。通过学习这些实例,我们可以掌握ZeroICE的基本用法,包括服务发布、客户端调用、数据序列化、错误处理等方面...

    c#整合zeroIce

    - `Client.cs`:示例客户端代码,用于测试服务器。 整合ZeroIce和C#的过程涉及到了C#的面向对象编程、网络通信以及服务的实现和部署。掌握这些技能有助于你构建可扩展的、高效的分布式系统。通过实践和调试"unit.1...

    c#整合zeroIce - 传递复杂对象

    ZeroIce是Ice(Internet Communication Engine)框架的一个组件,它为C#开发者提供了一种强大的工具,用于实现跨平台、跨语言的远程过程调用(RPC)。本文将深入探讨如何在C#中整合ZeroIce,以及如何通过该框架传递...

    c#整合zeroIce - 分片下载

    本文将详细讲解如何使用C#编程语言与ZeroIce框架进行整合,实现大文件的分片下载功能。 首先,让我们理解什么是ZeroIce。ZeroIce是一款基于Java开发的分布式框架,它提供了RPC(远程过程调用)服务,使得客户端可以...

    ICE客户端与服务端通信Demo

    平台编译环境:VS2017 ICE版本:3.7.7 ICEbuilder:5.0.9 源码中有两套程序: Server:启动服务器,等待连接 。连接后可双方通信 Client:连接服务器,与服务器通讯。 Slice: 手写几个接口即可。

    Zero Ice中文教程

    **零冰(Zero Ice)教程概述** Zero Ice是一款强大的分布式框架,它允许开发者构建高度可扩展的、跨语言的应用程序。这个"Zero Ice中文教程"是针对中国开发者设计的,旨在帮助他们理解和应用Ice框架,克服语言障碍,...

    zeroc ice3.6 window 安装包

    zeroc ice3.6 window 安装包,因为安装包太大,所以使用百度网盘地址。具体使用demo参见我的博客

    ice_3.7.0_linux版

    Zero ICE,Zeroc ICE,ice,linux,2017年最新版的Zero ICE版本3.7.0,linux版本 Zero ICE,Zeroc ICE,ice,linux,2017年最新版的Zero ICE版本3.7.0,linux版本

    基于ICE方式SIP穿透SymmetricNAT技术研究 pdf

    ### 基于ICE方式SIP穿透SymmetricNAT技术研究 #### 1. 引言 随着互联网技术的发展,多媒体通信服务(如语音、视频会议等)的需求日益增长。然而,这些服务在运行过程中面临的一大挑战是如何有效地穿透网络地址转换...

    ICE通信框架简介

    ZeroICE通信框架技术介绍,开发介绍,例子介绍

Global site tag (gtag.js) - Google Analytics