Я создаю фреймворк в Java, который будет прослушивать события, а затем обрабатывать их в Jython. Различные типы событий будут отправляться по разным сценариям.
Так как jython занимает довольно много времени, чтобы скомпилировать script, когда вызывается PythonInterpreter.exec(), мне придется предварительно скомпилировать скрипты. Я делаю это следующим образом:
// initialize the script as string (would load it from file in final version)
String script = "print 'foo'";
// get the compiled code object
PyCode compiled = org.python.core.__builtin__.compile( script, "<>", "exec" );
Скомпилированный объект PyCode будет помещен в репозиторий и использован как события, входящие в
PythonInterpreter pi = new PythonInterpreter();
pi.set( "variable_1", "value_1");
pi.set( "variable_x", "value_x");
pi.exec( compiled );
Теперь для моей загадки - может случиться, что одновременно происходит несколько событий определенного типа - при этом одновременно выполняются несколько экземпляров script.
Почти все скрипты, вероятно, останутся недолговечными - до 100 строк, без петель. Число и частота полностью случайны (генерируемые пользователем события) и могут составлять от 0 до 200 в секунду для каждого типа события.
Каким будет лучший способ сделать это? Я рассматриваю несколько возможностей:
- использовать синхронизацию в точке события триггера - это предотвратит несколько экземпляров одного и того же script, а также события не будут обрабатываться так быстро, как они должны быть
- создать пул скриптов того же типа, который каким-то образом заполняется клонированием исходного объекта PyCode - самая большая проблема, вероятно, будет оптимизировать размеры пула
- динамически клонирует объект script от родителя при необходимости, а затем отбрасывает его, когда exec() заканчивается - таким образом, отставание удаляется из компиляции, но оно все еще присутствует в методе clone
Возможно, комбинация чисел 2 и 3 была бы лучшая - создание динамических размеров пула?
Итак, какие-то мысли?;)