【发布时间】:2015-02-19 06:20:00
【问题描述】:
我无法弄清楚我所有的内存都去哪里了,大约 28,000 次循环后内存会耗尽。尝试了几种unset的组合都无济于事。
updateProduct() 仅被注释掉以帮助我隔离问题。
任何帮助将不胜感激。
include_once '../app/Mage.php';
Mage::init();
//fetch all products
$res = Mage::getSingleton('core/resource');
$db = $res->getConnection('catalog_read');
$productTable = $res->getTableName('catalog/product');
$sql = $db->select()->from($productTable,
'entity_id'
);
//Returns about 162,000 rows
$rows = $db->fetchAll($sql);
$rowcount = count($rows);
$progress = 0;
foreach($rows as $productRow)
{
$product_id = $productRow["entity_id"];
if($product_id){
//memory leaks here.
$product=Mage::getModel('catalog/product')->setStoreID(0)->load($product_id);
//updateProduct($product);
}else{
echo "LOAD ERROR\n";
}
$product->clearInstance();
unset($product);
gc_collect_cycles();
//echo memory_get_usage() . " 49\n";
if($progress % 500 == 0)
{
echo "$progress out of $rowcount complete\n";
echo memory_get_usage() . "\n";
}
$progress++;
}
updateProduct 正在匹配一些分层导航属性的折扣:
function updateProduct($product_id)
{
global $off10,$off20,$off30,$off40,$off50;
//echo "$product_id\n";
$product=Mage::getModel('catalog/product')->setStoreID(0)->load($product_id);
$attribute = $product->getResource()->getAttribute('discount');
if ($attribute)
{
$discount_value += $attribute->getFrontend()->getValue($product);
//Match discount to layered_nav_discount and all attributes < discount
if($discount_value < 10){
$value = "";
}elseif($discount_value < 20){
$value = "$off10";
}elseif($discount_value < 30){
$value = "$off10,$off20";
}elseif($discount_value < 40){
$value = "$off10,$off20,$off30";
}elseif($discount_value < 50){
$value = "$off10,$off20,$off30,$off40";
}elseif($discount_value >= 50){
$value = "$off10,$off20,$off30,$off40,$off50";
}
//Update layered_nav_discount
//$_product->addAttributeUpdate('layered_nav_discount', $value, 0);
unset($product);
return;
}
};
【问题讨论】:
-
这并不奇怪,因为您在此循环中使用了
load()。您应该在原始查询中选择您需要的属性。我不知道updateProduct($product)应该做什么,所以现阶段我们无法为您提供帮助,也许您可以提供更多信息。
标签: php magento memory-leaks foreach