ожидается, что алгоритм:
- вы запускаете JVM без фактического применения (только сказать ему, чтобы загрузить некоторые банки), он загружает и слушает сокет и ждет в фоновом режиме.
- при запуске приложения (
preloaded_java -cp /usr/share/java/....jar:. qqq.jar
) подключается к существующей загруженной JVM, загружает дополнительные jar (если есть) и выполняет основной класс. preloaded_java
как раз направляет входной сигнал и выход и регулирует прерывания etc.
обновление реализовано доказательство концепция: http://vi-server.org/vi/code/prejvm/
$ clojure prejvm.clj&
[1] 2883
$ nc 127.0.0.1 7711 <<< '{"mainclass" "test.Hello"}'
$ nc 127.0.0.1 7712
java.lang.ClassNotFoundException: test.Hello
at java.net.URLClassLoader.run(URLClassLoader.java:200)
...
at clojure.main.main(main.java:37)
$ nc 127.0.0.1 7711 <<< '{"classpaths" ["file:///home/vi/code/prejvm/"], "mainclass" "test.Hello"}'
$ nc 127.0.0.1 7712
Hello, world; number of args is 0
qwe q e32e qda
qwe q e32e qda
$ nc 127.0.0.1 7711 <<< '{"classpaths" ["file:///home/vi/code/prejvm/"], "mainclass" "test.Hello", "argv" ["qqq" "www" "eee"]}'
$ nc 127.0.0.1 7712
Hello, world; number of args is 3
sdfasdfasf df sad
sdfasdfasf df sad
обновление 2: нашел ответ сам: Nailgun сервер (от VimClojure).