Current Path : /var/www/www-root/data/webdav/www/www.monolith-realty.ru/bitrix/modules/main/admin/ |
Current File : /var/www/www-root/data/webdav/www/www.monolith-realty.ru/bitrix/modules/main/admin/repair_db.php |
<?php /** * Bitrix Framework * @package bitrix * @subpackage main * @copyright 2001-2013 Bitrix * @global CMain $APPLICATION * @global CUser $USER * @global CDatabase $DB */ require_once(__DIR__."/../include/prolog_admin_before.php"); define("HELP_FILE", "utilities/repair_db.php"); IncludeModuleLangFile(__FILE__); if(!$USER->CanDoOperation('edit_php')) { $APPLICATION->AuthForm(GetMessage("ACCESS_DENIED")); } elseif(isset($_REQUEST["table_name"]) && check_bitrix_sessid()) { require_once($_SERVER["DOCUMENT_ROOT"]."/bitrix/modules/main/include/prolog_admin_js.php"); @set_time_limit(0); $table_name = trim($_REQUEST["table_name"]); if($table_name <> '') { $arTables = array(); $rsTables = $DB->Query("show table status"); while($arTable = $rsTables->Fetch()) { $arTables[$arTable["Name"]] = $arTable; } ksort($arTables); $tables_count = count($arTables); if($table_name=="start|") { $arTable = array_shift($arTables); CAdminMessage::ShowMessage(array( "MESSAGE" => htmlspecialcharsbx($arTable["Name"]), "TYPE" => "PROGRESS", "PROGRESS_VALUE" => 0, "PROGRESS_TOTAL" => $tables_count, "HTML" => true, "DETAILS" => GetMessage("RDB_OPTIMIZE_PROGRESS", array( "#done#" => 0, "#todo#" => $tables_count, ))."#PROGRESS_BAR#", )); ?> <script>setTimeout("Optimize('<?echo CUtil::JSEscape($arTable["Name"])?>')", 100);</script> <? } else { if(mb_substr($table_name, 0, 2) === "o|") { $op = "optimize"; $table_name = mb_substr($table_name, 2); } elseif(mb_substr($table_name, 0, 2) === "a|") { $op = "analyze"; $table_name = mb_substr($table_name, 2); } else { $op = "check"; } foreach($arTables as $TableName => $arTable) { if($TableName == $table_name) break; unset($arTables[$TableName]); } if(!empty($arTables)) { $arTable = array_shift($arTables); $bCheckOK = true; $start_check = microtime(true); if($op == "check") { $rsStatus = $DB->Query('check table `'.$arTable["Name"].'`'); if($arStatus = $rsStatus->Fetch($rsStatus)) { if($arStatus["Msg_type"]=="error" || $arStatus["Msg_type"]=="warning") $bCheckOK = false; } } $end_check = microtime(true); $check_time = $end_check - $start_check; //When check time was less when 5 seconds we'll optimize and analyze table on the same hit if($bCheckOK && ($check_time < 5)) { if($op == "check" || $op == "optimize") $rsStatus = $DB->Query('optimize table `'.$arTable["Name"].'`'); if($op == "check" || $op == "analyze") $rsStatus = $DB->Query('analyze table `'.$arTable["Name"].'`'); } if(!$bCheckOK) { CAdminMessage::ShowMessage(array( "MESSAGE" => GetMessage("RDB_OPTIMIZE_ERROR"), "TYPE" => "ERROR", "HTML" => true, "DETAILS" => GetMessage("RDB_OPTIMIZE_CHECK_FIRST", array( "#table_name#" => htmlspecialcharsbx($arTable["Name"]), )), )); } elseif(!empty($arTables)) { if($check_time < 5) { $arTable = array_shift($arTables); CAdminMessage::ShowMessage(array( "MESSAGE" => htmlspecialcharsbx($arTable["Name"]), "TYPE" => "PROGRESS", "PROGRESS_VALUE" => $tables_count-count($arTables), "PROGRESS_TOTAL" => $tables_count, "HTML" => true, "DETAILS" => GetMessage("RDB_OPTIMIZE_PROGRESS", array( "#done#" => $tables_count-count($arTables), "#todo#" => $tables_count, ))."#PROGRESS_BAR#", )); ?><script>setTimeout("Optimize('<?echo CUtil::JSEscape($arTable["Name"])?>')", 100);</script><? } elseif($op == "check") //otherwise step optimize { CAdminMessage::ShowMessage(array( "MESSAGE" => htmlspecialcharsbx($arTable["Name"])." - ".GetMessage("RDB_OPTIMIZE_OPTIMIZE"), "TYPE" => "PROGRESS", "PROGRESS_VALUE" => $tables_count-count($arTables), "PROGRESS_TOTAL" => $tables_count, "HTML" => true, "DETAILS" => GetMessage("RDB_OPTIMIZE_PROGRESS", array( "#done#" => $tables_count-count($arTables), "#todo#" => $tables_count, ))."#PROGRESS_BAR#", )); ?><script>setTimeout("Optimize('o|<?echo CUtil::JSEscape($arTable["Name"])?>')", 100);</script><? } elseif($op == "optimize") //and step analyze { CAdminMessage::ShowMessage(array( "MESSAGE" => htmlspecialcharsbx($arTable["Name"])." - ".GetMessage("RDB_OPTIMIZE_ANALYZE"), "TYPE" => "PROGRESS", "PROGRESS_VALUE" => $tables_count-count($arTables), "PROGRESS_TOTAL" => $tables_count, "HTML" => true, "DETAILS" => GetMessage("RDB_OPTIMIZE_PROGRESS", array( "#done#" => $tables_count-count($arTables), "#todo#" => $tables_count, ))."#PROGRESS_BAR#", )); ?><script>setTimeout("Optimize('a|<?echo CUtil::JSEscape($arTable["Name"])?>')", 100);</script><? } else { $arTable = array_shift($arTables); CAdminMessage::ShowMessage(array( "MESSAGE" => htmlspecialcharsbx($arTable["Name"]), "TYPE" => "PROGRESS", "PROGRESS_VALUE" => $tables_count-count($arTables), "PROGRESS_TOTAL" => $tables_count, "HTML" => true, "DETAILS" => GetMessage("RDB_OPTIMIZE_PROGRESS", array( "#done#" => $tables_count-count($arTables), "#todo#" => $tables_count, ))."#PROGRESS_BAR#", )); ?><script>setTimeout("Optimize('<?echo CUtil::JSEscape($arTable["Name"])?>')", 100);</script><? } } else { COption::SetOptionInt("main", "LAST_DB_OPTIMIZATION_TIME", time()); CAdminMessage::ShowMessage(array( "MESSAGE" => GetMessage("RDB_OPTIMIZE_DONE"), "TYPE" => "OK", "HTML" => true, "DETAILS" => GetMessage("RDB_OPTIMIZE_ALL_DONE"), )); ?> <script> document.getElementById('opt_start').disabled = false; document.getElementById('opt_pause').disabled = true; document.getElementById('opt_continue').disabled = true; </script> <? } } else { CAdminMessage::ShowMessage(array( "MESSAGE" => GetMessage("RDB_OPTIMIZE_ERROR"), "TYPE" => "ERROR", "HTML" => true, "DETAILS" => GetMessage("RDB_OPTIMIZE_TABLE_NOT_FOUND"), )); } } } require_once($_SERVER["DOCUMENT_ROOT"]."/bitrix/modules/main/include/epilog_admin_js.php"); } else { $APPLICATION->SetTitle(GetMessage("RDB_REPAIR_DATABASE")); require_once(__DIR__."/../include/prolog_admin_after.php"); if($DB->type == "MYSQL") { if (isset($_REQUEST["check_tables"]) && $_REQUEST["check_tables"]=="Y" && check_bitrix_sessid()) { $start = microtime(true); $result = $DB->Query('show table status'); ?> <table cellspacing="0" cellpadding="0" border="0" class="list-table" width="0%"> <tr class="head"> <td><?=GetMessage("RDB_TABLE_NAME")?></td> <td align="right"><?=GetMessage("RDB_ROWS_COUNT")?></td> <td align="right"><?=GetMessage("RDB_TABLE_SIZE")?></td> <td><?=GetMessage("RDB_CHECK_RESULT")?></td> <td><?=GetMessage("RDB_REPAIR_RESULT")?></td> </tr> <? while($arResult = $result->Fetch()) { echo "<tr>"; echo "<td>".htmlspecialcharsbx($arResult["Name"])."</td>"; echo "<td align='right'>".$arResult["Rows"]."</td>"; echo "<td align='right'>".number_format($arResult["Data_length"], 0, ',', ' ')."</td>"; if( (empty($arResult["Type"]) && $arResult["Comment"] <> '' && empty($arResult["Engine"])) || (isset($arResult["Type"]) && (mb_strtoupper($arResult["Type"]) == "MYISAM" || mb_strtoupper($arResult["Type"]) == "INNODB")) || (isset($arResult["Engine"]) && (mb_strtoupper($arResult["Engine"]) == "MYISAM" || mb_strtoupper($arResult["Engine"]) == "INNODB")) ) { echo "<td>"; $query = 'CHECK TABLE `'.$arResult["Name"].'`'; $toRepair = ""; if(($status = $DB->Query($query))) { $i=0; while($arStatus = $status->Fetch()) { if($i>0) echo "<br>"; $i++; echo "[".$arStatus["Msg_type"]."] "; if($arStatus["Msg_type"]=="status" || $arStatus["Msg_type"]=="info") echo "<span style='color:green;'>"; else echo "<span style='color:red;'>"; echo htmlspecialcharsbx($arStatus["Msg_text"])."</span>"; if($arStatus["Msg_type"]=="error" || $arStatus["Msg_type"]=="warning") $toRepair = $arResult["Name"]; } } echo "</td>"; if(!empty($toRepair)) { echo "<td>"; $j=0; $queryR = 'REPAIR TABLE `'.$toRepair.'`'; $repair = $DB->Query($queryR); $toCheck = ""; while($repair && ($arRepair = $repair->Fetch())) { if($j>0) echo "<br>"; echo "[Repair ".$arRepair["Msg_type"]."] "; if($arRepair["Msg_type"]=="status" || $arRepair["Msg_type"]=="info") echo "<span style='color:green;'>"; else echo "<span style='color:red;'>"; echo htmlspecialcharsbx($arRepair["Msg_text"])."</span>"; $j++; $toCheck = $toRepair; } if(!empty($toCheck)) { $queryC = 'CHECK TABLE `'.$toCheck.'`'; $statusC = $DB->Query($queryC); while($arStatusC = $statusC->Fetch()) { echo "<br>"; echo "[Check ".$arStatusC["Msg_type"]."] "; if($arStatusC["Msg_type"]=="status" || $arStatusC["Msg_type"]=="info") echo "<span style='color:green;'>"; else echo "<span style='color:red;'>"; echo htmlspecialcharsbx($arStatusC["Msg_text"])."</span>"; } } echo "</td>"; } else echo "<td> </td>"; } else { if(!empty($arResult["Type"])) echo "<td>".$arResult["Type"]."</td>"; else echo "<td>".$arResult["Engine"]."</td>"; echo "<td> </td>"; } echo "</tr>"; } ?> <tr class="head"><td colspan="5"><?echo "<b>".GetMessage("RDB_EXEC_TIME")." </b>".round((microtime(true)-$start),5).GetMessage("RDB_SEC");?></td></tr> </table> <? } elseif(isset($_REQUEST["optimize_tables"]) && $_REQUEST["optimize_tables"]=="Y") { ?> <?echo BeginNote(), GetMessage("RDB_OPTIMIZE_TIP"), EndNote();?> <div id="optimize_result"> <?CAdminMessage::ShowMessage(array( "MESSAGE" => GetMessage("RDB_OPTIMIZE_WARNING_TITLE"), "TYPE" => "ERROR", "HTML" => true, "DETAILS" => GetMessage("RDB_OPTIMIZE_WARNING_DETAILS"), ));?> </div> <input type="button" name="opt_start" id="opt_start" value="<?echo GetMessage("RDB_OPTIMIZE_BTN_START")?>" OnClick="Optimize('start|');"> <input type="button" name="opt_pause" id="opt_pause" value="<?echo GetMessage("RDB_OPTIMIZE_BTN_PAUSE")?>" OnClick="Pause(true);" disabled> <input type="button" name="opt_continue" id="opt_continue" value="<?echo GetMessage("RDB_OPTIMIZE_BTN_CONTINUE")?>" OnClick="Pause(false);" disabled> <script> var pause = false; function Pause(flag) { pause = flag; if(pause) { document.getElementById('opt_start').disabled = true; document.getElementById('opt_pause').disabled = true; document.getElementById('opt_continue').disabled = false; } else { document.getElementById('opt_start').disabled = true; document.getElementById('opt_pause').disabled = false; document.getElementById('opt_continue').disabled = true; } } function Optimize(table_name) { if(pause) { setTimeout("Optimize('"+table_name+"')", 500); } else { CHttpRequest.Action = function(result) { CloseWaitWindow(); document.getElementById('optimize_result').innerHTML = result; }; ShowWaitWindow(); if(table_name == 'start|') { document.getElementById('opt_start').disabled = true; document.getElementById('opt_pause').disabled = false; document.getElementById('opt_continue').disabled = true; } table_name = encodeURIComponent(table_name); table_name = table_name.replace('adv', '%61dv'); var url = 'repair_db.php?lang=<?echo LANGUAGE_ID?>&<?echo bitrix_sessid_get()?>&table_name='+table_name; CHttpRequest.Send(url); } } </script> <? } else { ?> <p><?=GetMessage("RDB_TIP_1")?></p> <?CAdminMessage::ShowMessage(array( "MESSAGE" => GetMessage("RDB_TIP_2"), "TYPE" => "ERROR", "HTML" => true, "DETAILS" => GetMessage("RDB_TIP_3"), )); ?> <form name="check" action=""> <input type="submit" value="<?=GetMessage("RDB_CHECK_TABLES")?>" class="adm-btn-save"> <input type="hidden" value="Y" name="check_tables"> <? if(!isset($_REQUEST["login"]) && !isset($_REQUEST["password"])) echo bitrix_sessid_post(); if(isset($_REQUEST["login"])) echo '<input type="hidden" value="'.htmlspecialcharsbx($_REQUEST["login"]).'" name="login">'; if(isset($_REQUEST["password"])) echo '<input type="hidden" value="'.htmlspecialcharsbx($_REQUEST["password"]).'" name="password">'; if(isset($_REQUEST["lang"])) echo '<input type="hidden" value="'.htmlspecialcharsbx($_REQUEST["lang"]).'" name="lang">'; echo '</form>'; } } else { CAdminMessage::ShowMessage(array( "MESSAGE" => GetMessage("RDB_DATABASE_ERROR"), "TYPE" => "ERROR", )); } require_once(__DIR__."/../include/epilog_admin.php"); }