summaryrefslogtreecommitdiff
path: root/hugo/server_status.php
diff options
context:
space:
mode:
authorTristan Zur <tzur@web.web.ccwn.org>2014-03-27 22:27:47 +0100
committerTristan Zur <tzur@web.web.ccwn.org>2014-03-27 22:27:47 +0100
commitb62676ca5d3d6f6ba3f019ea3f99722e165a98d8 (patch)
tree86722cb80f07d4569f90088eeaea2fc2f6e2ef94 /hugo/server_status.php
Initial commit of intern.ccwn.org contentsHEADmaster
Diffstat (limited to 'hugo/server_status.php')
-rw-r--r--hugo/server_status.php496
1 files changed, 496 insertions, 0 deletions
diff --git a/hugo/server_status.php b/hugo/server_status.php
new file mode 100644
index 0000000..1db92fa
--- /dev/null
+++ b/hugo/server_status.php
@@ -0,0 +1,496 @@
+<?php
+/* vim: set expandtab sw=4 ts=4 sts=4: */
+/**
+ * object the server status page: processes, connections and traffic
+ *
+ * @package PhpMyAdmin
+ */
+
+require_once 'libraries/common.inc.php';
+require_once 'libraries/server_common.inc.php';
+require_once 'libraries/ServerStatusData.class.php';
+
+/**
+ * Replication library
+ */
+if (PMA_DRIZZLE) {
+ $server_master_status = false;
+ $server_slave_status = false;
+} else {
+ include_once 'libraries/replication.inc.php';
+ include_once 'libraries/replication_gui.lib.php';
+}
+
+$ServerStatusData = new PMA_ServerStatusData();
+
+/**
+ * Kills a selected process
+ */
+if (! empty($_REQUEST['kill'])) {
+ if (PMA_DBI_try_query('KILL ' . $_REQUEST['kill'] . ';')) {
+ $message = PMA_Message::success(__('Thread %s was successfully killed.'));
+ } else {
+ $message = PMA_Message::error(
+ __(
+ 'phpMyAdmin was unable to kill thread %s.'
+ . ' It probably has already been closed.'
+ )
+ );
+ }
+ $message->addParam($_REQUEST['kill']);
+}
+
+/**
+ * start output
+ */
+$response = PMA_Response::getInstance();
+$response->addHTML('<div>');
+$response->addHTML($ServerStatusData->getMenuHtml());
+$response->addHTML(getServerTrafficHtml($ServerStatusData));
+$response->addHTML('</div>');
+
+exit;
+
+/**
+ * Prints server traffic information
+ *
+ * @param Object $ServerStatusData An instance of the PMA_ServerStatusData class
+ *
+ * @return string
+ */
+function getServerTrafficHtml($ServerStatusData)
+{
+ $hour_factor = 3600 / $ServerStatusData->status['Uptime'];
+ $start_time = PMA_DBI_fetch_value(
+ 'SELECT UNIX_TIMESTAMP() - ' . $ServerStatusData->status['Uptime']
+ );
+
+ $retval = '<h3>';
+ $retval .= sprintf(
+ __('Network traffic since startup: %s'),
+ implode(
+ ' ',
+ PMA_Util::formatByteDown(
+ $ServerStatusData->status['Bytes_received'] + $ServerStatusData->status['Bytes_sent'],
+ 3,
+ 1
+ )
+ )
+ );
+ $retval .= '</h3>';
+ $retval .= '<p>';
+ $retval .= sprintf(
+ __('This MySQL server has been running for %1$s. It started up on %2$s.'),
+ PMA_Util::timespanFormat($ServerStatusData->status['Uptime']),
+ PMA_Util::localisedDate($start_time)
+ ) . "\n";
+ $retval .= '</p>';
+
+ if ($GLOBALS['server_master_status'] || $GLOBALS['server_slave_status']) {
+ $retval .= '<p class="notice">';
+ if ($GLOBALS['server_master_status'] && $GLOBALS['server_slave_status']) {
+ $retval .= __(
+ 'This MySQL server works as <b>master</b> and '
+ . '<b>slave</b> in <b>replication</b> process.'
+ );
+ } elseif ($GLOBALS['server_master_status']) {
+ $retval .= __(
+ 'This MySQL server works as <b>master</b> '
+ . 'in <b>replication</b> process.'
+ );
+ } elseif ($GLOBALS['server_slave_status']) {
+ $retval .= __(
+ 'This MySQL server works as <b>slave</b> '
+ . 'in <b>replication</b> process.'
+ );
+ }
+ $retval .= ' ';
+ $retval .= __(
+ 'For further information about replication status on the server, '
+ . 'please visit the <a href="#replication">replication section</a>.'
+ );
+ $retval .= '</p>';
+ }
+
+ /*
+ * if the server works as master or slave in replication process,
+ * display useful information
+ */
+ if ($GLOBALS['server_master_status'] || $GLOBALS['server_slave_status']) {
+ $retval .= '<hr class="clearfloat" />';
+ $retval .= '<h3><a name="replication">';
+ $retval .= __('Replication status');
+ $retval .= '</a></h3>';
+ foreach ($GLOBALS['replication_types'] as $type) {
+ if (isset(${"server_{$type}_status"}) && ${"server_{$type}_status"}) {
+ PMA_replication_print_status_table($type);
+ }
+ }
+ }
+
+ $retval .= '<table id="serverstatustraffic" class="data noclick">';
+ $retval .= '<thead>';
+ $retval .= '<tr>';
+ $retval .= '<th colspan="2">';
+ $retval .= __('Traffic') . '&nbsp;';
+ $retval .= PMA_Util::showHint(
+ __(
+ 'On a busy server, the byte counters may overrun, so those statistics '
+ . 'as reported by the MySQL server may be incorrect.'
+ )
+ );
+ $retval .= '</th>';
+ $retval .= '<th>&oslash; ' . __('per hour') . '</th>';
+ $retval .= '</tr>';
+ $retval .= '</thead>';
+ $retval .= '<tbody>';
+ $retval .= '<tr class="odd">';
+ $retval .= '<th class="name">' . __('Received') . '</th>';
+ $retval .= '<td class="value">';
+ $retval .= implode(
+ ' ',
+ PMA_Util::formatByteDown(
+ $ServerStatusData->status['Bytes_received'], 3, 1
+ )
+ );
+ $retval .= '</td>';
+ $retval .= '<td class="value">';
+ $retval .= implode(
+ ' ',
+ PMA_Util::formatByteDown(
+ $ServerStatusData->status['Bytes_received'] * $hour_factor, 3, 1
+ )
+ );
+ $retval .= '</td>';
+ $retval .= '</tr>';
+ $retval .= '<tr class="even">';
+ $retval .= '<th class="name">' . __('Sent') . '</th>';
+ $retval .= '<td class="value">';
+ $retval .= implode(
+ ' ',
+ PMA_Util::formatByteDown(
+ $ServerStatusData->status['Bytes_sent'], 3, 1
+ )
+ );
+ $retval .= '</td>';
+ $retval .= '<td class="value"><?php echo';
+ $retval .= implode(
+ ' ',
+ PMA_Util::formatByteDown(
+ $ServerStatusData->status['Bytes_sent'] * $hour_factor, 3, 1
+ )
+ );
+ $retval .= '</td>';
+ $retval .= '</tr>';
+ $retval .= '<tr class="odd">';
+ $retval .= '<th class="name">' . __('Total') . '</th>';
+ $retval .= '<td class="value">';
+ $retval .= implode(
+ ' ',
+ PMA_Util::formatByteDown(
+ $ServerStatusData->status['Bytes_received'] + $ServerStatusData->status['Bytes_sent'], 3, 1
+ )
+ );
+ $retval .= '</td>';
+ $retval .= '<td class="value">';
+ $retval .= implode(
+ ' ',
+ PMA_Util::formatByteDown(
+ ($ServerStatusData->status['Bytes_received'] + $ServerStatusData->status['Bytes_sent'])
+ * $hour_factor, 3, 1
+ )
+ );
+ $retval .= '</td>';
+ $retval .= '</tr>';
+ $retval .= '</tbody>';
+ $retval .= '</table>';
+
+ $retval .= '<table id="serverstatusconnections" class="data noclick">';
+ $retval .= '<thead>';
+ $retval .= '<tr>';
+ $retval .= '<th colspan="2">' . __('Connections') . '</th>';
+ $retval .= '<th>&oslash; ' . __('per hour') . '</th>';
+ $retval .= '<th>%</th>';
+ $retval .= '</tr>';
+ $retval .= '</thead>';
+ $retval .= '<tbody>';
+ $retval .= '<tr class="odd">';
+ $retval .= '<th class="name">' . __('max. concurrent connections') . '</th>';
+ $retval .= '<td class="value">';
+ $retval .= PMA_Util::formatNumber(
+ $ServerStatusData->status['Max_used_connections'], 0
+ );
+ $retval .= '</td>';
+ $retval .= '<td class="value">--- </td>';
+ $retval .= '<td class="value">--- </td>';
+ $retval .= '</tr>';
+ $retval .= '<tr class="even">';
+ $retval .= '<th class="name">' . __('Failed attempts') . '</th>';
+ $retval .= '<td class="value">';
+ $retval .= PMA_Util::formatNumber(
+ $ServerStatusData->status['Aborted_connects'], 4, 1, true
+ );
+ $retval .= '</td>';
+ $retval .= '<td class="value">';
+ $retval .= PMA_Util::formatNumber(
+ $ServerStatusData->status['Aborted_connects'] * $hour_factor, 4, 2, true
+ );
+ $retval .= '</td>';
+ $retval .= '<td class="value">';
+ if ($ServerStatusData->status['Connections'] > 0) {
+ $retval .= PMA_Util::formatNumber(
+ $ServerStatusData->status['Aborted_connects'] * 100 / $ServerStatusData->status['Connections'],
+ 0, 2, true
+ );
+ $retval .= '%';
+ } else {
+ $retval .= '--- ';
+ }
+ $retval .= '</td>';
+ $retval .= '</tr>';
+ $retval .= '<tr class="odd">';
+ $retval .= '<th class="name">' . __('Aborted') . '</th>';
+ $retval .= '<td class="value">';
+ $retval .= PMA_Util::formatNumber(
+ $ServerStatusData->status['Aborted_clients'], 4, 1, true
+ );
+ $retval .= '</td>';
+ $retval .= '<td class="value">';
+ $retval .= PMA_Util::formatNumber(
+ $ServerStatusData->status['Aborted_clients'] * $hour_factor, 4, 2, true
+ );
+ $retval .= '</td>';
+ $retval .= '<td class="value">';
+ if ($ServerStatusData->status['Connections'] > 0) {
+ $retval .= PMA_Util::formatNumber(
+ $ServerStatusData->status['Aborted_clients'] * 100 / $ServerStatusData->status['Connections'],
+ 0, 2, true
+ );
+ $retval .= '%';
+ } else {
+ $retval .= '--- ';
+ }
+ $retval .= '</td>';
+ $retval .= '</tr>';
+ $retval .= '<tr class="even">';
+ $retval .= '<th class="name">' . __('Total') . '</th>';
+ $retval .= '<td class="value">';
+ $retval .= PMA_Util::formatNumber(
+ $ServerStatusData->status['Connections'], 4, 0
+ );
+ $retval .= '</td>';
+ $retval .= '<td class="value">';
+ $retval .= PMA_Util::formatNumber(
+ $ServerStatusData->status['Connections'] * $hour_factor, 4, 2
+ );
+ $retval .= '</td>';
+ $retval .= '<td class="value">';
+ $retval .= PMA_Util::formatNumber(100, 0, 2);
+ $retval .= '%</td>';
+ $retval .= '</tr>';
+ $retval .= '</tbody>';
+ $retval .= '</table>';
+
+ $url_params = array();
+
+ $show_full_sql = ! empty($_REQUEST['full']);
+ if ($show_full_sql) {
+ $url_params['full'] = 1;
+ $full_text_link = 'server_status.php' . PMA_generate_common_url(
+ array(), 'html', '?'
+ );
+ } else {
+ $full_text_link = 'server_status.php' . PMA_generate_common_url(
+ array('full' => 1)
+ );
+ }
+
+ // This array contains display name and real column name of each
+ // sortable column in the table
+ $sortable_columns = array(
+ array(
+ 'column_name' => __('ID'),
+ 'order_by_field' => 'Id'
+ ),
+ array(
+ 'column_name' => __('User'),
+ 'order_by_field' => 'User'
+ ),
+ array(
+ 'column_name' => __('Host'),
+ 'order_by_field' => 'Host'
+ ),
+ array(
+ 'column_name' => __('Database'),
+ 'order_by_field' => 'db'
+ ),
+ array(
+ 'column_name' => __('Command'),
+ 'order_by_field' => 'Command'
+ ),
+ array(
+ 'column_name' => __('Time'),
+ 'order_by_field' => 'Time'
+ ),
+ array(
+ 'column_name' => __('Status'),
+ 'order_by_field' => 'State'
+ ),
+ array(
+ 'column_name' => __('SQL query'),
+ 'order_by_field' => 'Info'
+ )
+ );
+ $sortable_columns_count = count($sortable_columns);
+
+ if (PMA_DRIZZLE) {
+ $sql_query = "SELECT
+ p.id AS Id,
+ p.username AS User,
+ p.host AS Host,
+ p.db AS db,
+ p.command AS Command,
+ p.time AS Time,
+ p.state AS State,
+ " . ($show_full_sql ? 's.query' : 'left(p.info, ' . (int)$GLOBALS['cfg']['MaxCharactersInDisplayedSQL'] . ')') . " AS Info
+ FROM data_dictionary.PROCESSLIST p
+ " . ($show_full_sql ? 'LEFT JOIN data_dictionary.SESSIONS s ON s.session_id = p.id' : '');
+ if (! empty($_REQUEST['order_by_field'])
+ && ! empty($_REQUEST['sort_order'])
+ ) {
+ $sql_query .= ' ORDER BY p.' . $_REQUEST['order_by_field'] . ' ' . $_REQUEST['sort_order'];
+ }
+ } else {
+ $sql_query = $show_full_sql
+ ? 'SHOW FULL PROCESSLIST'
+ : 'SHOW PROCESSLIST';
+ if (! empty($_REQUEST['order_by_field'])
+ && ! empty($_REQUEST['sort_order'])
+ ) {
+ $sql_query = 'SELECT * FROM `INFORMATION_SCHEMA`.`PROCESSLIST` ORDER BY `'
+ . $_REQUEST['order_by_field'] . '` ' . $_REQUEST['sort_order'];
+ }
+ }
+
+ $result = PMA_DBI_query($sql_query);
+
+ /**
+ * Displays the page
+ */
+ $retval .= '<table id="tableprocesslist" class="data clearfloat noclick sortable">';
+ $retval .= '<thead>';
+ $retval .= '<tr>';
+ $retval .= '<th>' . __('Processes') . '</th>';
+ foreach ($sortable_columns as $column) {
+
+ $is_sorted = ! empty($_REQUEST['order_by_field'])
+ && ! empty($_REQUEST['sort_order'])
+ && ($_REQUEST['order_by_field'] == $column['order_by_field']);
+
+ $column['sort_order'] = 'ASC';
+ if ($is_sorted && $_REQUEST['sort_order'] === 'ASC') {
+ $column['sort_order'] = 'DESC';
+ }
+
+ if ($is_sorted) {
+ if ($_REQUEST['sort_order'] == 'ASC') {
+ $asc_display_style = 'inline';
+ $desc_display_style = 'none';
+ } elseif ($_REQUEST['sort_order'] == 'DESC') {
+ $desc_display_style = 'inline';
+ $asc_display_style = 'none';
+ }
+ }
+
+ $retval .= '<th>';
+ $retval .= '<a href="server_status.php' . PMA_generate_common_url($column) . '" ';
+ if ($is_sorted) {
+ $retval .= 'onmouseout="$(\'.soimg\').toggle()" '
+ . 'onmouseover="$(\'.soimg\').toggle()"';
+ }
+ $retval .= '>';
+
+ $retval .= $column['column_name'];
+
+ if ($is_sorted) {
+ $retval .= '<img class="icon ic_s_desc soimg" alt="'
+ . __('Descending') . '" title="" src="themes/dot.gif" '
+ . 'style="display: ' . $desc_display_style . '" />';
+ $retval .= '<img class="icon ic_s_asc soimg hide" alt="'
+ . __('Ascending') . '" title="" src="themes/dot.gif" '
+ . 'style="display: ' . $asc_display_style . '" />';
+ }
+
+ $retval .= '</a>';
+
+ if (! PMA_DRIZZLE && (0 === --$sortable_columns_count)) {
+ $retval .= '<a href="' . $full_text_link . '">';
+ if ($show_full_sql) {
+ $retval .= PMA_Util::getImage(
+ 's_partialtext.png',
+ __('Truncate Shown Queries')
+ );
+ } else {
+ $retval .= PMA_Util::getImage(
+ 's_fulltext.png',
+ __('Show Full Queries')
+ );
+ }
+ $retval .= '</a>';
+ }
+ $retval .= '</th>';
+ }
+
+ $retval .= '</tr>';
+ $retval .= '</thead>';
+ $retval .= '<tbody>';
+
+ $odd_row = true;
+ while ($process = PMA_DBI_fetch_assoc($result)) {
+
+ // Array keys need to modify due to the way it has used
+ // to display column values
+ if (! empty($_REQUEST['order_by_field'])
+ && ! empty($_REQUEST['sort_order'])
+ ) {
+ foreach (array_keys($process) as $key) {
+ $new_key = ucfirst(strtolower($key));
+ $process[$new_key] = $process[$key];
+ unset($process[$key]);
+ }
+ }
+
+ $url_params['kill'] = $process['Id'];
+ $kill_process = 'server_status.php' . PMA_generate_common_url($url_params);
+
+ $retval .= '<tr class="' . ($odd_row ? 'odd' : 'even') . '">';
+ $retval .= '<td><a href="' . $kill_process . '">' . __('Kill') . '</a></td>';
+ $retval .= '<td class="value">' . $process['Id'] . '</td>';
+ $retval .= '<td>' . htmlspecialchars($process['User']) . '</td>';
+ $retval .= '<td>' . htmlspecialchars($process['Host']) . '</td>';
+ $retval .= '<td>' . ((! isset($process['db']) || ! strlen($process['db'])) ? '<i>' . __('None') . '</i>' : htmlspecialchars($process['db'])) . '</td>';
+ $retval .= '<td>' . htmlspecialchars($process['Command']) . '</td>';
+ $retval .= '<td class="value">' . $process['Time'] . '</td>';
+ $retval .= '<td>' . (empty($process['State']) ? '---' : $process['State']) . '</td>';
+ $retval .= '<td>';
+
+ if (empty($process['Info'])) {
+ $retval .= '---';
+ } else {
+ if (! $show_full_sql && strlen($process['Info']) > $GLOBALS['cfg']['MaxCharactersInDisplayedSQL']) {
+ $retval .= htmlspecialchars(substr($process['Info'], 0, $GLOBALS['cfg']['MaxCharactersInDisplayedSQL'])) . '[...]';
+ } else {
+ $retval .= PMA_SQP_formatHtml(PMA_SQP_parse($process['Info']));
+ }
+ }
+ $retval .= '</td>';
+ $retval .= '</tr>';
+ $odd_row = ! $odd_row;
+ }
+ $retval .= '</tbody>';
+ $retval .= '</table>';
+
+ return $retval;
+}
+
+?>