MongoDB
MongoDb database, Collection, MongoDb database cluster running status data Collection.
Config¶
Preconditions¶
-
Already tested version:
- 6.0
- 5.0
- 4.0
- 3.0
- 2.8.0
-
Developed and used MongoDB version
4.4.5
; - Write the configuration file in the corresponding directory and then start DataKit to complete the configuration;
- For secure connections using TLS, please configure the response certificate file path and configuration under
## TLS connection config
in the configuration file; - If MongoDB has access control enabled, you need to configure the necessary user rights to establish an authorized connection:
# Run MongoDB shell.
$ mongo
# Authenticate as the admin/root user.
> use admin
> db.auth("<admin OR root>", "<YOUR_MONGODB_ADMIN_PASSWORD>")
# Create the user for the DataKit.
> db.createUser({
"user": "datakit",
"pwd": "<YOUR_COLLECT_PASSWORD>",
"roles": [
{ role: "read", db: "admin" },
{ role: "clusterMonitor", db: "admin" },
{ role: "backup", db: "admin" },
{ role: "read", db: "local" }
]
})
More authorization information can refer to official documentation Built-In Roles。
After done with commands above, filling the user
and pwd
to DataKit configuration file conf.d/db/mongodb.conf
.
Collector Configuration¶
Go to the conf.d/db
directory under the DataKit installation directory, copy mongodb.conf.sample
and name it mongodb.conf
. Examples are as follows:
[[inputs.mongodb]]
## Gathering interval
interval = "10s"
## Specify one single Mongodb server. These server related fields will be ignored when the 'servers' field is not empty.
## connection_format is a string in the standard connection format (mongodb://) or SRV connection format (mongodb+srv://).
connection_format = "mongodb://"
## The host and port.
host_port = "127.0.0.1:27017"
## Username
username = "datakit"
## Password
password = "<PASS>"
## The authentication database to use.
# default_db = "admin"
## A query string that specifies connection specific options as <name>=<value> pairs.
# query_string = "authSource=admin&authMechanism=SCRAM-SHA-256"
## When true, collect replica set stats
gather_replica_set_stats = false
## When true, collect cluster stats
## Note that the query that counts jumbo chunks triggers a COLLSCAN, which may have an impact on performance.
gather_cluster_stats = false
## When true, collect per database stats
gather_per_db_stats = true
## When true, collect per collection stats
gather_per_col_stats = true
## List of db where collections stats are collected, If empty, all dbs are concerned.
col_stats_dbs = []
## When true, collect top command stats.
gather_top_stat = true
## Set true to enable election
election = true
## TLS connection config
# ca_certs = ["/etc/ssl/certs/mongod.cert.pem"]
# cert = "/etc/ssl/certs/mongo.cert.pem"
# cert_key = "/etc/ssl/certs/mongo.key.pem"
# insecure_skip_verify = true
# server_name = ""
## Mongodb log files and Grok Pipeline files configuration
# [inputs.mongodb.log]
# files = ["/var/log/mongodb/mongod.log"]
# pipeline = "mongod.p"
## Customer tags, if set will be seen with every metric.
# [inputs.mongodb.tags]
# "key1" = "value1"
# "key2" = "value2"
# ...
Once configured, restart DataKit.
The collector can now be turned on by ConfigMap Injection Collector Configuration.
TLS config (self-signed)¶
Use OpenSSL to generate a certificate file for MongoDB TLS configuration to enable server-side encryption and client-side authentication.
- Configure TLS certificates
Install OpenSSL and run the following command:
- Configure MongoDB server-side encryption
Use OpenSSL to generate a certificate-level key file, run the following command and enter the corresponding authentication block information at the command prompt:
sudo openssl req -x509 -newkey rsa:<bits> -days <days> -keyout <mongod.key.pem> -out <mongod.cert.pem> -nodes
bits
: rsa key digits, for example, 2048days
: expired datemongod.key.pem
: key filemongod.cert.pem
: CA certificate file
Running the above command generates the cert.pem
file and the key.pem
file, and we need to merge the block
inside the two files to run the following command:
Configure the TLS subentry in the /etc/mongod.config file after merging
Start MongoDB with the configuration file and run the following command:
Start MongoDB from the command line and run the following command:
Copy mongod.cert.pem as mongo.cert.pem to MongoDB client and enable TLS:
- Configuring MongoDB Client Authentication
Use OpenSSL to generate a certificate-level key file and run the following command:
sudo openssl req -x509 -newkey rsa:<bits> -days <days> -keyout <mongod.key.pem> -out <mongod.cert.pem> -nodes
bits
: rsa key digits, for example, 2048days
: expired datemongo.key.pem
: key filemongo.cert.pem
: CA certificate file
Merging the block in the mongod.cert.pem and mongod.key.pem files runs the following command:
Copy the mongod.cert.pem file to the MongoDB server and configure the TLS entry in the /etc/mongod.config file.
# Tls config
net:
tls:
mode: requireTLS
certificateKeyFile: </etc/ssl/mongod.pem>
CAFile: </etc/ssl/mongod.cert.pem>
Start MongoDB and run the following command:
Copy mongod.cert.pem for mongo.cert.pem; Copy mongod.pem for mongo.pem to MongoDB client and enable TLS:
mongo --tls --host <mongod_url> --tlsCAFile </etc/ssl/mongo.cert.pem> --tlsCertificateKeyFile </etc/ssl/mongo.pem>
Note:insecure_skip_verify
must be true
in mongodb.conf configuration when using self-signed certificates.
Metric¶
For all of the following data collections, the global election tags will added automatically, we can add extra tags in [inputs.mongodb.tags]
if needed:
mongodb
¶
- explain
MongoDB measurement. Some metrics may not appear depending on the MongoDB version or DB running status.
- Tags
Tag | Description |
---|---|
host | mongodb host |
mongod_host | mongodb host with port |
- Metrics
Metric | Description |
---|---|
active_reads | The number of the active client connections performing read operations. Type: int Unit: count |
active_writes | The number of active client connections performing write operations. Type: int Unit: count |
aggregate_command_failed | The number of times that 'aggregate' command failed on this mongod Type: int Unit: count |
aggregate_command_total | The number of times that 'aggregate' command executed on this mongod. Type: int Unit: count |
assert_msg | The number of message assertions raised since the MongoDB process started. Check the log file for more information about these messages. Type: int Unit: count |
assert_regular | The number of regular assertions raised since the MongoDB process started. Check the log file for more information about these messages. Type: int Unit: count |
assert_rollovers | The number of times that the rollover counters have rolled over since the last time the MongoDB process started. The counters will rollover to zero after 2 30 assertions. Use this value to provide context to the other values in the asserts data structure. Type: int Unit: count |
assert_user | The number of "user asserts" that have occurred since the last time the MongoDB process started. These are errors that user may generate, such as out of disk space or duplicate key. You can prevent these assertions by fixing a problem with your application or deployment. Check the MongoDB log for more information. Type: int Unit: count |
assert_warning | Changed in version 4.0. Starting in MongoDB 4.0, the field returns zero 0. In earlier versions, the field returns the number of warnings raised since the MongoDB process started. Type: int Unit: count |
available_reads | The number of concurrent of read transactions allowed into the WiredTiger storage engine Type: int Unit: count |
available_writes | The number of concurrent of write transactions allowed into the WiredTiger storage engine Type: int Unit: count |
commands | The total number of commands issued to the database since the mongod instance last started. opcounters.command counts all commands except the write commands: insert, update, and delete.Type: int Unit: count |
commands_per_sec | Deprecated, use commands. Type: int Unit: count |
connections_available | The number of unused incoming connections available. Type: int Unit: count |
connections_current | The number of incoming connections from clients to the database server . Type: int Unit: count |
connections_total_created | Count of all incoming connections created to the server. This number includes connections that have since closed. Type: int Unit: count |
count_command_failed | The number of times that 'count' command failed on this mongod Type: int Unit: count |
count_command_total | The number of times that 'count' command executed on this mongod Type: int Unit: count |
cursor_no_timeout | Deprecated, use cursor_no_timeout_count. Type: int Unit: count |
cursor_no_timeout_count | The number of open cursors with the option DBQuery.Option.noTimeout set to prevent timeout after a period of inactivity Type: int Unit: count |
cursor_pinned | Deprecated, use cursor_pinned_count. Type: int Unit: count |
cursor_pinned_count | The number of "pinned" open cursors. Type: int Unit: count |
cursor_timed_out | Deprecated, use cursor_timed_out_count. Type: int Unit: count |
cursor_timed_out_count | The total number of cursors that have timed out since the server process started. If this number is large or growing at a regular rate, this may indicate an application error. Type: int Unit: count |
cursor_total | Deprecated, use cursor_total_count. Type: int Unit: count |
cursor_total_count | The number of cursors that MongoDB is maintaining for clients. Because MongoDB exhausts unused cursors, typically this value small or zero. However, if there is a queue, stale tailable cursors, or a large number of operations this value may rise. Type: int Unit: count |
delete_command_failed | The number of times that 'delete' command failed on this mongod Type: int Unit: count |
delete_command_total | The number of times that 'delete' command executed on this mongod Type: int Unit: count |
deletes | The total number of delete operations since the mongod instance last started. Type: int Unit: count |
deletes_per_sec | Deprecated, use deletes. Type: int Unit: count |
distinct_command_failed | The number of times that 'distinct' command failed on this mongod Type: int Unit: count |
distinct_command_total | The number of times that 'distinct' command executed on this mongod Type: int Unit: count |
document_deleted | The total number of documents deleted. Type: int Unit: count |
document_inserted | The total number of documents inserted. Type: int Unit: count |
document_returned | The total number of documents returned by queries. Type: int Unit: count |
document_updated | The total number of documents updated. Type: int Unit: count |
find_and_modify_command_failed | The number of times that 'find' and 'modify' commands failed on this mongod Type: int Unit: count |
find_and_modify_command_total | The number of times that 'find' and 'modify' commands executed on this mongod Type: int Unit: count |
find_command_failed | The number of times that 'find' command failed on this mongod Type: int Unit: count |
find_command_total | The number of times that 'find' command executed on this mongod Type: int Unit: count |
flushes | The number of transaction checkpoints Type: int Unit: count |
flushes_per_sec | Deprecated, use flushes. Type: int Unit: count |
flushes_total_time_ns | The transaction checkpoint total time (ms)" Type: int Unit: count |
get_more_command_failed | The number of times that 'get more' command failed on this mongod Type: int Unit: count |
get_more_command_total | The number of times that 'get more' command executed on this mongod Type: int Unit: count |
getmores | The total number of getMore operations since the mongod instance last started. This counter can be high even if the query count is low. Secondary nodes send getMore operations as part of the replication process.Type: int Unit: count |
getmores_per_sec | Deprecated, use getmores Type: int Unit: count |
insert_command_failed | The number of times that 'insert' command failed on this mongod Type: int Unit: count |
insert_command_total | The number of times that 'insert' command executed on this mongod Type: int Unit: count |
inserts | The total number of insert operations received since the mongod instance last started. Type: int Unit: count |
inserts_per_sec | Deprecated, use inserts. Type: int Unit: count |
jumbo_chunks | Count jumbo flags in cluster chunk. Type: int Unit: count |
mapped_megabytes | Mapped megabytes. (Existed in 3.0 and earlier version) Type: int Unit: count |
net_in_bytes | Deprecated, use net_out_bytes_count. Type: int Unit: count |
net_in_bytes_count | The total number of bytes that the server has received over network connections initiated by clients or other mongod instances. Type: int Unit: count |
net_out_bytes | Deprecated, use net_out_bytes_count. Type: int Unit: count |
net_out_bytes_count | The total number of bytes that the server has sent over network connections initiated by clients or other mongod instances. Type: int Unit: count |
non-mapped_megabytes | Non mapped megabytes. (Existed in 3.0 and earlier version) Type: int Unit: count |
open_connections | The number of incoming connections from clients to the database server. Type: int Unit: count |
operation_scan_and_order | The total number of queries that return sorted numbers that cannot perform the sort operation using an index. Type: int Unit: count |
operation_write_conflicts | The total number of queries that encountered write conflicts. Type: int Unit: count |
page_faults | The total number of page faults. Type: int Unit: count |
page_faults_per_sec | Page Faults/sec is the average number of pages faulted per second. (Existed in 3.0 and earlier version) Type: int Unit: count |
percent_cache_dirty | Size in bytes of the dirty data in the cache. This value should be less than the bytes currently in the cache value. Type: float Unit: count |
percent_cache_used | Size in byte of the data currently in cache. This value should not be greater than the maximum bytes configured value. Type: float Unit: count |
queries | The total number of queries received since the mongod instance last started. Type: int Unit: count |
queries_per_sec | Deprecated, use queries. Type: int Unit: count |
queued_reads | The number of operations that are currently queued and waiting for the read lock. A consistently small read-queue, particularly of shorter operations, should cause no concern. Type: int Unit: count |
queued_writes | The number of operations that are currently queued and waiting for the write lock. A consistently small write-queue, particularly of shorter operations, is no cause for concern. Type: int Unit: count |
repl_apply_batches_num | The total number of batches applied across all databases. Type: int Unit: count |
repl_apply_batches_total_millis | The total amount of time in milliseconds the mongod has spent applying operations from the oplog. Type: int Unit: count |
repl_apply_ops | The total number of oplog operations applied. metrics.repl.apply.ops is incremented after each operation. Type: int Unit: count |
repl_buffer_count | The current number of operations in the oplog buffer. Type: int Unit: count |
repl_buffer_size_bytes | The current size of the contents of the oplog buffer. Type: int Unit: count |
repl_commands | The total number of replicated commands issued to the database since the mongod instance last started. Type: int Unit: count |
repl_commands_per_sec | Deprecated, use repl_commands. Type: int Unit: count |
repl_deletes | The total number of replicated delete operations since the mongod instance last started. Type: int Unit: count |
repl_deletes_per_sec | Deprecated, use repl_deletes. Type: int Unit: count |
repl_executor_pool_in_progress_count | The number of replication tasks that are currently being executed by the executor pool. Type: int Unit: count |
repl_executor_queues_network_in_progress | The number of network-related replication tasks that are currently being processed by the executor queues. Type: int Unit: count |
repl_executor_queues_sleepers | The number of replication tasks in the executor queues that are currently in a sleeping state. Type: int Unit: count |
repl_executor_unsignaled_events | The number of events related to the replication executor that have not yet been signaled. Type: int Unit: count |
repl_getmores | The total number of replicated getmore operations since the mongod instance last started. Type: int Unit: count |
repl_getmores_per_sec | Deprecated, use repl_getmores. Type: int Unit: count |
repl_inserts | The total number of replicated insert operations since the mongod instance last started. Type: int Unit: count |
repl_inserts_per_sec | Deprecated, use repl_inserts. Type: int Unit: count |
repl_lag | Delay between a write operation on the primary and its copy to a secondary. Type: int Unit: count |
repl_network_bytes | The total amount of data read from the replication sync source. Type: int Unit: count |
repl_network_getmores_num | The total number of getmore operations, which are operations that request an additional set of operations from the replication sync source. Type: int Unit: count |
repl_network_getmores_total_millis | The total amount of time required to collect data from getmore operations. Type: int Unit: count |
repl_network_ops | The total number of operations read from the replication source. Type: int Unit: count |
repl_queries | The total number of replicated queries since the mongod instance last started. Type: int Unit: count |
repl_queries_per_sec | Deprecated, use repl_queries. Type: int Unit: count |
repl_state | The node state of replication member. Type: int Unit: count |
repl_updates | The total number of replicated update operations since the mongod instance last started. Type: int Unit: count |
repl_updates_per_sec | Deprecated, use repl_updates. Type: int Unit: count |
resident_megabytes | The value of mem.resident is roughly equivalent to the amount of RAM, in MiB, currently used by the database process. Type: int Unit: count |
storage_freelist_search_bucket_exhausted | The number of times that mongod has checked the free list without finding a suitably large record allocation. Type: int Unit: count |
storage_freelist_search_requests | The number of times mongod has searched for available record allocations. Type: int Unit: count |
storage_freelist_search_scanned | The number of available record allocations mongod has searched. Type: int Unit: count |
tcmalloc_central_cache_free_bytes | Number of free bytes in the central cache that have been assigned to size classes. They always count towards virtual memory usage, and unless the underlying memory is swapped. Type: int Unit: count |
tcmalloc_current_allocated_bytes | Number of bytes currently allocated by application. Type: int Unit: count |
tcmalloc_current_total_thread_cache_bytes | Number of bytes used across all thread caches. Type: int Unit: count |
tcmalloc_heap_size | Number of bytes in the heap. Type: int Unit: count |
tcmalloc_max_total_thread_cache_bytes | Upper limit on total number of bytes stored across all per-thread caches. Default: 16MB. Type: int Unit: count |
tcmalloc_pageheap_commit_count | Number of virtual memory commits. Type: int Unit: count |
tcmalloc_pageheap_committed_bytes | Bytes committed, always <= system_bytes_. Type: int Unit: count |
tcmalloc_pageheap_decommit_count | Number of virtual memory de-commits. Type: int Unit: count |
tcmalloc_pageheap_free_bytes | Number of bytes in free, mapped pages in page heap. Type: int Unit: count |
tcmalloc_pageheap_reserve_count | Number of virtual memory reserves. Type: int Unit: count |
tcmalloc_pageheap_scavenge_count | Number of times scavaged flush pages. Type: int Unit: count |
tcmalloc_pageheap_total_commit_bytes | Bytes committed in lifetime of process. Type: int Unit: count |
tcmalloc_pageheap_total_decommit_bytes | Bytes de-committed in lifetime of process. Type: int Unit: count |
tcmalloc_pageheap_total_reserve_bytes | Number of virtual memory reserves. Type: int Unit: count |
tcmalloc_pageheap_unmapped_bytes | Total bytes on returned free lists. Type: int Unit: count |
tcmalloc_spinlock_total_delay_ns | The total time (in nanoseconds) threads have been delayed while waiting for spinlocks in TCMalloc. Type: int Unit: count |
tcmalloc_thread_cache_free_bytes | Bytes in thread caches. Type: int Unit: count |
tcmalloc_total_free_bytes | Total bytes on normal free lists. Type: int Unit: count |
tcmalloc_transfer_cache_free_bytes | Bytes in central transfer cache. Type: int Unit: count |
total_available | The number of connections available from the mongos to the config servers, replica sets, and standalone mongod instances in the cluster. Type: int Unit: count |
total_created | The number of connections the mongos has ever created to other members of the cluster. Type: int Unit: count |
total_docs_scanned | The total number of index items scanned during queries and query-plan evaluation. Type: int Unit: count |
total_in_use | Reports the total number of outgoing connections from the current mongod/mongos instance to other members of the sharded cluster or replica set that are currently in use. Type: int Unit: count |
total_keys_scanned | The total number of index items scanned during queries and query-plan evaluation. Type: int Unit: count |
total_refreshing | Reports the total number of outgoing connections from the current mongod/mongos instance to other members of the sharded cluster or replica set that are currently being refreshed. Type: int Unit: count |
total_tickets_reads | A document that returns information on the number of concurrent of read transactions allowed into the WiredTiger storage engine. Type: int Unit: count |
total_tickets_writes | A document that returns information on the number of concurrent of write transactions allowed into the WiredTiger storage engine. Type: int Unit: count |
ttl_deletes | The total number of documents deleted from collections with a ttl index. Type: int Unit: count |
ttl_deletes_per_sec | Deprecated, use ttl_deletes. Type: int Unit: count |
ttl_passes | The number of times the background process removes documents from collections with a ttl index. Type: int Unit: count |
ttl_passes_per_sec | Deprecated, use ttl_passes. Type: int Unit: count |
update_command_failed | The number of times that 'update' command failed on this mongod Type: int Unit: count |
update_command_total | The number of times that 'update' command executed on this mongod Type: int Unit: count |
updates | The total number of update operations received since the mongod instance last started. Type: int Unit: count |
updates_per_sec | Deprecated, use updates. Type: int Unit: count |
uptime_ns | The total upon time of mongod in nano seconds. Type: int Unit: count |
vsize_megabytes | mem.virtual displays the quantity, in MiB, of virtual memory used by the mongod process. Type: int Unit: count |
wtcache_app_threads_page_read_count | The number of pages read by application threads from the WiredTiger cache. Type: int Unit: count |
wtcache_app_threads_page_read_time | The total time application threads spend reading pages from the WiredTiger cache. Type: int Unit: count |
wtcache_app_threads_page_write_count | The number of pages written by application threads to the WiredTiger cache. Type: int Unit: count |
wtcache_bytes_read_into | The total number of bytes read into the WiredTiger cache. Type: int Unit: count |
wtcache_bytes_written_from | The total number of bytes written from the WiredTiger cache. Type: int Unit: count |
wtcache_current_bytes | The current number of bytes being used in the WiredTiger cache. Type: int Unit: count |
wtcache_internal_pages_evicted | The number of internal pages evicted from the WiredTiger cache. Type: int Unit: count |
wtcache_max_bytes_configured | Maximum cache size. Type: int Unit: count |
wtcache_modified_pages_evicted | The number of modified pages evicted from the WiredTiger cache. Type: int Unit: count |
wtcache_pages_evicted_by_app_thread | The number of pages evicted from the WiredTiger cache by application threads. Type: int Unit: count |
wtcache_pages_queued_for_eviction | The current number of pages in the WiredTiger cache that are queued for eviction. Type: int Unit: count |
wtcache_pages_read_into | Number of pages read into the cache. Type: int Unit: count |
wtcache_pages_requested_from | Number of pages request from the cache. Type: int Unit: count |
wtcache_pages_written_from | Pages written from cache Type: int Unit: count |
wtcache_server_evicting_pages | The current number of pages in the WiredTiger cache that are being evicted by the server. Type: int Unit: count |
wtcache_tracked_dirty_bytes | The total number of bytes in the WiredTiger cache that are tracked as dirty. Type: int Unit: count |
wtcache_unmodified_pages_evicted | Main statistics for page eviction. Type: int Unit: count |
wtcache_worker_thread_evictingpages | The number of pages being evicted from the WiredTiger cache by worker threads. Type: int Unit: count |
mongodb_db_stats
¶
- explain
MongoDB stats measurement. Some metrics may not appear depending on the MongoDB version or DB running status.
- Tags
Tag | Description |
---|---|
db_name | database name |
host | mongodb host |
mongod_host | mongodb host with port |
- Metrics
Metric | Description |
---|---|
avg_obj_size | The average size of each document in bytes. Type: float Unit: count |
collections | Contains a count of the number of collections in that database. Type: int Unit: count |
data_size | The total size of the uncompressed data held in this database. The dataSize decreases when you remove documents. Type: int Unit: count |
index_size | The total size of all indexes created on this database. Type: int Unit: count |
indexes | Contains a count of the total number of indexes across all collections in the database. Type: int Unit: count |
mapped_megabytes | Mapped megabytes. (Existed in 3.0 and earlier version) Type: int Unit: count |
non-mapped_megabytes | Non mapped megabytes. (Existed in 3.0 and earlier version) Type: int Unit: count |
objects | Contains a count of the number of objects (i.e. documents) in the database across all collections. Type: int Unit: count |
ok | Command execute state. Type: int Unit: count |
page_faults_per_sec | Page Faults/sec is the average number of pages faulted per second. (Existed in 3.0 and earlier version) Type: int Unit: count |
percent_cache_dirty | Size in bytes of the dirty data in the cache. This value should be less than the bytes currently in the cache value. (Existed in 3.0 and earlier version) Type: int Unit: count |
percent_cache_used | Size in byte of the data currently in cache. This value should not be greater than the maximum bytes configured value. (Existed in 3.0 and earlier version) Type: int Unit: count |
storage_size | The total amount of space allocated to collections in this database for document storage. Type: int Unit: count |
wtcache_app_threads_page_read_count | (Existed in 3.0 and earlier version) Type: int Unit: count |
wtcache_app_threads_page_read_time | (Existed in 3.0 and earlier version) Type: int Unit: count |
wtcache_app_threads_page_write_count | (Existed in 3.0 and earlier version) Type: int Unit: count |
wtcache_bytes_read_into | (Existed in 3.0 and earlier version) Type: int Unit: count |
wtcache_bytes_written_from | (Existed in 3.0 and earlier version) Type: int Unit: count |
wtcache_current_bytes | (Existed in 3.0 and earlier version) Type: int Unit: count |
wtcache_internal_pages_evicted | (Existed in 3.0 and earlier version) Type: int Unit: count |
wtcache_max_bytes_configured | Maximum cache size. (Existed in 3.0 and earlier version) Type: int Unit: count |
wtcache_modified_pages_evicted | (Existed in 3.0 and earlier version) Type: int Unit: count |
wtcache_pages_evicted_by_app_thread | (Existed in 3.0 and earlier version) Type: int Unit: count |
wtcache_pages_queued_for_eviction | (Existed in 3.0 and earlier version) Type: int Unit: count |
wtcache_pages_read_into | Number of pages read into the cache. (Existed in 3.0 and earlier version) Type: int Unit: count |
wtcache_pages_requested_from | Number of pages request from the cache. (Existed in 3.0 and earlier version) Type: int Unit: count |
wtcache_pages_written_from | Pages written from cache. (Existed in 3.0 and earlier version) Type: int Unit: count |
wtcache_server_evicting_pages | (Existed in 3.0 and earlier version) Type: int Unit: count |
wtcache_tracked_dirty_bytes | (Existed in 3.0 and earlier version) Type: int Unit: count |
wtcache_unmodified_pages_evicted | Main statistics for page eviction. (Existed in 3.0 and earlier version) Type: int Unit: count |
wtcache_worker_thread_evictingpages | (Existed in 3.0 and earlier version) Type: int Unit: count |
mongodb_col_stats
¶
- explain
MongoDB collection measurement. Some metrics may not appear depending on the MongoDB version or DB running status.
- Tags
Tag | Description |
---|---|
collection | collection name |
db_name | database name |
host | mongodb host |
mongod_host | mongodb host with port |
- Metrics
Metric | Description |
---|---|
avg_obj_size | The average size of an object in the collection. Type: float Unit: count |
count | The number of objects or documents in this collection. Type: int Unit: count |
mapped_megabytes | Mapped megabytes. (Existed in 3.0 and earlier version) Type: int Unit: count |
non-mapped_megabytes | Non mapped megabytes. (Existed in 3.0 and earlier version) Type: int Unit: count |
ok | Command execute state. Type: int Unit: count |
page_faults_per_sec | Page Faults/sec is the average number of pages faulted per second. (Existed in 3.0 and earlier version) Type: int Unit: count |
percent_cache_dirty | Size in bytes of the dirty data in the cache. This value should be less than the bytes currently in the cache value. (Existed in 3.0 and earlier version) Type: int Unit: count |
percent_cache_used | Size in byte of the data currently in cache. This value should not be greater than the maximum bytes configured value. (Existed in 3.0 and earlier version) Type: int Unit: count |
size | The total uncompressed size in memory of all records in a collection. Type: int Unit: count |
storage_size | The total amount of storage allocated to this collection for document storage. Type: int Unit: count |
total_index_size | The total size of all indexes. Type: int Unit: count |
wtcache_app_threads_page_read_count | (Existed in 3.0 and earlier version) Type: int Unit: count |
wtcache_app_threads_page_read_time | (Existed in 3.0 and earlier version) Type: int Unit: count |
wtcache_app_threads_page_write_count | (Existed in 3.0 and earlier version) Type: int Unit: count |
wtcache_bytes_read_into | (Existed in 3.0 and earlier version) Type: int Unit: count |
wtcache_bytes_written_from | (Existed in 3.0 and earlier version) Type: int Unit: count |
wtcache_current_bytes | (Existed in 3.0 and earlier version) Type: int Unit: count |
wtcache_internal_pages_evicted | (Existed in 3.0 and earlier version) Type: int Unit: count |
wtcache_max_bytes_configured | Maximum cache size. (Existed in 3.0 and earlier version) Type: int Unit: count |
wtcache_modified_pages_evicted | (Existed in 3.0 and earlier version) Type: int Unit: count |
wtcache_pages_evicted_by_app_thread | (Existed in 3.0 and earlier version) Type: int Unit: count |
wtcache_pages_queued_for_eviction | (Existed in 3.0 and earlier version) Type: int Unit: count |
wtcache_pages_read_into | Number of pages read into the cache. (Existed in 3.0 and earlier version) Type: int Unit: count |
wtcache_pages_requested_from | Number of pages request from the cache. (Existed in 3.0 and earlier version) Type: int Unit: count |
wtcache_pages_written_from | Pages written from cache. (Existed in 3.0 and earlier version) Type: int Unit: count |
wtcache_server_evicting_pages | (Existed in 3.0 and earlier version) Type: int Unit: count |
wtcache_tracked_dirty_bytes | (Existed in 3.0 and earlier version) Type: int Unit: count |
wtcache_unmodified_pages_evicted | Main statistics for page eviction. (Existed in 3.0 and earlier version) Type: int Unit: count |
wtcache_worker_thread_evictingpages | (Existed in 3.0 and earlier version) Type: int Unit: count |
mongodb_shard_stats
¶
- explain
MongoDB shard measurement. Some metrics may not appear depending on the MongoDB version or DB running status.
- Tags
Tag | Description |
---|---|
host | mongodb host |
mongod_host | mongodb host with port |
- Metrics
Metric | Description |
---|---|
available | The number of connections available for this host to connect to the mongos. Type: int Unit: count |
created | The number of connections the host has ever created to connect to the mongos. Type: int Unit: count |
in_use | Reports the total number of outgoing connections from the current mongod/mongos instance to other members of the sharded cluster or replica set that are currently in use. Type: int Unit: count |
refreshing | Reports the total number of outgoing connections from the current mongod/mongos instance to other members of the sharded cluster or replica set that are currently being refreshed. Type: int Unit: count |
mongodb_top_stats
¶
- explain
MongoDB top measurement. Some metrics may not appear depending on the MongoDB version or DB running status.
- Tags
Tag | Description |
---|---|
collection | collection name |
host | mongodb host |
mongod_host | mongodb host with port |
- Metrics
Metric | Description |
---|---|
commands_count | The total number of "command" event issues. Type: int Unit: count |
commands_time | The amount of time in microseconds that "command" costs. Type: int Unit: count |
get_more_count | The total number of getmore event issues.Type: int Unit: count |
get_more_time | The amount of time in microseconds that getmore costs.Type: int Unit: count |
insert_count | The total number of "insert" event issues. Type: int Unit: count |
insert_time | The amount of time in microseconds that "insert" costs. Type: int Unit: count |
mapped_megabytes | Mapped megabytes. (Existed in 3.0 and earlier version) Type: int Unit: count |
non-mapped_megabytes | Non mapped megabytes. (Existed in 3.0 and earlier version) Type: int Unit: count |
page_faults_per_sec | Page Faults/sec is the average number of pages faulted per second. (Existed in 3.0 and earlier version) Type: int Unit: count |
percent_cache_dirty | Size in bytes of the dirty data in the cache. This value should be less than the bytes currently in the cache value. (Existed in 3.0 and earlier version) Type: int Unit: count |
percent_cache_used | Size in byte of the data currently in cache. This value should not be greater than the maximum bytes configured value. (Existed in 3.0 and earlier version) Type: int Unit: count |
queries_count | The total number of "queries" event issues. Type: int Unit: count |
queries_time | The amount of time in microseconds that "queries" costs. Type: int Unit: count |
read_lock_count | The total number of "readLock" event issues. Type: int Unit: count |
read_lock_time | The amount of time in microseconds that "readLock" costs. Type: int Unit: count |
remove_count | The total number of "remove" event issues. Type: int Unit: count |
remove_time | The amount of time in microseconds that "remove" costs. Type: int Unit: count |
total_count | The total number of "total" event issues. Type: int Unit: count |
total_time | The amount of time in microseconds that "total" costs. Type: int Unit: count |
update_count | The total number of "update" event issues. Type: int Unit: count |
update_time | The amount of time in microseconds that "update" costs. Type: int Unit: count |
write_lock_count | The total number of "writeLock" event issues. Type: int Unit: count |
write_lock_time | The amount of time in microseconds that "writeLock" costs. Type: int Unit: count |
wtcache_app_threads_page_read_count | (Existed in 3.0 and earlier version) Type: int Unit: count |
wtcache_app_threads_page_read_time | (Existed in 3.0 and earlier version) Type: int Unit: count |
wtcache_app_threads_page_write_count | (Existed in 3.0 and earlier version) Type: int Unit: count |
wtcache_bytes_read_into | (Existed in 3.0 and earlier version) Type: int Unit: count |
wtcache_bytes_written_from | (Existed in 3.0 and earlier version) Type: int Unit: count |
wtcache_current_bytes | (Existed in 3.0 and earlier version) Type: int Unit: count |
wtcache_internal_pages_evicted | (Existed in 3.0 and earlier version) Type: int Unit: count |
wtcache_max_bytes_configured | Maximum cache size. (Existed in 3.0 and earlier version) Type: int Unit: count |
wtcache_modified_pages_evicted | (Existed in 3.0 and earlier version) Type: int Unit: count |
wtcache_pages_evicted_by_app_thread | (Existed in 3.0 and earlier version) Type: int Unit: count |
wtcache_pages_queued_for_eviction | (Existed in 3.0 and earlier version) Type: int Unit: count |
wtcache_pages_read_into | Number of pages read into the cache. (Existed in 3.0 and earlier version) Type: int Unit: count |
wtcache_pages_requested_from | Number of pages request from the cache. (Existed in 3.0 and earlier version) Type: int Unit: count |
wtcache_pages_written_from | Pages written from cache. (Existed in 3.0 and earlier version) Type: int Unit: count |
wtcache_server_evicting_pages | (Existed in 3.0 and earlier version) Type: int Unit: count |
wtcache_tracked_dirty_bytes | (Existed in 3.0 and earlier version) Type: int Unit: count |
wtcache_unmodified_pages_evicted | Main statistics for page eviction. (Existed in 3.0 and earlier version) Type: int Unit: count |
wtcache_worker_thread_evictingpages | (Existed in 3.0 and earlier version) Type: int Unit: count |
collector
¶
-
explain
-
Tags
Tag | Description |
---|---|
instance | Server addr of the instance |
job | Server name of the instance |
- Metrics
Metric | Description |
---|---|
up | Type: int Unit: - |
Custom Object¶
database
¶
- Tags
Tag | Description |
---|---|
col_co_status | Current status of collector on instance(OK/NotOK ) |
host | The server host address |
ip | Connection IP of the instance |
name | Object uniq ID |
reason | If status not ok, we'll get some reasons about the status |
- Metrics
Metric | Description |
---|---|
display_name | Displayed name in UI Type: string Unit: - |
uptime | Current instance uptime Type: int Unit: time,s |
version | Current version of instance Type: string Unit: - |
Mongod Log Collection¶
Annotate the configuration file # enable_mongod_log = false
and change false
to true
. Other configuration options for mongod log are in [inputs.mongodb.log]
, and the commented configuration is very default. If the path correspondence is correct, no configuration is needed. After starting DataKit, you will see a collection measurement named mongod_log
.
Log raw data sample
{"t":{"$date":"2021-06-03T09:12:19.977+00:00"},"s":"I", "c":"STORAGE", "id":22430, "ctx":"WTCheckpointThread","msg":"WiredTiger message","attr":{"message":"[1622711539:977142][1:0x7f1b9f159700], WT_SESSION.checkpoint: [WT_VERB_CHECKPOINT_PROGRESS] saving checkpoint snapshot min: 653, snapshot max: 653 snapshot count: 0, oldest timestamp: (0, 0) , meta checkpoint timestamp: (0, 0)"}}
Log cut field
Field Name | Field Value | Description |
---|---|---|
message | Log raw data | |
component | STORAGE | The full component string of the log message |
context | WTCheckpointThread | The name of the thread issuing the log statement |
msg | WiredTiger message | The raw log output message as passed from the server or driver |
status | I | The short severity code of the log message |
time | 2021-06-03T09:12:19.977+00:00 | Timestamp |