- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
PHP 在处理了大约 45 分钟的记录后出现了 ZEND HEAP 错误,我花了无数小时研究并试图解决这个错误,但未能解决。当我研究并尝试了所有方法时,没有 .ini 配置可以解决这个问题!这似乎只是一个 php 5xx 限制或错误。
我有 6 个表和超过 54,000,000 条要查询的记录。从这些查询中,我生成了一个专有文本文件。
我正在寻找以下脚本中的最佳建议或脚本的重新创建,因为我在过去一年中对其进行了 100 次修改并且它变得更快,但我无法摆脱 ZEND HEAD 错误,该错误会终止我的脚本非常大的记录集。
这不是基于网络的脚本,所有工作都是本地化的,并通过 php cli 运行。
我还应该注意到,我花了无数个小时重新配置 php.ini 内存设置和任何其他可能的调整,我尝试了但没有成功。
我希望脚本可以用 OOP 结构编写,从而提高内存效率。
提前感谢任何时间或想法。以下是我现有的代码:
<?php
ini_set('mysql.connect_timeout', '9999999999999999999999999999999999999999999999');
ini_set('default_socket_timeout', '9999999999999999999999999999999999999999999999');
ini_set('memory_limit','9999999999999999999999999999999999999999999999M');
// Opens a connection to a MySQL server.
$connection = mysql_connect ("localhost", "root", "");
if (!$connection)
{
die('Not connected : ' . mysql_error());
}
// Sets the active MySQL database.
$db_selected = mysql_select_db("charities", $connection);
if (!$db_selected)
{
die ('Can\'t use db : ' . mysql_error());
}
// Basic settings
$txtdate = date('Ymdhis');
// Filter only
$_POST["state_abbr"] = 'NY'; // State
$_POST["loc_type"] = 'Non Profit'; // Church, School, Non Profit etc...
// Query parameters - eg for Open or Closed Status.
$_POST["case_disp"] = 'C';
$_POST["case_disp_txt"] = 'CLOSED';
$_POST["case_disp_gp"] = 'CLOSED';
$_POST["last_act_txt"] = 'CLOSED';
// Text output only.
$_POST["status_word"] = 'Closed'; // Location status: "ABANDONED" or "ACTIVE"
$_POST["stateU"] = 'New York';
$Locations_yr = "2012-" . date('Y');
// Selects all the rows in the markers table.
$query = "SELECT * FROM charity_full_merged as a
INNER JOIN charity_full_merged_st_load_case as b
ON a.charity_id=b.charity_id
INNER JOIN charity_full_merged_land as c
ON b.charity_id=c.charity_id
INNER JOIN charity_full_merged_county as d
ON c.charity_id=d.charity_id
INNER JOIN charity_full_merged_customer as e
ON d.charity_id=e.charity_id
WHERE
a.township_range_quarters != ''
AND
b.geo_state = '".$_POST["state_abbr"]."'
AND
b.casetype_txt LIKE \"%".$_POST["loc_type"]."%\"
AND
b.case_disp_txt = '".$_POST["case_disp_txt"]."' GROUP BY b.charity_nm;";
$result = mysql_query($query);
if($result === FALSE) {
die(mysql_error());
}
$results_count = mysql_num_rows($result);
$result = mysql_query($query);
if (!$result)
{
die('Invalid query: ' . mysql_error());
}
// Creates an array of strings to hold the lines of the txt file.
$txt = array('<?xml version="1.0" encoding="UTF-8"?>');
$txt[] = "<Document>
<name>" . date('Y') . " Data Map of " . $_POST["stateU"] . ". " . $_POST["status_word"] . " " . $_POST["loc_type"] . " Locations. </name>
<description>" . $_POST["stateU"] . " " . $_POST["status_word"] . " " . $_POST["loc_type"] . " " . " map." . " " . $results_count . " Records. Created by Charity Group 5." . date('Y') . ". </description>";
while ($row = @ mysql_fetch_assoc($result))
{
if ($row['last_action_txt'] == 'NOP'
{
$boxclr = 'activeLoc';
}
else if ($row['case_disp'] == 'C'
{
$boxclr = 'closedLoc';
}
else { // Unknown
$boxclr = "yellowBox";
}
$txt[] = "... general content written here ... (about 100 lines of text per record ";
}
// End XML file
$txt[] = ' </Document>';
$txt[] = '</txt>';
$txtOutput = join("\n", $txt);
// Create .txt file.
$txtfile = $_POST["stateU"] . "Charities" . $_POST["status_word"] . "-" . $_POST["loc_type"] . "-LocationS-" . $results_count . "-" . $txtdate . ".txt";
// Put the contents of $txtOutput into the $txtfile.
file_put_contents($txtfile, $txtOutput);
echo "$results_count " . $_POST["status_word"] . " " . $_POST["loc_type"] . " Location records processed...";
?>
最佳答案
我想您已经理解了一般问题。您正在尝试将整个结果集累积到 $txt
数组中 - 如您所见,这不适用于庞大的数据集。相反,您应该允许 PHP 在生成数据时输出数据。
所以代替:
$txt[] = "(header stuff)";
while ($row = mysql_fetch_assoc($result) { // Remove the @ here!!!
$txt[] = "(content stuff)"; // This becomes 'huge'
}
$txt[] = "(footer stuff)";
$txtOutput = join("\n", $txt); // Now your memory usage is
// ~ 2 * 'huge'
file_put_contents($filename, $txtOutput);
$fp = fopen($filename, "w");
fwrite($fp, "(header stuff)");
while ($row = mysql_fetch_assoc($result) {
fwrite($fp, "(content stuff)");
}
fwrite($fp, "(footer stuff)");
fclose($fp);
此外,当您必须尝试使用像 9999999999999999999999999999999999999999999999
这样的数字时对于套接字超时或内存限制,这应该是一个很大的警告,表明您做错了什么。
关于php - 如何节省内存负载并防止 ZEND HEAP php 错误查询创建 .txt 文件的数百万条记录,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16267821/
我知道我要求太多,但也许你也可以帮助解决这个问题。 a.txt 包含单词,b.txt 包含字符串。 我想知道 b.txt 中有多少个字符串以 a.txt 中的单词结尾 例子:一个.txt apple
这个问题在这里已经有了答案: erge text files ordered by numerical filenames in Bash (3 个答案) 关闭 4 年前。 我有一个文件夹,其中包含
我在一个目录中有几个平面文件 (.txt)。所有这些文件的格式都是 *.txt.txt,所以我想将其重命名为 *.txt?有什么简单的方法可以一起重命名? 当我尝试 ren *.txt.txt *.t
这个问题在这里已经有了答案: How can I use a file in a command and redirect output to the same file without trunc
您是否有任何理由应该或不应该允许访问 javascript 或 css 文件?特别是常见的文件,如 jquery。 最佳答案 人们普遍认为,搜索引擎每天为给定站点分配一定数量的带宽或 URL。因此,一
Closed. This question is off-topic。它当前不接受答案。 想要改善这个问题吗? Update the question,所以它是用于堆栈溢出的on-topic。 已关闭
这是相同的代码。我面临的问题是,我无法在任何文件上写入任何内容。请帮忙解决这个问题 #include #include int main() { FILE *fe; FILE *fo;
我想要特定于域的 robots.txt,到目前为止这有效: RewriteRule ^robots\.txt$ robots/%{HTTP_HOST}.txt [L] 但我希望有一个后备方案,因此如果
我正在调试一些构建成功运行的 SQL 命令的代码。 然而,在查询结束时,查询结果似乎被写入了一个文本文件。 完整的查询如下 echo SELECT DATE,DATETABLE,DATE,APPDAT
这个问题已经有答案了: difference between grep Vs cat and grep (5 个回答) 已关闭 8 年前。 我看到一个例子,其中有人这样做: cat source.tx
我想将表中的数据从以 csv 格式存储的文本文件插入到 sql server 表中。为此,我正在使用批量插入语句。现在我需要在“From”子句中指定文件名。我不想在那里使用网络位置或本地位置。我想将我
假设我有一个测试文件夹 (test.domain.com) 并且我不希望搜索引擎在其中抓取,我是否需要在测试文件夹中有一个 robots.txt 或者我可以只放置一个 robots.txt在根目录中,
关闭。这个问题是off-topic .它目前不接受答案。 想改善这个问题吗? Update the question所以它是 on-topic对于堆栈溢出。 9年前关闭。 Improve this q
这个问题在这里已经有了答案: order of directives in robots.txt, do they overwrite each other or complement each ot
关闭。这个问题是opinion-based .它目前不接受答案。 想改进这个问题?更新问题,以便 editing this post 可以用事实和引用来回答它. 8年前关闭。 Improve this
已关闭。这个问题是 not about programming or software development 。目前不接受答案。 这个问题似乎不是关于 a specific programming
在过去的几年中,当我引用“名字”字段的文本框控件时,我一直使用 FirstNameTxt 命名约定。但是,我注意到大多数其他开发人员倾向于使用命名约定 txtFirstName 哪个是最好的约定?为什
我只想允许目录 /minsc 中的一个文件,但我想禁止该目录的其余部分。 现在 robots.txt 中是这样的: User-agent: * Crawl-delay: 10 # Directorie
我正在编写一个将 youtube.com 映射到另一个域的代理服务器(因此用户可以轻松地从德国等国家/地区访问 youtube,而无需审查搜索结果和视频)。 不幸的是,我的 robots.txt 中存
我没有编程技能,但有一项非常具体的任务:我必须将一个庞大的文本文件拆分成多个,并在特定的文本标记 (@) 处拆分它们。我决定尝试使用 Powershell 脚本来完成此任务。 到目前为止,这就是我想出
我是一名优秀的程序员,十分优秀!