class CommonHookHandler in DB Maintenance 8
Same name and namespace in other branches
- 7.2 src/Module/Hook/CommonHookHandler.php \Drupal\db_maintenance\Module\Hook\CommonHookHandler
- 2.0.x src/Module/Hook/CommonHookHandler.php \Drupal\db_maintenance\Module\Hook\CommonHookHandler
CommonHookHandler class.
Hierarchy
- class \Drupal\db_maintenance\Module\Hook\CommonHookHandler
Expanded class hierarchy of CommonHookHandler
1 file declares its use of CommonHookHandler
- db_maintenance.module in ./
db_maintenance.module - Module file for DB Maintenance.
File
- src/
Module/ Hook/ CommonHookHandler.php, line 17 - CommonHookHandler class.
Namespace
Drupal\db_maintenance\Module\HookView source
class CommonHookHandler {
/**
* Implements hook_help().
*/
public static function hookHelp($path, $arg) {
switch ($path) {
case 'admin/help#db_maintenance':
$output = '';
$output .= '<h3>' . t('About') . '</h3>';
$output .= '<p>' . t('DB Maintenance performs an optimization query on selected tables') . '</p>';
$output .= '<h3>' . t('Uses') . '</h3>';
$output .= '<dl>';
$output .= '<dt>' . t('MyIASM Tables') . '</dt>';
$output .= '<dd>' . t('OPTIMIZE TABLE repairs a table if it has deleted or split rows, sorts table indexes, and updates table statistics. For BDB and InnoDB, OPTIMIZE rebuilds the table.') . '</dd>';
$output .= '<dd>' . t('OPTIMIZE works best on tables with large deletions (e.g. cache or watchdog), however, MySQL will reuse old record positions, therefore in most setups, OPTIMIZE TABLE is unnecessary unless you just like defragmenting.') . '</dd>';
$output .= '<dd>' . t("The Overhead column in phpMyAdmin's database view is the most common way to determine the need of an OPTIMIZE TABLE query. It essentially shows the amount of disk space you would recover by running an optimize/defragmentation query.") . '</dd>';
$output .= '<dd><i><u>' . t('Note: MySQL locks tables while OPTIMIZE TABLE is running.') . '</u></i></dd>';
$output .= '<dt>' . t('Postgre SQL Tables') . '</dt>';
$output .= '<dd>' . t("VACUUM reclaims storage occupied by deleted tuples. In normal PostgreSQL operation, tuples that are deleted or obsoleted by an update are not physically removed from their table; they remain present until a VACUUM is done. It's therefore necessary to VACUUM periodically, especially on frequently-updated tables.") . '</dd>';
$output .= '</dl>';
return $output;
case 'admin/config/system/db_maintenance':
return t('<p>DB maintenance performs an optimization query on selected tables.</p>
<p>For MyISAM tables,
OPTIMIZE TABLE repairs a table if it has deleted or split rows, sorts table indexes,
and updates table statistics. For BDB and InnoDB, OPTIMIZE rebuilds the table. OPTIMIZE
works best on tables with large deletions (e.g. cache or watchdog), however MySQL will reuse
old record positions, therefore in most setups, OPTIMIZE TABLE is unnecessary unless you
just like defragmenting.</p><p>Note: MySQL locks tables during the time OPTIMIZE TABLE is running.</p>
<p>The Overhead column in phpMyAdmin\'s database view is the most common way to determine the
need of an OPTIMIZE TABLE query. It essentially shows the amount of disk space you would
recover by running an optimize/defragmentation query.</p>
<p>For PostgreSQL tables, VACUUM reclaims storage occupied by deleted tuples.
In normal PostgreSQL operation, tuples that are deleted or obsoleted by an update are not
physically removed from their table; they remain present until a VACUUM is done. Therefore
it\'s necessary to VACUUM periodically, especially on frequently-updated tables.</p>');
}
}
/**
* Implements hook_permission().
*/
public static function hookPermission() {
return array(
'administer db maintenance' => array(
'title' => t('Administer DB Maintenance'),
'description' => t('Select which tables to optimize during cron jobs.'),
),
);
}
/**
* Implements hook_cron().
*/
public static function hookCron() {
// Get current DateTime.
$timestamp = \Drupal::time()
->getRequestTime();
$dt = new \DateTime();
$dt
->setTimestamp($timestamp);
if (!IntervalHandler::isTimeIntervalConfirmed($dt)) {
// Do not proceed if REQUEST_TIME is not in the time interval.
return;
}
$last_run = ConfigHandler::getCronLastRun();
if (ConfigHandler::getUseTimeInterval()) {
// Adjust $last_run for 5 minutes to overcome real start time
// fluctuations. It is important when using time interval
// for not to miss the interval time frame.
$last_run -= 300;
}
$interval = $timestamp - ConfigHandler::getCronFrequency();
// Only run cron if enough time has elapsed.
if ($interval > $last_run) {
// db_maintenance_optimize_tables();
DbHandler::optimizeTables();
}
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
CommonHookHandler:: |
public static | function | Implements hook_cron(). | |
CommonHookHandler:: |
public static | function | Implements hook_help(). | |
CommonHookHandler:: |
public static | function | Implements hook_permission(). |