更新:
现在我正在尝试接收大约 120M 行的数组。我没有通过 UTL_file 执行此操作的原因是因为在我们的生产服务器中,它需要 oracle 用户访问权限才能将写入的平面文件写入并将其移动到我们所需的目录中。另外一个问题是提取后仍然需要大量文本操作,我认为这是 Perl 的工作。
我现在想做的是编写我自己的 DBI::Iterator 实现以及它可能需要的所有其他依赖项;不过要清楚,不一定都是。(就像一些只有 DBI 的方法,然后只是 idb_rows ......只是为了让它运行,因为我无法安装模块)
原始问题:
美好的一天,我对 perl 编程比较陌生,一周前我开始在 perl 中再次收到内存不足的消息。我之前可以通过切换到 64 位 perl 来解决这个问题。
我昨天刚刚发现我的生产机器的内核不允许我使用超过 4GB 的内存(在我的其他生产服务器中,我能够将大量数据加载到内存中)
这是我在生产服务器中的具体限制
- 我不允许安装 perl 的新模块
- 在某种程度上,我被允许在本地安装它们,但我遇到了麻烦
我现在打算做的是重新创建这个模块。 迭代器::DBI
我没有迭代器的背景。在最长的时间内,我通过以下函数开发数据库提取和 ETL 流程。使用下面的函数一年半后,我第一次遇到内存不足的错误。
sub myDBI
{
my ($filename) = @_;
my $query = "";
unless(open(FILE,$filename))
{
Logger("[ ERR ] unable to open $SETTINGS{SQL_TRIGGER}\n");
print
die;
}
my @result=`sqlplus -S $SETTINGS{USER_NAME}/$SETTINGS{PASSWORD}\@$SETTINGS{DB_NAME} <<END
SET HEADING OFF
SET FEEDBACK OFF
SET SERVEROUTPUT ON
SET LINES 5000
SET COLSEP "||"
$query
/
`
;
@result;
}