Files
MaxScale/maxctrl/lib/show.js
2020-02-12 08:27:48 +02:00

721 lines
24 KiB
JavaScript

/*
* Copyright (c) 2016 MariaDB Corporation Ab
*
* Use of this software is governed by the Business Source License included
* in the LICENSE.TXT file and at www.mariadb.com/bsl11.
*
* Change Date: 2024-02-10
*
* On the date above, in accordance with the Business Source License, use
* of this software will be governed by version 2 or later of the General
* Public License.
*/
require('./common.js')()
const server_fields = [
{
name: 'Server',
path: 'id',
description: 'Server name'
},
{
name: 'Address',
path: 'attributes.parameters.address',
description: 'Address where the server listens'
},
{
name: 'Port',
path: 'attributes.parameters.port',
description: 'The port on which the server listens'
},
{
name: 'State',
path: 'attributes.state',
description: 'Server state'
},
{
name: 'Version',
path: 'attributes.version_string',
description: 'Server version'
},
{
name: 'Last Event',
path: 'attributes.last_event',
description: 'The type of the latest event'
},
{
name: 'Triggered At',
path: 'attributes.triggered_at',
description: 'Time when the latest event was triggered at'
},
{
name: 'Services',
path: 'relationships.services.data[].id',
description: 'Services that use this server'
},
{
name: 'Monitors',
path: 'relationships.monitors.data[].id',
description: 'Monitors that monitor this server'
},
{
name: 'Master ID',
path: 'attributes.master_id',
description: 'The server ID of the master'
},
{
name: 'Node ID',
path: 'attributes.node_id',
description: 'The node ID of this server'
},
{
name: 'Slave Server IDs',
path: 'attributes.slaves',
description: 'List of slave server IDs'
},
{
name: 'Statistics',
path: 'attributes.statistics',
description: 'Server statistics'
},
{
name: 'Parameters',
path: 'attributes.parameters',
description: 'Server parameters'
}
]
const service_fields = [
{
name: 'Service',
path: 'id',
description: 'Service name'
},
{
name: 'Router',
path: 'attributes.router',
description: 'Router that the service uses'
},
{
name: 'State',
path: 'attributes.state',
description: 'Service state'
},
{
name: 'Started At',
path: 'attributes.started',
description: 'When the service was started'
},
{
name: 'Current Connections',
path: 'attributes.connections',
description: 'Current connection count'
},
{
name: 'Total Connections',
path: 'attributes.total_connections',
description: 'Total connection count'
},
{
name: 'Servers',
path: 'relationships.servers.data[].id',
description: 'Servers that the service uses'
},
{
name: 'Parameters',
path: 'attributes.parameters',
description: 'Service parameter'
},
{
name: 'Router Diagnostics',
path: 'attributes.router_diagnostics',
description: 'Diagnostics provided by the router module'
}
]
const monitor_fields = [
{
name: 'Monitor',
path: 'id',
description: 'Monitor name'
},
{
name: 'State',
path: 'attributes.state',
description: 'Monitor state'
},
{
name: 'Servers',
path: 'relationships.servers.data[].id',
description: 'The servers that this monitor monitors'
},
{
name: 'Parameters',
path: 'attributes.parameters',
description: 'Monitor parameters'
},
{
name: 'Monitor Diagnostics',
path: 'attributes.monitor_diagnostics',
description: 'Diagnostics provided by the monitor module'
}
]
const session_fields = [
{
name: 'Id',
path: 'id',
description: 'Session ID'
},
{
name: 'Service',
path: 'relationships.services.data[].id',
description: 'The service where the session connected'
},
{
name: 'State',
path: 'attributes.state',
description: 'Session state'
},
{
name: 'User',
path: 'attributes.user',
description: 'Username'
},
{
name: 'Host',
path: 'attributes.remote',
description: 'Client host address'
},
{
name: 'Connected',
path: 'attributes.connected',
description: 'Time when the session started'
},
{
name: 'Idle',
path: 'attributes.idle',
description: 'How long the session has been idle, in seconds'
},
{
name: 'Connections',
path: 'attributes.connections[].server',
description: 'Ordered list of backend connections'
},
{
name: 'Connection IDs',
path: 'attributes.connections[].protocol_diagnostics.connection_id',
description: 'Thread IDs for the backend connections'
},
{
name: 'Queries',
path: 'attributes.queries[].statement',
description: 'Query history'
},
{
name: 'Log',
path: 'attributes.log',
description: 'Per-session log messages'
}
]
const filter_fields = [
{
name: 'Filter',
path: 'id',
description: 'Filter name'
},
{
name: 'Module',
path: 'attributes.module',
description: 'The module that the filter uses'
},
{
name: 'Services',
path: 'relationships.services.data[].id',
description: 'Services that use the filter'
},
{
name: 'Parameters',
path: 'attributes.parameters',
description: 'Filter parameters'
}
]
const module_fields = [
{
name: 'Module',
path: 'id',
description: 'Module name'
},
{
name: 'Type',
path: 'attributes.module_type',
description: 'Module type'
},
{
name: 'Version',
path: 'attributes.version',
description: 'Module version'
},
{
name: 'Maturity',
path: 'attributes.maturity',
description: 'Module maturity'
},
{
name: 'Description',
path: 'attributes.description',
description: 'Short description about the module'
},
{
name: 'Parameters',
path: 'attributes.parameters',
description: 'All the parameters that the module accepts'
},
{
name: 'Commands',
path: 'attributes.commands',
description: 'Commands that the module provides'
}
]
const thread_fields = [
{
name: 'Id',
path: 'id',
description: 'Thread ID'
},
{
name: 'Accepts',
path: 'attributes.stats.accepts',
description: 'Number of TCP accepts done by this thread'
},
{
name: 'Reads',
path: 'attributes.stats.reads',
description: 'Number of EPOLLIN events'
},
{
name: 'Writes',
path: 'attributes.stats.writes',
description: 'Number of EPOLLOUT events'
},
{
name: 'Hangups',
path: 'attributes.stats.hangups',
description: 'Number of EPOLLHUP and EPOLLRDUP events'
},
{
name: 'Errors',
path: 'attributes.stats.errors',
description: 'Number of EPOLLERR events'
},
{
name: 'Avg event queue length',
path: 'attributes.stats.avg_event_queue_length',
description: 'Average number of events returned by one epoll_wait call'
},
{
name: 'Max event queue length',
path: 'attributes.stats.max_event_queue_length',
description: 'Maximum number of events returned by one epoll_wait call'
},
{
name: 'Max exec time',
path: 'attributes.stats.max_exec_time',
description: 'The longest time spent processing events returned by a epoll_wait call'
},
{
name: 'Max queue time',
path: 'attributes.stats.max_queue_time',
description: 'The longest time an event had to wait before it was processed'
},
{
name: 'Current FDs',
path: 'attributes.stats.current_descriptors',
description: 'Current number of managed file descriptors'
},
{
name: 'Total FDs',
path: 'attributes.stats.total_descriptors',
description: 'Total number of managed file descriptors'
},
{
name: 'Load (1s)',
path: 'attributes.stats.load.last_second',
description: 'Load percentage over the last second'
},
{
name: 'Load (1m)',
path: 'attributes.stats.load.last_minute',
description: 'Load percentage over the last minute'
},
{
name: 'Load (1h)',
path: 'attributes.stats.load.last_hour',
description: 'Load percentage over the last hour'
},
{
name: 'QC cache size',
path: 'attributes.stats.query_classifier_cache.size',
description: 'Query classifier size'
},
{
name: 'QC cache inserts',
path: 'attributes.stats.query_classifier_cache.inserts',
description: 'Number of times a new query was added into the query classification cache'
},
{
name: 'QC cache hits',
path: 'attributes.stats.query_classifier_cache.hits',
description: 'How many times a query classification was found in the query classification cache'
},
{
name: 'QC cache misses',
path: 'attributes.stats.query_classifier_cache.misses',
description: 'How many times a query classification was not found in the query classification cache'
},
{
name: 'QC cache evictions',
path: 'attributes.stats.query_classifier_cache.evictions',
description: 'How many times a query classification result was evicted from the query classification cache'
},
]
const show_maxscale_fields = [
{
name: 'Version',
path: 'attributes.version',
description: 'MaxScale version'
},
{
name: 'Commit',
path: 'attributes.commit',
description: 'MaxScale commit ID'
},
{
name: 'Started At',
path: 'attributes.started_at',
description: 'Time when MaxScale was started'
},
{
name: 'Activated At',
path: 'attributes.activated_at',
description: 'Time when MaxScale left passive mode'
},
{
name: 'Uptime',
path: 'attributes.uptime',
description: 'Time MaxScale has been running'
},
{
name: 'Parameters',
path: 'attributes.parameters',
description: 'Global MaxScale parameters'
}
]
const show_logging_fields = [
{
name: 'Current Log File',
path: 'attributes.log_file',
description: 'The current log file MaxScale is logging into'
},
{
name: 'Enabled Log Levels',
path: 'attributes.log_priorities',
description: 'List of log levels enabled in MaxScale'
},
{
name: 'Parameters',
path: 'attributes.parameters',
description: 'Logging parameters'
}
]
const show_commands_fields = [
{
name: 'Command',
path: 'id',
description: 'Command name'
},
{
name: 'Parameters',
path: 'attributes.parameters[].type',
description: 'Parameters the command supports'
},
{
name: 'Descriptions',
path: 'attributes.parameters[].description',
description: 'Parameter descriptions'
}
]
const qc_cache_fields = [
{
name: 'Statement',
path: 'id',
description: 'The canonical form of the SQL statement'
},
{
name: 'Hits',
path: 'attributes.hits',
description: 'Number of times cache entry has been used'
},
{
name: 'Type',
path: 'attributes.classification.type_mask',
description: 'Query type'
}
]
const show_dbusers_fields = [
{
name: 'Users',
path: 'attributes.authenticator_diagnostics[]',
description: 'The list of users'
},
{
name: 'Listener',
path: 'id',
description: 'Listener name'
},
{
name: 'Authenticator',
path: 'attributes.parameters.authenticator',
description: 'The authenticator used by the listener'
}
]
exports.command = 'show <command>'
exports.desc = 'Show objects'
exports.handler = function() {}
exports.builder = function(yargs) {
yargs
.command('server <server>', 'Show server', function(yargs) {
return yargs.epilog('Show detailed information about a server. The `Parameters` ' +
'field contains the currently configured parameters for this ' +
'server. See `help alter server` for more details about altering ' +
'server parameters.' + fieldDescriptions(server_fields))
.wrap(null)
.usage('Usage: show server <server>')
}, function(argv) {
maxctrl(argv, function(host) {
return getResource(host, 'servers/' + argv.server, server_fields)
})
})
.command('servers', 'Show all servers', function(yargs) {
return yargs.epilog('Show detailed information about all servers.' +
fieldDescriptions(server_fields))
.wrap(null)
.usage('Usage: show servers')
}, function(argv) {
maxctrl(argv, function(host) {
return getCollectionAsResource(host, 'servers/', server_fields)
})
})
.command('service <service>', 'Show service', function(yargs) {
return yargs.epilog('Show detailed information about a service. The `Parameters` ' +
'field contains the currently configured parameters for this ' +
'service. See `help alter service` for more details about altering ' +
'service parameters.' + fieldDescriptions(service_fields))
.wrap(null)
.usage('Usage: show service <service>')
}, function(argv) {
maxctrl(argv, function(host) {
return getResource(host, 'services/' + argv.service, service_fields)
})
})
.command('services', 'Show all services', function(yargs) {
return yargs.epilog('Show detailed information about all services.' +
fieldDescriptions(service_fields))
.wrap(null)
.usage('Usage: show services')
}, function(argv) {
maxctrl(argv, function(host) {
return getCollectionAsResource(host, 'services/', service_fields)
})
})
.command('monitor <monitor>', 'Show monitor', function(yargs) {
return yargs.epilog('Show detailed information about a monitor. The `Parameters` ' +
'field contains the currently configured parameters for this ' +
'monitor. See `help alter monitor` for more details about altering ' +
'monitor parameters.' + fieldDescriptions(monitor_fields))
.wrap(null)
.usage('Usage: show monitor <monitor>')
}, function(argv) {
maxctrl(argv, function(host) {
return getResource(host, 'monitors/' + argv.monitor, monitor_fields)
})
})
.command('monitors', 'Show all monitors', function(yargs) {
return yargs.epilog('Show detailed information about all monitors.' +
fieldDescriptions(monitor_fields))
.wrap(null)
.usage('Usage: show monitors')
}, function(argv) {
maxctrl(argv, function(host) {
return getCollectionAsResource(host, 'monitors/', monitor_fields)
})
})
.command('session <session>', 'Show session', function(yargs) {
return yargs.epilog('Show detailed information about a single session. ' +
'The list of sessions can be retrieved with the ' +
'`list sessions` command. The <session> is the session ' +
'ID of a particular session.\n\n' +
'The `Connections` field lists the servers to which ' +
'the session is connected and the `Connection IDs` ' +
'field lists the IDs for those connections.' +
fieldDescriptions(session_fields))
.wrap(null)
.usage('Usage: show session <session>')
.group([rDnsOption.shortname], 'Options:')
.option(rDnsOption.shortname, rDnsOption.definition)
}, function(argv) {
maxctrl(argv, function(host) {
var resource = 'sessions/' + argv.session
if (argv[this.rDnsOption.shortname]) {
resource += '?' + this.rDnsOption.optionOn
}
return getResource(host, resource, session_fields)
})
})
.command('sessions', 'Show all sessions', function(yargs) {
return yargs.epilog('Show detailed information about all sessions. ' +
'See `help show session` for more details.' +
fieldDescriptions(session_fields))
.wrap(null)
.usage('Usage: show sessions')
.group([rDnsOption.shortname], 'Options:')
.option(rDnsOption.shortname, rDnsOption.definition)
}, function(argv) {
maxctrl(argv, function(host) {
var resource = 'sessions/'
if (argv[this.rDnsOption.shortname]) {
resource += '?' + this.rDnsOption.optionOn
}
return getCollectionAsResource(host, resource, session_fields)
})
})
.command('filter <filter>', 'Show filter', function(yargs) {
return yargs.epilog('The list of services that use this filter is show in the `Services` field.' +
fieldDescriptions(filter_fields))
.wrap(null)
.usage('Usage: show filter <filter>')
}, function(argv) {
maxctrl(argv, function(host) {
return getResource(host, 'filters/' + argv.filter, filter_fields)
})
})
.command('filters', 'Show all filters', function(yargs) {
return yargs.epilog('Show detailed information of all filters.' +
fieldDescriptions(filter_fields))
.wrap(null)
.usage('Usage: show filters')
}, function(argv) {
maxctrl(argv, function(host) {
return getCollectionAsResource(host, 'filters/', filter_fields)
})
})
.command('module <module>', 'Show loaded module', function(yargs) {
return yargs.epilog('This command shows all available parameters as well as ' +
'detailed version information of a loaded module.' +
fieldDescriptions(module_fields))
.wrap(null)
.usage('Usage: show module <module>')
}, function(argv) {
maxctrl(argv, function(host) {
return getResource(host, 'maxscale/modules/' + argv.module, module_fields)
})
})
.command('modules', 'Show all loaded modules', function(yargs) {
return yargs.epilog('Displays detailed information about all modules.' +
fieldDescriptions(module_fields))
.wrap(null)
.usage('Usage: show modules')
}, function(argv) {
maxctrl(argv, function(host) {
return getCollectionAsResource(host, 'maxscale/modules/', module_fields)
})
})
.command('maxscale', 'Show MaxScale information', function(yargs) {
return yargs.epilog('See `help alter maxscale` for more details about altering ' +
'MaxScale parameters.' + fieldDescriptions(show_maxscale_fields))
.wrap(null)
.usage('Usage: show maxscale')
}, function(argv) {
maxctrl(argv, function(host) {
return getResource(host, 'maxscale', show_maxscale_fields)
})
})
.command('thread <thread>', 'Show thread', function(yargs) {
return yargs.epilog('Show detailed information about a worker thread.' +
fieldDescriptions(thread_fields))
.wrap(null)
.usage('Usage: show thread <thread>')
}, function(argv) {
maxctrl(argv, function(host) {
return getResource(host, 'maxscale/threads/' + argv.thread, thread_fields)
})
})
.command('threads', 'Show all threads', function(yargs) {
return yargs.epilog('Show detailed information about all worker threads.' +
fieldDescriptions(thread_fields))
.wrap(null)
.usage('Usage: show threads')
}, function(argv) {
maxctrl(argv, function(host) {
return getCollectionAsResource(host, 'maxscale/threads', thread_fields)
})
})
.command('logging', 'Show MaxScale logging information', function(yargs) {
return yargs.epilog('See `help alter logging` for more details about altering ' +
'logging parameters.' + fieldDescriptions(show_logging_fields))
.wrap(null)
.usage('Usage: show logging')
}, function(argv) {
maxctrl(argv, function(host) {
return getResource(host, 'maxscale/logs', show_logging_fields)
})
})
.command('commands <module>', 'Show module commands of a module', function(yargs) {
return yargs.epilog('This command shows the parameters the command expects with ' +
'the parameter descriptions.' + fieldDescriptions(show_commands_fields))
.wrap(null)
.usage('Usage: show commands <module>')
}, function(argv) {
maxctrl(argv, function(host) {
return getSubCollection(host, 'maxscale/modules/' + argv.module, 'attributes.commands',
show_commands_fields)
})
})
.command('qc_cache', 'Show query classifier cache', function(yargs) {
return yargs.epilog('Show contents (statement and hits) of query classifier cache.')
.wrap(null)
.usage('Usage: show qc_cache')
}, function(argv) {
maxctrl(argv, function(host) {
return getCollection(host, 'maxscale/query_classifier/cache', qc_cache_fields)
})
})
.command('dbusers <service>', 'Show database users of the service', function(yargs) {
return yargs.epilog('Show information about the database users of the service')
.wrap(null)
.usage('Usage: show dbusers <service>')
}, function(argv) {
maxctrl(argv, function(host) {
return getSubCollection(host, 'services/' + argv.service, 'attributes.listeners[]', show_dbusers_fields)
})
})
.wrap(null)
.usage('Usage: show <command>')
.help()
.command('*', 'the default command', {}, function(argv) {
maxctrl(argv, function(host) {
return error('Unknown command. See output of `help show` for a list of commands.')
})
})
}