mpreview
Description
Use mpreview
to get an idea of the kinds of metric time series that are stored in your metrics indexes and to troubleshoot your metrics data.
mpreview
returns a preview of the raw metric data points in a specified metric index that match a provided filter. By default, mpreview
retrieves a target of five metric data points per metric time series from each metrics time-series index file (.tsidx
file) associated with the search. You can change this target amount with the target_per_timeseries
argument.
By design, mpreview
returns metric data points in JSON format.
The mpreview
command cannot search data that was indexed prior to your upgrade to the 8.0.x version of the Splunk platform.
You can use the mpreview
command only if your role has the run_msearch
capability. See Define roles on the Splunk platform with capabilities in Securing Splunk Enterprise.
Syntax
The required syntax is in bold.
- | mpreview
- [filter=<string>]
- [<index-opt>]...
- [splunk_server=<wc-string>]
- [splunk_server_group=<wc-string>]...
- [earliest=<time-specifier>]
- [latest=<time-specifier>] :
- [chunk_size=<unsigned-integer>]
- [target_per_timeseries=<unsigned-integer>]
Required arguments
None. By default all types of terms are returned.
Optional arguments
- chunk_size
- Syntax: chunk_size=<unsigned-integer>
- Description: Advanced option. This argument controls how many metric time series are retrieved at a time from a single time-series index file (
.tsidx
file) when the Splunk software processes searches. Lower this setting from its default only when you find a particularmpreview
search is using too much memory, or when it infrequently returns events. This can happen when a search groups by excessively high-cardinality dimensions (dimensions with very large amounts of distinct values). In such situations, a lowerchunk_size
value can makempreview
searches more responsive, but potentially slower to complete. A higherchunk_size
, on the other hand, can help long-running searches to complete faster, with the potential tradeoff of causing the search to be less responsive. Formpreview
,chunk_size
cannot be set lower than 10.
- For more information about this setting, see Use chunk_size to regulate mpreview performance.
- Default: 1000
For Splunk Enterprise: The default value for the the
chunk_size
argument is set by thechunk_size
setting for the[msearch]
stanza inlimits.conf
.
- earliest
- Syntax: earliest=<time-specifier>
- Description: Specify the earliest
_time
for the time range of your search. You can specify the time in the following formats:
- Exact time (in ISO8601 format). For example,
earliest="2023-09-05T11:52:43-05:00"
orearliest="2023-09-05T11:52:43.123-05:00"
. - Relative time. For example,
earliest=-h
orearliest=@w0
. - UNIX time. For example,
earliest=1696812434
.
- For more information about setting exact times see Date and time format variables. For more information about setting relative times, see Time modifiers. Subsecond options are available only if you are searching over a metrics index with millisecond timestamp resolution.
- filter
- Syntax: filter= "<string>"
- Description: An arbitrary boolean expression over the dimension or
metric_name
.
- index-opt
- Syntax: index=<index-name> (index=<index-name>)...
- Description: Limits the search to results from one or more indexes. You can use wildcard characters (*). To match non-internal indexes, use
index=*
. To match internal indexes, useindex=_*
.
- latest
- Syntax: latest=<time-specifier>
- Description: Specify the latest time for the
_time
range of your search. You can specify the time in the following formats:
- Exact time (in ISO8601 format). For example,
latest="2023-09-12T11:52:43-05:00"
orearliest="2023-09-12T11:52:43.123-05:00"
. - Relative time. For example,
latest=-30m
orlatest=@w6
. - UNIX time. For example,
latest=1699490848
.
- For more information about setting exact times see Date and time format variables. For more information about setting relative times, see Time modifiers. Subsecond options are available only if you are searching over a metrics index with millisecond timestamp resolution.
- splunk_server
- Syntax: splunk_server=<wc-string>
- Description: Specifies the distributed search peer from which to return results. If you are using Splunk Enterprise, you can specify only one
splunk_server
argument. However, you can use a wildcard when you specify the server name to indicate multiple servers. For example, you can specifysplunk_server=peer01
orsplunk_server=peer*
. Uselocal
to refer to the search head.
- splunk_server_group
- Syntax: splunk_server_group=<wc-string>
- Description: Limits the results to one or more server groups. If you are using Splunk Cloud Platform, omit this parameter. You can specify a wildcard character in the string to indicate multiple server groups.
- target_per_timeseries
- Syntax: target_per_timeseries=<unsigned-integer>
- Description Determines the target number of metric data points to retrieve per metric time series from each metrics time-series index file (
.tsidx
file) associated with thempreview
search. If a time series has less than thetarget_per_timeseries
of data points within a.tsidx
file, the search head retrieves all of the data points for that time series within that particular.tsidx
file.
If you set
target_per_timeseries
to 0 it returns all data points available within the given time range for each time series. This search will likely be very large in scale and therefore very slow to complete. If you must search on a large number of metric data points, usemstats
instead.
- For more information about this setting, see How the target_per_timeseries argument works.
- Default: 5
The default value for the the
target_per_timeseries
argument is set by thetarget_per_timeseries
setting for the[msearch]
stanza inlimits.conf
Usage
This search command generates a list of individual metric data points from a specified metric index that match a provided filter. The filter can be any arbitrary boolean expression over the dimensions or the metric_name
. Specify earliest
and latest
to override the time range picker settings.
For more information about setting earliest
and latest
, see Time modifiers.
The mpreview command is designed to display individual metric data points in JSON format. If you want to aggregate metric data points, use the mstats
command.
All metrics search commands are case sensitive. This means, for example, that mpreview
treats as the following as three distinct values of metric_name
: cap.gear
, CAP.GEAR
, and Cap.Gear
.
How the target_per_timeseries argument works
Unfiltered mpreview
searches can cover extremely large numbers of raw metric data points. In some cases the sheer number of data points covered by the search can cause such searches to be slow or unresponsive.
The target_per_timeseries
argument makes the mpreview
command more responsive while giving you a relatively broad preview of your metric data. It limits the number of metric data points that mpreview
can return from each metric time series in each .tsidx
file covered by the search.
For example, if you have 10 metrics tsidx
files that each contain 100 metric time series, and each time series has >=5 data points. If you set target_per_timeseries=5
in the search, you should expect a maximum of 10 x 100 x 5 = 5000 metric data points to be returned by the search.
On the other hand, say you have 10 metrics tsidx
files that each contain 100 metric time series, but in this case, 50 of those time series have 3 data points and the other 50 of those time series have >=5 data points. If you set target_per_timeseries=5
in the search, you should expect to get 10 x ((50 x 3) + (50 x 5)) = 4000 data points.
The target_per_timeseries
argument is especially useful when the number of metric data points covered by your mpreview
search is significantly larger than the number of metric time series covered by the search. It's not particularly helpful if the number of data points in your search are slightly larger than or equal to the number of metric time series in the search.
You can run this search to determine the number of metric data points that could potentially be covered by an mpreview
search:
| metadata index=<metric_index_name> type=hosts datatype=metric | fields totalCount
You can run this search to determine the number of metric time series that could potentially be covered by an mpreview
search:
| mstats count(*) WHERE index=<metric_index_name> by _timeseries | stats count
Use chunk_size to regulate mpreview performance
If you find that mpreview is slow or unresponsive despite the target_per_timeseries
argument you can also use chunk_size
to regulate mpreview
behavior. Reduce the chunk_size
to make the search more responsive with the potential tradeoff of making the search slower to complete. Raise the chunk_size
to help the mpreview
search to complete faster, with the potential tradeoff of making it less responsive.
Examples
1. Return data points that match a specific filter
This search returns individual data points from the _metrics
index that match a specific filter.
| mpreview index=_metrics filter="group=queue name=indexqueue metric_name=*.current_size"
Here is an example of a JSON-formatted result of the above search.
2. Return individual data points from the metrics index
| mpreview index=_metrics
3. Lower chunk_size to improve mpreview performance
The following search lowers chunk_size
so that it returns 100 metric time series worth of metric data points in batches from tsidx
files that belong to the _metrics
index. Ordinarily it would return 1000 metric time series in batches.
| mpreview index=_metrics chunk_size=100
4. Speed up an mpreview search with target_per_timeseries
The following search uses target_per_timeseries
to return a maximum of five metric data points per time series in each tsidx
file searched in the _metrics
index.
| mpreview index=_metrics target_per_timeseries=5
See also
meventcollect | msearch |
This documentation applies to the following versions of Splunk® Enterprise: 8.1.1, 8.1.2, 8.1.3, 8.1.4, 8.1.5, 8.1.6, 8.1.7, 8.1.8, 8.1.9, 8.1.10, 8.1.11, 8.1.12, 8.1.13, 8.1.14, 8.2.0, 8.2.1, 8.2.2, 8.2.3, 8.2.4, 8.2.5, 8.2.6, 8.2.7, 8.2.8, 8.2.9, 8.2.10, 8.2.11, 8.2.12, 9.0.0, 9.0.1, 9.0.2, 9.0.3, 9.0.4, 9.0.5, 9.0.6, 9.0.7, 9.0.8, 9.0.9, 9.0.10, 9.1.0, 9.1.1, 9.1.2, 9.1.3, 9.1.4, 9.1.5, 9.1.6, 9.1.7, 9.2.0, 9.2.1, 9.2.2, 9.2.3, 9.2.4
Feedback submitted, thanks!