64 lines
2.2 KiB
PHP
64 lines
2.2 KiB
PHP
<?
|
|
/*
|
|
Jorge - frontend for mod_logdb - ejabberd server-side message archive module.
|
|
|
|
Copyright (C) 2007 Zbigniew Zolkiewski
|
|
|
|
This program is free software; you can redistribute it and/or
|
|
modify it under the terms of the GNU General Public License
|
|
as published by the Free Software Foundation; either version 2
|
|
of the License, or (at your option) any later version.
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with this program; if not, write to the Free Software
|
|
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
*/
|
|
# This script is used for rebuilding full-text index and maintaining database performance. Run it in following conditions:
|
|
# - you changed parameters regarding full-text index
|
|
# - there were lot of deletions on tables
|
|
# - after longer period of time script was not running (it depends on your DB size)
|
|
#
|
|
# Refer to MySQL-dev documentation for info how REPAIR and OPTIMIZE statments work.
|
|
# NOTE: Edit settings below and replace all CAPSED_TEXT with proper values.
|
|
#
|
|
error_reporting(E_ERROR);
|
|
$conn=mysql_connect("_YOUR_DB_IP_ADDRESS_", "_USER_NAME_", "_PASSWORD_") or die ("DB CONNECT ERROR\n");
|
|
mysql_select_db ("_DB_NAME_") or die ("DB SELECT ERROR\n");
|
|
$query=mysql_query("show tables");
|
|
|
|
|
|
while ($result=mysql_fetch_array($query)) {
|
|
|
|
if (preg_match("/^logdb_messages_.*._REPLACE_THIS_WITH_YOUR_XMPP_HOST/i", $result[Tables_in_REPLACE_THIS_WITH_YOUR_DB_NAME])) {
|
|
$i++;
|
|
$repair="REPAIR TABLE `$result[Tables_in_REPLACE_THIS_WITH_YOUR_DB_NAME]` QUICK";
|
|
$res=mysql_query($repair);
|
|
while ($res=mysql_fetch_array($res)) {
|
|
|
|
print "Operation: $res[Op], Table: $res[Table], Status: $res[Msg_text]"."\n";
|
|
|
|
}
|
|
$optimize="OPTIMIZE TABLE `$result[Tables_in_REPLACE_THIS_WITH_YOUR_DB_NAME]`";
|
|
$res=mysql_query($optimize);
|
|
while ($res=mysql_fetch_array($res)) {
|
|
|
|
print "Operation: $res[Op], Table: $res[Table], Status: $res[Msg_text]"."\n";
|
|
|
|
}
|
|
print "--------------\n\n";
|
|
}
|
|
}
|
|
|
|
|
|
print "Finish, tables repaired: $i\n";
|
|
|
|
mysql_close();
|
|
|
|
|
|
?>
|