我正在使用Apache Commons Pool来创建一个Nashorn引擎池.在应用程序启动时,我调用preparePool()
来将minIdle实例数预热到eval()所有脚本到引擎中,以便它可以立即响应对invokeFunction()的调用.
热身
@Override
public NashornScriptEngine create() {
// ...
try {
engine.eval(asset1);
engine.eval(asset2);
engine.eval(asset3);
} // ...
return engine;
}
根据池大小和预加载脚本的复杂性,这需要相当长的时间.
问题
>我可以只预热一个实例并将其安全地克隆到minIdle实例的数量吗?
>是否可以安全地序列化并保留已创建实例的克隆? (这将允许维护引擎缓存,如果其中一个资产发生更改,则只需要使其无效)
相关资源(适当时将更新此部分)
最佳答案
Nashorn的引擎实例既不可复制也不可序列化.我建议您使用单个引擎实例,并使用ScriptEngine.createBindings()创建多个Bindings对象并对其进行池化.您显然需要通过调用ScriptEngine.eval(String | Reader,Bindings)方法来初始化每个Bindings. (您也可以使用ScriptContext对象而不仅仅是Bindings;它们实际上是绑定和out / err流的元组.)
使用单个ScriptEngine的好处是代码共享.将相同的脚本评估为多个绑定仍然只编译脚本一次(如果使用Compilable接口),并且所有函数对象的代码将由相同的编译字节码表示.