Monitor Type: collectd/solr
(Source)
Accepts Endpoints: Yes
Multiple Instances Allowed: Yes
Monitors Solr instances by using the collectd Solr plugin. Supports Solr 6.6 and later.
NOTE: This plugin can collect metrics from Solr only when a Solr instance is running in SolrCloud mode
The solr-collectd plugin collects metrics from solr instances hitting these endpoints:
- statistics (default metrics)
- metrics (optional metrics)
monitors:
- type: collectd/solr
host: 127.0.0.1
port: 8983
To activate this monitor in the Smart Agent, add the following to your agent config:
monitors: # All monitor config goes under this key
- type: collectd/solr
... # Additional config
For a list of monitor options that are common to all monitors, see Common Configuration.
Config option | Required | Type | Description |
---|---|---|---|
pythonBinary |
no | string |
Path to a python binary that should be used to execute the Python code. If not set, a built-in runtime will be used. Can include arguments to the binary as well. |
host |
yes | string |
|
port |
yes | integer |
|
cluster |
no | string |
Cluster name of this solr cluster. |
enhancedMetrics |
no | bool |
EnhancedMetrics boolean to indicate whether stats from /metrics are needed (default: false ) |
includeMetrics |
no | list of strings |
IncludeMetrics metric names from the /admin/metrics endpoint to include (valid when EnhancedMetrics is "false") |
excludeMetrics |
no | list of strings |
ExcludeMetrics metric names from the /admin/metrics endpoint to exclude (valid when EnhancedMetrics is "true") |
These are the metrics available for this monitor. Metrics that are categorized as container/host (default) are in bold and italics in the list below.
counter.solr.http_2xx_responses
(counter)
Total number of 2xx http responsescounter.solr.http_4xx_responses
(counter)
Total number of 4xx http responsescounter.solr.http_5xx_responses
(counter)
Total number of 5xx http responsescounter.solr.http_requests
(counter)
Total number of http requestscounter.solr.jvm_classes_loaded
(counter)
Number of JVM classes loadedcounter.solr.node_collections_requests
(counter)
Number of collection level requets to Solr nodecounter.solr.node_cores_requests
(counter)
Number of core level requets to Solr nodecounter.solr.node_metric_request_count
(counter)
Number of metric requestscounter.solr.node_metrics_requests
(counter)
Number of metrics level requets to Solr nodecounter.solr.node_zookeeper_requests
(counter)
Number of zookeeper level requets to Solr nodecounter.solr.openFileDescriptorCount
(counter)
Number of open file descriptorscounter.solr.replication_handler_requests
(counter)
Number of replication handler requetscounter.solr.search_query_requests
(counter)
Number of search query requestscounter.solr.update_handler_requests
(counter)
Number of update handler requetscounter.solr.zookeeper_errors
(counter)
Number of failures/error at Zookeepergauge.solr.core_deleted_docs
(gauge)
Number of deleted docs in Solr coregauge.solr.core_index_size
(gauge)
Size of a core indexgauge.solr.core_max_docs
(gauge)
Total number of docs in Solr coregauge.solr.core_num_docs
(gauge)
Total number of indexed docs in Solr coregauge.solr.core_totalspace
(gauge)
Total space allocated for coregauge.solr.core_usablespace
(gauge)
Usable space available in coregauge.solr.document_cache_cumulative_hitratio
(gauge)
Cummulative hit ration of document cachegauge.solr.field_value_cache_cumulative_hitratio
(gauge)
Cummulative hit ration of filed value cachegauge.solr.http_active_requests
(gauge)
Number of http active requestsgauge.solr.jetty_get_request_latency
(gauge)
Time to process http get requestgauge.solr.jetty_post_request_latency
(gauge)
Time to process http post requestgauge.solr.jetty_request_latency
(gauge)
Http request response timegauge.solr.jvm_gc_cms_count
(gauge)
JVM Garbage Collector - CMS invocation countgauge.solr.jvm_gc_cms_time
(gauge)
JVM Garbage Collector - CMS prcoess timegauge.solr.jvm_gc_parnew_count
(gauge)
JVM Garbage Collector - Parnew invocation countgauge.solr.jvm_gc_parnew_time
(gauge)
JVM Garbage Collector - Parnew process timegauge.solr.jvm_heap_usage
(gauge)
JVM Heap usagegauge.solr.jvm_mapped_memory_capacity
(gauge)
Total JVM mapped memory capacitygauge.solr.jvm_mapped_memory_used
(gauge)
Total JVM mapped memory usedgauge.solr.jvm_memory_pools_Code-Cache_usage
(gauge)
JVM memory pools - PCode Cache usagegauge.solr.jvm_memory_pools_Metaspace_usage
(gauge)
JVM memory pools - Metaspace usagegauge.solr.jvm_memory_pools_Par-Eden-Space_usage
(gauge)
JVM memory pools - Par Eden space usagegauge.solr.jvm_memory_pools_Par-Survivor-Space_usage
(gauge)
JVM memory pools - Par Survivor space usagegauge.solr.jvm_total_memory
(gauge)
JVM total memory allocatedgauge.solr.jvm_total_memory_used
(gauge)
JVM memory usedgauge.solr.node_metric_request_time
(gauge)
Time to process a metric requestgauge.solr.query_result_cache_cumulative_hitratio
(gauge)
Cummulative hit ration of query cachegauge.solr.replication_handler_response
(gauge)
Resplication handler response timegauge.solr.search_query_response
(gauge)
Search query response timegauge.solr.searcher_warmup
(gauge)
Time to new searcher to warm upgauge.solr.shard_cumulative_docs
(gauge)gauge.solr.update_request_handler_response
(gauge)
Update request handler response timegauge.solr.zookeeper_request_time
(gauge)
Time to process a request at zookeeper
The following information applies to the agent version 4.7.0+ that has
enableBuiltInFiltering: true
set on the top level of the agent config.
To emit metrics that are not default, you can add those metrics in the
generic monitor-level extraMetrics
config option. Metrics that are derived
from specific configuration options that do not appear in the above list of
metrics do not need to be added to extraMetrics
.
To see a list of metrics that will be emitted you can run agent-status monitors
after configuring this monitor in a running agent instance.
The following information only applies to agent version older than 4.7.0. If
you have a newer agent and have set enableBuiltInFiltering: true
at the top
level of your agent config, see the section above. See upgrade instructions in
Old-style whitelist filtering.
If you have a reference to the whitelist.json
in your agent's top-level
metricsToExclude
config option, and you want to emit metrics that are not in
that whitelist, then you need to add an item to the top-level
metricsToInclude
config option to override that whitelist (see Inclusion
filtering. Or you can just
copy the whitelist.json, modify it, and reference that in metricsToExclude
.