ice作为一种rpc框架,为主流平台设计,包括Windows和Linux,支持广泛的语言,包括C++,Java,C#(和其他.Net的语言,例如Visual Basic),Python,Ruby,PHP和ActionScript。

安装ice

1.官网下载地址  https://zeroc.com/downloads/ice

2.安装程序,本文安装位置E:\Program Files\ZeroC\Ice-3.6.3

3.配置环境变量

计算机->属性->高级系统设置->环境变量

1)新建立一个ICE_HOME,变量值为安装路径

2)在Path中添加”%ICE_HOME%\bin“

3)检验

配置完成之后打开cmd

出现版本号即为安装并配置完成

java结合ice开发

创建一个maven管理的java项目

在pom.xml中添加依赖

<!-- https://mvnrepository.com/artifact/com.zeroc/ice -->
<dependency>
<groupId>com.zeroc</groupId>
<artifactId>ice</artifactId>
<version>3.6.3</version>
</dependency>

依赖最好对应ice版本

快速查找依赖的方法  直接百度 maven+多需要的依赖名称

如maven ice

在项目文件夹下创建slice文件夹   创建一个文件**.ice

本项目示例Hello.ice

[["java:package:com.test.ice.service"]] // 定义java包名  父结构
module demo //模块包名
{
interface Hello //接口服务名称
{
string sayHello(string s); //具体的方法
};
};

1)使用slice2java编译ice文件生成java代码

在ice所在文件夹打开cmd或者shell,使用以下命令                                   ps:--output-dir    输出文件的目录

slice2java .\Hello.ice --output-dir ..\src\main\java

如果看不到代码,刷新项目即可

2)使用eclipse插件生成代码

eclipse – Help – Marketplace 搜索ice,第一个插件install

安装完成之后重启eclipse

重启之后,选中项目名称右键选中Ice builder      -> add ice builder

则生成了ice的Java代码

编写程序

在生成的代码中可以看到"_ice文件接口名称Disp.java"的文件,例如本次项目为_HelloDisp.java

1)接口实现类HelloImpl       继承_HelloDisp.java

import com.test.ice.service.demo._HelloDisp;

import Ice.Current;

public class HelloImpl extends _HelloDisp{

	/**
*
*/
private static final long serialVersionUID = 1L; @Override
public String sayHello(String s, Current __current) {
System.out.println(s);
return "hello,"+s;
} }

ps:接下来的话可以忽略,最好是与接口不是同一项目,也就是api即接口项目,server项目,client项目,将接口项目以maven的方式打包成jar安装到本地库,具体操作实例https://www.jianshu.com/p/5ce9d1567fee,其他项目添加接口项目依赖

2)服务启动类Server

import com.test.ice.service.demo.impl.HelloImpl;

import Ice.Communicator;
import Ice.ObjectAdapter; public class Server { public static void main(String[] args) {
int status = 0;
Communicator ic = null;
try{
System.out.println("Server starting...");
ic = Ice.Util.initialize(args);
ObjectAdapter adapter = ic.createObjectAdapterWithEndpoints("iceTest", "default -p 10006");
Ice.Object object = new HelloImpl();
adapter.add(object, ic.stringToIdentity("hello"));
adapter.activate();
System.out.println("Server start success.");
ic.waitForShutdown();
}catch(Ice.LocalException e){
e.printStackTrace();
status = 1;
}catch(Exception e){
System.err.println(e.getMessage());
status = 1;
}
if(ic != null){
try{
ic.destroy();
}catch(Exception e){
System.err.println(e.getMessage());
status = 1;
}
}
System.exit(status);
} }

3)客户端client

import com.test.ice.service.demo.HelloPrx;
import com.test.ice.service.demo.HelloPrxHelper; public class Client { public static void main(String[] args) {
int status = 0;
Ice.Communicator ic = null;
try {
ic = Ice.Util.initialize(args);
Ice.ObjectPrx base = ic.stringToProxy("hello:default -p 10006");
HelloPrx hello = HelloPrxHelper.checkedCast(base);
if (hello == null) {
throw new Error("Invalid proxy");
} String s = hello.sayHello("World!");
System.out.println(">>" + s);
} catch (Ice.LocalException e) {
e.printStackTrace();
status = 1;
} catch (Exception e) {
System.err.println(e.getMessage());
status = 1;
}
if (ic != null) {
try {
ic.destroy();
} catch (Exception e) {
System.err.println(e.getMessage());
status = 1;
}
}
System.exit(status);
}
}

4)运行程序

首先运行服务启动类Server,

启动客户端Client

服务端接受到数据

客户端接收到服务端返回的数据

简单的java 结合ice开发到此介绍结束,具体深入后续一起努力哦

python开发ice项目

1.安装ice所需的依赖包

pip install zeroc-ice

2.编写ice文件

module demo
{
interface Hello
{
string sayHello(string s);
};
};

3.编写Server启动程序

#!/usr/bin/env python
# coding=utf-8
import sys, Ice # 动态加载slice文件并编译
Ice.loadSlice("./demo.ice") #ice文件中的模块名称
import demo
## 实现一个服务类
class HelloImpl(demo.Hello):
def sayHello(self, s, current=None):
print s
msg ="Hello,"+s
return msg with Ice.initialize(sys.argv) as communicator:
print "Server starting..."
adapter = communicator.createObjectAdapterWithEndpoints("SimplePrinterAdapter", "default -p 10006")
object = HelloImpl()
adapter.add(object, communicator.stringToIdentity("hello"))
adapter.activate()
print "Server start success."
communicator.waitForShutdown()

4.编写客户端启动程序

#!/usr/bin/env python
# coding=utf-8
import sys, Ice
Ice.loadSlice("./demo.ice")
import demo with Ice.initialize(sys.argv) as communicator:
base = communicator.stringToProxy("hello:default -p 10006")
printer = demo.HelloPrx.checkedCast(base)
if not printer:
raise RuntimeError("Invalid proxy")
print printer.sayHello("World!")

5.运行程序

1)启动server程序

2)启动client程序

3)server接受到客户端发送来的数据并输出

4)client接受到server返回的数据并输出

java与python服务互相调用

java启动server服务,python客户端程序调用服务

1)启动java server服务

2)启动python client服务

3)server服务接收数据并输出

4)client接收返回数据并输出

到此为止,门外看看而已

开发zeroc ice应用入门(java开发ice应用,python开发ice应用,java与python结合开发ice服务)的更多相关文章

  1. 用Python开发Zeroc Ice应用

    Zeroc Ice简介   Zeroc ICE(Internet Communications Engine ,互联网通信引擎)是目前功能比较强大和完善的RPC框架,支持跨平台.跨语言调用.它非常灵活 ...

  2. Spark+ECLIPSE+JAVA+MAVEN windows开发环境搭建及入门实例【附详细代码】

    http://blog.csdn.net/xiefu5hh/article/details/51707529 Spark+ECLIPSE+JAVA+MAVEN windows开发环境搭建及入门实例[附 ...

  3. 01--Java语言概述与开发环境 最适合入门的Java教程

    Java 程序运行机制 编译型语言: 使用专门的编译器,针对特定平台(操作系统)将某种高级语言源代码一次性"翻 译"成可被该平台硬件执行的机器码(包括机器指令和操作数),并包装成该 ...

  4. Cloudera Manager、CDH零基础入门、线路指导 http://www.aboutyun.com/thread-9219-1-1.html (出处: about云开发)

    Cloudera Manager.CDH零基础入门.线路指导http://www.aboutyun.com/thread-9219-1-1.html(出处: about云开发) 问题导读:1.什么是c ...

  5. Android菜鸟的成长笔记(1)——Android开发环境搭建从入门到精通

    原文:Android菜鸟的成长笔记(1)--Android开发环境搭建从入门到精通 今天在博客中看到好多Android的初学者对Android的开发环境的搭建不熟悉而导致不能进行学习,所以我决定自己写 ...

  6. Selenium自动化测试,接口自动化测试开发,性能测试从入门到精通

    Selenium自动化测试,接口自动化测试开发,性能测试从入门到精通Selenium接口性能自动化测试基础部分:分层自动化思想Slenium介绍Selenium1.0/2.0/3.0Slenium R ...

  7. CXF-JAX-RS开发(一)入门案例

    一.简介 资源驱动.基于HTTP协议[按照标准指定URL,就可以访问数据]以XML|JSON格式传输数据. 二.quickstart 1.创建maven project[Packaging:jar] ...

  8. SpringBoot开发二十-Redis入门以及Spring整合Redis

    安装 Redis,熟悉 Redis 的命令以及整合Redis,在Spring 中使用Redis. 代码实现 Redis 内置了 16 个库,索引是 0-15 ,默认选择第 0 个 Redis 的常用命 ...

  9. [刘阳Java]_避开环境配置快速的使用Java的开发工具_第5讲

    我们一般学习Java都应该遵循通过系统的命令工具来编译Java程序,然后对编译好Java程序进行运行,这个是非常好的习惯.但是随着后期学习Java技术的深入我们也得像Java的IDE工具屈服.所以,可 ...

随机推荐

  1. k8s创建资源

        一.创建方式分类: 命令 vs 配置文件 Kubernetes 支持两种方式创建资源:   1.用 kubectl 命令直接创建(适用于少数的pod创建) kubectl run httpd- ...

  2. Java ——Number & Math 类 装箱 拆箱 代码块

    本节重点思维导图 当需要使用数字的时候,我们通常使用内置数据类型,如:byte.int.long.double 等 int a = 5000; float b = 13.65f; byte c = 0 ...

  3. python每日一练:0001题

    第 0001 题:做为 Apple Store App 独立开发者,你要搞限时促销,为你的应用生成激活码(或者优惠券),使用 Python 如何生成 200 个激活码(或者优惠券)? import o ...

  4. 002--PowerDesigner显示注释comment

    PowerDesigner显示注释comment 参考博客:https://blog.csdn.net/chao_1990/article/details/52620206 原始样式 显示操作 调出执 ...

  5. ceph部署问题解决

    注意:1.ceph-deploy实用程序将输出文件到当前目录.执行ceph-deploy时确保你在这个目录下.2.不要使用sudo调用ceph-deploy,要么以root用户身份运行它,因为它不会发 ...

  6. 如何判断一段程序是由C 编译程序还是由C++编译程序编译的

    以下是在论坛中看到的两种解释: (1)如果是要你的代码在编译时发现编译器类型,就判断_cplusplus或_STDC_宏,通常许多编译器还有其他编译标志宏, #ifdef __cplusplus co ...

  7. WPF ControlTemplate

    ControlTemplate:控件模板,顾名思义也就是定制特定的控件供公共调用,有点类似WinForm中对一些通用控件进行重写使用. ControlTemplate:控件模板主要有两个重要属性:Vi ...

  8. <每日一题> Day5:简单递推两题

    原题链接 参考代码: #include <iostream> using namespace std; typedef long long ll; + ; ll dp[maxn]; int ...

  9. 洛谷 P1525 关押罪犯 & [NOIP2010提高组](贪心,种类并查集)

    传送门 解题思路 很显然,为了让最大值最小,肯定就是从大到小枚举,让他们分在两个监狱中,第一个不符合的就是答案. 怎样判断是否在一个监狱中呢? 很显然,就是用种类并查集. 种类并查集的讲解——团伙(很 ...

  10. sqlserver sp_who2和inputbuffer的使用,连接数

    一.sp_who2的使用 1.存储过程的位置 sp_who官方解释地址:https://docs.microsoft.com/zh-cn/sql/relational-databases/system ...