错误提示:
AllocmemHandle: OUT OF PRIVATE HANDLES! -- pid 000039F8 Handles used so far 6399, Maximum handles = 16446, error = 0x107
刚看到别人的blog上面介绍的是因为java代理循环出现的问题
Each document opened in an agent allocates a private handle. When the document is closed by the agent, the handle is freed. Loops can be tricky. If the document isn't closed after processing, a handle will be allocated for every document processed in the loop.
This isn't a concern in small databases with few documents processed, but in larger databases, it can become an issue.
别人给出的java代理代码为
View docView = config.app_db.getView("ALLDOC");
Document middleDoc;
Document curDoc = docView.getFirstDocument();
Vector cal = new Vector();
while (curDoc != null){
middleDoc = docView.getNextDocument(curDoc);
cal = session.evaluate(config.arc_create_fomular, curDoc);
if (cal.get(0).toString().equals("1.0")){
correspond += 1;
}
curDoc = middleDoc;
if (correspond >= config.maxArchive) break;
}
他做了改善后的代码为
View docView = config.app_db.getView("ALLDOC");
Document middleDoc;
Document curDoc = docView.getFirstDocument();
Vector cal = new Vector();
while (curDoc != null){
middleDoc = docView.getNextDocument(curDoc);
cal = session.evaluate(config.arc_delete_fomular, curDoc);
if (cal.get(0).toString().equals("1.0")){
correspond += 1;
}
curDoc.recycle();
curDoc = null;
curDoc = middleDoc;
middleDoc = null;
if (correspond >= config.maxArchive) break;
}
导致原因:对于domino的java代理而言,当目标对象是大数据库对象并执行循环时,仅仅在代理的最后对session进行recycle是不够的,在循环中要注意及时的释放资源。