博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
基于服务的并行系统的通讯方式探讨
阅读量:6801 次
发布时间:2019-06-26

本文共 781 字,大约阅读时间需要 2 分钟。

作者:朱金灿

来源:

 

     最近在设计一个基于服务的并行系统。架构图大致如下:

 

 

        和同事讨论后,服务器部署的Java Web服务,计算节点上部署的是C++算法或其它语言算法。毫无疑问二者需要一个中间协议或中间层进行通讯。同事建议的方案是Java WebService+ Java服务程序(Jacob)+ com中间层+算法模块,其中Java服务程序+ com中间层+算法模块部署在计算节点上,Java WebService通过rmi和Java服务程序通讯,Java服务程序通过Jacob和com中间层通讯,com中间层再和算法模块通讯。

        我的方案是:Java Web+客户端C++服务程序+com中间层+算法模块,其中计算节点C++服务程序+com中间层+算法模块部署在计算节点上,Java WebService通过socket和计算节点C++服务程序通讯,计算节点C++服务程序通过com中间层和算法模块通讯。

 

        他的理由是rmi是成熟的java通讯技术,且可以直接调用远程对象,使用很方便。Java通过socket和C++程序通讯将会遇到很多难以解决的问题。

        我的理由是Java通过socket和C++程序通讯肯定也有很多程序的做法,虽然不如rmi使用那么方便。如果计算节点是Windows平台,C++可以直接调用com中间层,并不需要jacob这样的中间层(jacob的并发性差也颇被人诟病的),如果计算节点是Linux平台,Java服务程序需要使用jni之类的中间层和C++算法模块通讯,而C++服务程序可以直接和C++算法模块通讯,这样就避免了同时维护jacob和jni两个通讯中间层。可能开始Java通过socket和C++程序麻烦些,但避免了后期维护的麻烦。

转载于:https://www.cnblogs.com/lanzhi/p/6470113.html

你可能感兴趣的文章
CentOS 7最小安装后,手动连接网络
查看>>
选择排序
查看>>
卷积神经网络(基础知识回顾)-第七讲
查看>>
inno setup中文支持
查看>>
js内存泄漏的问题?
查看>>
程序代码阅读与分析
查看>>
Linux 安装PHP PECL 百分百成功
查看>>
关于c++风格 code style
查看>>
svn 常用
查看>>
SVM支持向量机
查看>>
Asymptote 学习记录(2):例子阅读
查看>>
《常微分方程教程》习题2-2,4:一个跟踪问题
查看>>
陶哲轩实分析例17.2.3
查看>>
兩個集合之間的全體部分函數可以形成一個集合
查看>>
Elementary Methods in Number Theory Exercise 1.2.17
查看>>
认识拨号计划 - Dialplan
查看>>
DataTable 的数据导出到 Excel
查看>>
委托由浅入深学习
查看>>
BZOJ 1012 [JSOI2008]最大数maxnumber
查看>>
权限管理[Linux]
查看>>