- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我正在寻找一种允许在 Java 和 C++ 应用程序之间进行 RPC 的非常简单的方法。
我的系统包含几个 Java 模块和一个 C++ 模块。我没有太多不同的过程可以调用(每个模块大约 2-3 个),并且它们不会有太大变化(除了一些小的调整,例如添加新过程或更改原型(prototype))。我正在编写所有模块,以便我可以使用任何我想要的东西。此外,除了一台机器之外,所有模块都将在同一台机器上执行,但如果能够在另一台机器上执行其中一些模块而不会造成太多麻烦(基本上,只需更改配置文件),那将是一个加号。
用于此应用程序的所有模块、机器和网络都是可信的,但我不希望 RPC 协议(protocol)有任何安全缺陷,我希望性能开销最小,因此 RPC 协议(protocol)越简单越好。此外,每个调用的方法只有一个原型(prototype)。
目前我正在尝试通过 TCP 套接字使用 RPC,因为我不想使用 RMI 或 Unix 原语(Java 上没有标准实现,也没有网络功能)。我写了一个非常简单的 RPC 协议(protocol):通过一个 TCP 帧,你给出被调用方法的序列化名称,然后是序列化的参数列表。在服务器端,它监听一个对象并使用反射来执行给定的方法。如果出现错误,返回的对象是封装了错误的 DistantRPCError。
代码非常简单(只有大约 100 个位置)并且可以在多种情况下使用(我使用 Streams,所以我什至不依赖于套接字)。我面临的问题是我无法静态测试我的代码(本地测试的简单初始化比测试代码长)而且我真的看不出用 C++ 实现它有多难(使用 JNI 进行序列化) ,我想)。
所以我的问题是:您是否知道在 Java 和 C++ 中进行 RPC 调用的不同方法,这种方法非常简单(因此没有 RMI)并且可以信任(我不是在寻找 Shiny 的技术,我想要一些标准的和经过行业验证的东西)。此外,我对性能有一些限制(该机器是一台低成本计算机,我在本地有很多密码学要做)。正如我所说,大部分模块(除了一两个)都是在本地执行的,所以我也对 IPC 机制感兴趣(即使我的所有模块只有一个 RPC 机制会很好)。
如果你愿意,我可以给你我的实际 RPC 代码,但正如我所说,它甚至没有经过测试,所以我完全不确定它是否有效。
编辑:我可能会使用 SOAP,因为我对使用 ORB 来解决我的特定问题没有太大兴趣。谢谢你的想法!
最佳答案
我不知道其中任何一个是否符合您的简单性标准,但我想说您的两个最佳选择是旧的 - CORBA - 和新的 - 网络服务。
想到 CORBA 是因为用不同语言编写的分布式组件的互操作是其灵感的一部分,但这并不简单。市场也对 CORBA 投了反对票。我会说它在 90 年代初到中期达到顶峰,此后一直在下降。我很少听说 CORBA,因为它的值(value)。
Web 服务,尤其是如果您避开 SOAP 而使用 REST,则通过 HTTP 工作并且相对简单。我看不出开发和维护自己的有线协议(protocol)有任何优势。我会使用 HTTP 并坚持使用 REST。
关于java - Java 和 C++ 中最简单的 RPC,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5297185/
我制作手机游戏,但我想为我的社交游戏制作一些简单的基于浏览器的客户端,以便我们可以更轻松地调试。最简单的引擎是什么? 我研究了一些 HTML5 引擎和 GWT,但我想听听社区的意见。我正在寻找一种能够
有一个有趣的例子,有人设法为一个只占用 1kb 的论坛创建了一个 PHP 脚本:http://www.nerdparadise.com/blogs/blake/6034/ 我想知道是否有类似的小脚本可
首先我要吐槽一下,看程序的过程中遇见了yield这个关键字,然后百度的时候,发现没有一个能简单的让我懂的,讲起来真tm的都是头头是道,什么参数,什么传递的,还口口声声说自己的教程是最简单的,最浅显易
我的proguard配置太糟糕了,我的游戏崩溃了,而且似乎不正常。在我弄清楚到底哪里出了问题之前,最简单,最安全的配置用于全部安装是什么?有没有办法使它仅更改变量名?或者只是混淆代码以使其更难阅读而不
我正在重构一些 C# 代码,其中一部分是重做一些引用,因为我们正在完全重做文件夹结构。我想做的就是进入 .csproj 或 .sln 文件并修改路径。 然而,一些引用文献有类似的路径 "../../.
免责声明:这是一个理论问题,目的是增加我的理解。我知道我总是可以使用像 JSON 库这样的工具来解决问题。 假设我想创建一个逗号分隔的值列表,这些值本身可能包含逗号。这些逗号需要先转义。假设我使用 .
我对编程完全陌生,我选择 Delphi 作为我想学习的编程语言。 我基本上想构建使用套接字填写和提交 Web 表单的工具,并且我希望它们也是多线程的。 我希望它们功能丰富且性能正确。 我并不急于这样做
我正在构建一个协作创作工具,该工具允许用户共同编辑信息空间,该信息空间是节点和链接的可视化。一个客户端应用程序中所做的更改需要反映到所有其他客户端中。由于它是可视化的,因此可能需要经常更新潜在的大数据
作为一家专门开发自定义 CMS 的公司,我们被要求在下一个项目中部署开源 CMS。 我们可以自由选择系统。对于熟悉 PHP5 中的 MVC 模型和 OOP 的团队,您会推荐什么? 有人告诉我Drupa
已结束。此问题正在寻求书籍、工具、软件库等的推荐。它不满足Stack Overflow guidelines 。目前不接受答案。 我们不允许提出寻求书籍、工具、软件库等推荐的问题。您可以编辑问题,以便
我完全是 Ember.js 菜鸟,需要了解后端注意事项,目前似乎很少有教程涵盖。对于快速原型(prototype)设计,最简单/最简单的后端设置是什么?我看到了一些 ember-rails 教程,但是
我正在寻找这种最简单、最简单的方法来启动 Java Web 服务。我曾经使用 Axis-1-on-Tomcat,但是对于 Axis 2,它变得太厚了。我正在寻找的一些偏好: 低内存占用 - 一个包含最
我多年来一直使用旧版 openGL 和 cocoa,但现在我正在努力过渡到 openGL 3.2。互联网上有几个例子,但它们都太复杂了(许多甚至在 XCode 5.1 下不再编译)。有人可以编写一个最
我正在构建一个简单的应用程序,它应该将开关/支票簿的状态存储 7 天。我遇到的唯一问题是我用来构建所述应用程序的网站不适合手机上的本地存储。没有通过本地存储或链接到在线数据库来存储开关/支票簿状态的良
关闭。这个问题是opinion-based .它目前不接受答案。 想要改进这个问题? 更新问题,以便 editing this post 可以用事实和引用来回答它. 关闭 7 个月前。 Improv
有时我需要 1 个用户类型元素的集合(或任何其他容器)并以这种方式创建它们: boost::assign::list_of(typeVariable).convert_to_container >()
我的页面上有一个 DropDownList 和一个 TextBox。当用户在 DropDownList 中选择“其他”选项时,我想在其右侧显示一个文本框。我不想使用传统的回发技术。我希望这种交互是在客
说到编码,我还很年轻,而且我听说过很多关于组织的事情。有些使用部分,有些使用 div,有些使用 div 作为按钮,其他使用 css 中的输入来更改它。作为一个喜欢让他的代码干净、简单易懂但又正确的人,
我需要将带有变量项的 ContentValues 转换为 JSON 字符串,我可以将其保存到数据库中,并在以后用作 HTTP 请求的正文。网络上的所有内容都只会以相反的方向进行转换。 最佳答案 每当您
我的电脑上安装了 Python 3.7。想用tensorflow,发现基本不支持3.7,所以想(也)安装Python 3.6。 关于如何做到这一点有什么建议吗?我是否必须卸载 3.7 并将其替换为 3
我是一名优秀的程序员,十分优秀!