java – 准备Nashorn引擎的Apache Commons池的有效方法

我正在使用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实例的数量吗?
>是否可以安全地序列化并保留已创建实例的克隆? (这将允许维护引擎缓存,如果其中一个资产发生更改,则只需要使其无效)

相关资源(适当时将更新此部分)

> SO: Clone Entire JavaScript Engine

最佳答案
Nashorn的引擎实例既不可复制也不可序列化.我建议您使用单个引擎实例,并使用ScriptEngine.createBindings()创建多个Bindings对象并对其进行池化.您显然需要通过调用ScriptEngine.eval(String | Reader,Bindings)方法来初始化每个Bindings. (您也可以使用ScriptContext对象而不仅仅是Bindings;它们实际上是绑定和out / err流的元组.)

使用单个ScriptEngine的好处是代码共享.将相同的脚本评估为多个绑定仍然只编译脚本一次(如果使用Compilable接口),并且所有函数对象的代码将由相同的编译字节码表示.

相关文章

最近看了一下学习资料,感觉进制转换其实还是挺有意思的,尤...
/*HashSet 基本操作 * --set:元素是无序的,存入和取出顺序不...
/*list 基本操作 * * List a=new List(); * 增 * a.add(inde...
/* * 内部类 * */ 1 class OutClass{ 2 //定义外部类的成员变...
集合的操作Iterator、Collection、Set和HashSet关系Iterator...
接口中常量的修饰关键字:public,static,final(常量)函数...