【RPC框架探索】(一)ICE框架的探索

2024-03-29 00:08
文章标签 rpc 框架 探索 ice

本文主要是介绍【RPC框架探索】(一)ICE框架的探索,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

【1】基于Linux CentOS-7的安装

cd /etc/yum.repos.dsudo 
wget https://zeroc.com/download/rpm/zeroc-ice-el7.reposudo 
yum install ice-all-runtime ice-all-devel

【2】编写一个基本的slice,保存为Printer.ice

module Demo {interface Printer {void printString(string s);};
};

编译slice

$ mkdir generated
$ slice2java --output-dir generated Printer.ice

编写一个基本实现

public class PrinterI extends Demo._PrinterDisp {public voidprintString(String s, Ice.Current current){System.out.println(s);}
}

【2】编写Server代码

public class Server {public static voidmain(String[] args){int status = 0;Ice.Communicator ic = null;try {ic = Ice.Util.initialize(args);Ice.ObjectAdapter adapter =ic.createObjectAdapterWithEndpoints("SimplePrinterAdapter", "default -p 10000");Ice.Object object = new PrinterI();adapter.add(object, ic.stringToIdentity("SimplePrinter"));adapter.activate();ic.waitForShutdown();} catch (Ice.LocalException e) {e.printStackTrace();status = 1;} catch (Exception e) {System.err.println(e.getMessage());status = 1;}if (ic != null) {// Clean up//try {ic.destroy();} catch (Exception e) {System.err.println(e.getMessage());status = 1;}}System.exit(status);}
}

编译代码

$ mkdir classes
$ javac -d classes -classpath classes:/usr/share/java/ice.jar \
Server.java PrinterI.java generated/Demo/*.java

这里注意想一下ice.jar的jar的位置,一定要是正确的位置

【3】编写Client代码

public class Client {public static voidmain(String[] args){int status = 0;Ice.Communicator ic = null;try {ic = Ice.Util.initialize(args);Ice.ObjectPrx base = ic.stringToProxy("SimplePrinter:default -p 10000");Demo.PrinterPrx printer = Demo.PrinterPrxHelper.checkedCast(base);if (printer == null)throw new Error("Invalid proxy");printer.printString("Hello World!");} catch (Ice.LocalException e) {e.printStackTrace();status = 1;} catch (Exception e) {System.err.println(e.getMessage());status = 1;}if (ic != null) {// Clean up//try {ic.destroy();} catch (Exception e) {System.err.println(e.getMessage());status = 1;}}System.exit(status);}
}

编译Client

$ javac -d classes -classpath classes:/usr/share/java/ice.jar \
Client.java PrinterI.java generated/Demo/*.java

【4】执行Server和Client

cd classes
java Server &
java Client &

出现错误

Error: A JNI error has occurred, please check your installation and try again

出现这个错误,检查发现CLASSPATH中没有设置ice.jar,搜索系统ice.jar,发现在/usr/share/java/ice.jar,将其添加到classpath中,问题解决,可以使用下面的脚本setenv.sh

#! /bin/bash

JAVA_HOME=/usr/java/jdk1.8.0_131
CLASSPATH=.:$JAVA_HOME/lib/tools.jar:$JAVA_HOME/lib/dt.jar:/usr/share/java/ice.jar
PATH=$JAVA_HOME/bin:$PATH
export JAVA_HOME CLASSPATH PATH

执行source setenv.sh,设置好相关变量

java Server &
java Client &

出现结果

Hello World!

调用成功
【5】使用python客户端调用java的服务端
安装pip和ice-python

sudo yum install python-pip
pip install zeroc-ice

出现错误

#include <Python.h>
compilation terminated.
error: command 'gcc' failed with exit status 1

安装python开发环境解决

sudo yum install python-devl

出现错误

#include <bzlib.h>
compilation terminated.
error: command 'gcc' failed with exit status 1

安装bzip2开发库

sudo yum install bzip2-devel

编译python版的ice文件

slice2py Printer.ice

编写python的Client.py

import sys, traceback, Ice
import Demostatus = 0
ic = None
try:ic = Ice.initialize(sys.argv)base = ic.stringToProxy("SimplePrinter:default -p 10000")printer = Demo.PrinterPrx.checkedCast(base)if not printer:raise RuntimeError("Invalid proxy")printer.printString("Hello World!")
except:traceback.print_exc()status = 1if ic:# Clean uptry:ic.destroy()except:traceback.print_exc()status = 1sys.exit(status)

然后直接调用

python Client.py

结果

Hello World!

这篇关于【RPC框架探索】(一)ICE框架的探索的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/857074

相关文章

RabbitMQ工作模式中的RPC通信模式详解

《RabbitMQ工作模式中的RPC通信模式详解》在RabbitMQ中,RPC模式通过消息队列实现远程调用功能,这篇文章给大家介绍RabbitMQ工作模式之RPC通信模式,感兴趣的朋友一起看看吧... 目录RPC通信模式概述工作流程代码案例引入依赖常量类编写客户端代码编写服务端代码RPC通信模式概述在R

C++ HTTP框架推荐(特点及优势)

《C++HTTP框架推荐(特点及优势)》:本文主要介绍C++HTTP框架推荐的相关资料,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1. Crow2. Drogon3. Pistache4. cpp-httplib5. Beast (Boos

SpringBoot基础框架详解

《SpringBoot基础框架详解》SpringBoot开发目的是为了简化Spring应用的创建、运行、调试和部署等,使用SpringBoot可以不用或者只需要很少的Spring配置就可以让企业项目快... 目录SpringBoot基础 – 框架介绍1.SpringBoot介绍1.1 概述1.2 核心功能2

Spring框架中@Lazy延迟加载原理和使用详解

《Spring框架中@Lazy延迟加载原理和使用详解》:本文主要介绍Spring框架中@Lazy延迟加载原理和使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录一、@Lazy延迟加载原理1.延迟加载原理1.1 @Lazy三种配置方法1.2 @Component

Python Dash框架在数据可视化仪表板中的应用与实践记录

《PythonDash框架在数据可视化仪表板中的应用与实践记录》Python的PlotlyDash库提供了一种简便且强大的方式来构建和展示互动式数据仪表板,本篇文章将深入探讨如何使用Dash设计一... 目录python Dash框架在数据可视化仪表板中的应用与实践1. 什么是Plotly Dash?1.1

基于Flask框架添加多个AI模型的API并进行交互

《基于Flask框架添加多个AI模型的API并进行交互》:本文主要介绍如何基于Flask框架开发AI模型API管理系统,允许用户添加、删除不同AI模型的API密钥,感兴趣的可以了解下... 目录1. 概述2. 后端代码说明2.1 依赖库导入2.2 应用初始化2.3 API 存储字典2.4 路由函数2.5 应

Python GUI框架中的PyQt详解

《PythonGUI框架中的PyQt详解》PyQt是Python语言中最强大且广泛应用的GUI框架之一,基于Qt库的Python绑定实现,本文将深入解析PyQt的核心模块,并通过代码示例展示其应用场... 目录一、PyQt核心模块概览二、核心模块详解与示例1. QtCore - 核心基础模块2. QtWid

最新Spring Security实战教程之Spring Security安全框架指南

《最新SpringSecurity实战教程之SpringSecurity安全框架指南》SpringSecurity是Spring生态系统中的核心组件,提供认证、授权和防护机制,以保护应用免受各种安... 目录前言什么是Spring Security?同类框架对比Spring Security典型应用场景传统

Python结合Flask框架构建一个简易的远程控制系统

《Python结合Flask框架构建一个简易的远程控制系统》这篇文章主要为大家详细介绍了如何使用Python与Flask框架构建一个简易的远程控制系统,能够远程执行操作命令(如关机、重启、锁屏等),还... 目录1.概述2.功能使用系统命令执行实时屏幕监控3. BUG修复过程1. Authorization

SpringBoot集成图片验证码框架easy-captcha的详细过程

《SpringBoot集成图片验证码框架easy-captcha的详细过程》本文介绍了如何将Easy-Captcha框架集成到SpringBoot项目中,实现图片验证码功能,Easy-Captcha是... 目录SpringBoot集成图片验证码框架easy-captcha一、引言二、依赖三、代码1. Ea