Java 到 Erlang 的消息

Posted

技术标签:

【中文标题】Java 到 Erlang 的消息【英文标题】:Java to Erlang messages 【发布时间】:2011-05-07 03:53:53 【问题描述】:

我正在用Erlang 制作一个应用程序,带有Java 的GUI。 我已经设法在 to 语言之间建立了连接,但现在我需要(我猜)每次按下按钮时(例如)从 Java 向 Erlang 发送一条消息。

这是正确的方法吗?

这样的消息会是什么样子?

我找到了一些关于这种集成形式的好网站,但我觉得我没有得到一切。

http://www.trapexit.org/How_to_communicate_java_and_erlang

【问题讨论】:

【参考方案1】:

除了通过 OTP jinterface 进行经典的 Java-Erlang 通信之外,您还可以研究以下方法:

 - thrift
 - ice from zeroC (no official erlang binding)
 - maybe two http servers on both sides (I like this approach) 
 - protocol buffers (rather not, it is better for larger data transfers)

您需要了解流量的形状并选择最佳解决方案。 Jinterface 还不错,虽然..(这里是官方文档:http://www.erlang.org/doc/apps/jinterface/jinterface_users_guide.html

【讨论】:

我设法将消息从 Erlang 发送到 Java 并成功接收。 [主要来自这个例子][1]。但我想要做的主要事情是相反的。从 Java 发送到 Erlang。我有一些猜测,我必须向我从 Erlang 获得的 Pid 返回一条消息。 [1]:pdincau.wordpress.com/2010/01/07/…【参考方案2】:

如果 jinterface 太复杂,你可以只使用 open_port 上的 packet 选项并使用

byte[] in_buf = new byte[256];
byte[] out_buf = new byte[256];
int in_count = System.in.read ();
int offset = 0; 
do
    
        int c = System.in.read (in_buf, offset, in_count-offset);
        offset += c;
    
while (offset < in_count);

从 erlang 读取数据包并写入使用:

System.out.write(out_count);
System.out.write(out_buf, 0, out_count);

在 erlang 方面,这将匹配

open_port(spawn, "<path-to-java> -cp <classpath> your-java-prog", 
          [packet, 1]).

如果您需要更大的数据包,请使用 packet, 2 或 packet, 4 并调整 java.util. 在数据包内,您可以在两侧运行您喜欢的任何协议。

【讨论】:

【参考方案3】:

我正在开发一个与您类似的应用程序:C++ GUI 和 Erlang 服务器。我使用 TCP 套接字在 GUI 和服务器之间交换消息,并使用 Erlang 服务器模式来处理请求(我可能同时有多个 GUI 连接到服务器)。

【讨论】:

以上是关于Java 到 Erlang 的消息的主要内容,如果未能解决你的问题,请参考以下文章

在 Erlang 中将消息路由到 PID

Erlang/OTP 升级丢失现有的 RabbitMQ 消息

用erlang解析ejabberd数据包

Erlang Tracing:因果一致性?

Erlang进程发送消息

Erlang 中的并发