我正在使用RPostgreSQL连接到本地数据库。该设置在我的Linux机器上工作得很好。 R 2.11.1,Postgres 8.4。foreach%dopar%+ RPostgreSQL
我正在玩多核(doMC)并行后端的'foreach'来包装一些重复查询(数字为数千)并将结果附加到数据结构中。奇怪的是,如果我使用%do%,但是在切换到%dopar%时失败,除了只有一次迭代时(如下所示),它会起作用
我想知道它是否与单个操作有关连接对象,所以我创建了10个连接对象,并根据“我”是什么,为该查询提供了一个特定的con对象,具体取决于我的模10(下面仅由2个连接对象指出)。被评估为eval(expr.01)的表达式包含/是依赖于'i'的查询。
我无法理解这些特定的错误信息。我想知道是否有任何方法可以完成这项工作。
谢谢。
维沙尔Belsare
[R片断如下:
> id.qed2.foreach <- foreach(i = 1588:1588, .inorder=FALSE) %dopar% {
+ if (i %% 2 == 0) {con <- con0};
+ if (i %% 2 == 1) {con <- con1};
+ fetch(dbSendQuery(con,eval(expr.01)),n=-1)$idreuters};
> id.qed2.foreach
[[1]]
[1] 411 414 2140 2406 4490 4507 4519 4570 4571 4572 4703 4731
[109] 48765 84312 91797
> id.qed2.foreach <- foreach(i = 1588:1589, .inorder=FALSE) %dopar% {
+ if (i %% 2 == 0) {con <- con0};
+ if (i %% 2 == 1) {con <- con1};
+ fetch(dbSendQuery(con,eval(expr.01)),n=-1)$idreuters};
Error in stop(paste("expired", class(con))) :
no function to return from, jumping to top level
Error in stop(paste("expired", class(con))) :
no function to return from, jumping to top level
Error in { :
task 1 failed - "error in evaluating the argument 'res' in selecting a method for function 'fetch'"
>
编辑:我改变了一些东西,(仍然不成功),但有一些事情要轻。在循环中创建的连接对象并不是通过dbDisconnect“断开连接”,导致挂起连接,如Postgres的/ var/log所示。当我这样做时,会出现一些新的错误消息:
> system.time(
+ id.qed2.foreach <- foreach(i = 1588:1590, .inorder=FALSE,
.packages=c("DBI", "RPostgreSQL")) %dopar% {drv0 <- dbDriver("PostgreSQL");
con0 <- dbConnect(drv0, dbname='nseindia');
list(idreuters=fetch(dbSendQuery(con0,eval(expr.01)),n=-1)$idreuters);
dbDisconnect(con0)})
Error in postgresqlExecStatement(conn, statement, ...) :
no function to return from, jumping to top level
Error in postgresqlExecStatement(conn, statement, ...) :
no function to return from, jumping to top level
Error in postgresqlExecStatement(conn, statement, ...) :
no function to return from, jumping to top level
Error in { :
task 1 failed - "error in evaluating the argument 'res' in selecting a method for function 'fetch'"
如果您解决了问题,请将您的解决方案作为下面的答案发布,并将其标记为已接受。这对将来的参考很有用。 – BoltClock 2010-10-11 14:40:15