Сообщения с Java на Erlang
Я делаю приложение на Erlang, с графическим интерфейсом на Java. Мне удалось установить связь между языками, но теперь мне нужно (я думаю) отправлять сообщение с Java на Erlang каждый раз, когда я, например, нажимаю кнопку.
Это правильный путь?
Как бы выглядело такое сообщение?
Я нашел несколько хороших сайтов об этой форме интеграции, но я чувствую, что я не все понимаю.
3 ответа
Если jinterface слишком сложен, вы можете просто использовать опцию пакета в open_port и использовать
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);
На стороне эрланга это будет соответствовать
open_port({spawn, "<path-to-java> -cp <classpath> your-java-prog",
[{packet, 1}]).
Если вам нужны пакеты большего размера, используйте {package, 2} или {packet, 4} и адаптируйте Java. Внутри пакетов вы можете запустить любой протокол с обеих сторон.
Помимо классической коммуникации Java-Erlang через OTP-интерфейс вы можете исследовать такие методы, как:
- 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)
Я работаю над приложением, похожим на ваше: C++ GUI и сервер Erlang. Я использую TCP-сокеты для обмена сообщениями между графическим интерфейсом и сервером и серверные шаблоны Erlang для обработки запросов (у меня может быть одновременно подключено более одного графического интерфейса к серверу).