GRAPH.MEMORY
The GRAPH.MEMORY command returns detailed memory consumption statistics for a specific graph in megabytes (MB). It provides insight into how much memory is used by various internal data structures such as nodes, edges, schemas, indices, and matrix representations. This command can be used to monitor memory consumption at the graph level, making it especially useful for debugging, monitoring, performance optimization, and capacity planning in FalkorDB deployments.
Syntax
GRAPH.MEMORY USAGE <graph-name> [SAMPLES <count>]
Arguments
| Argument | Description |
|---|---|
<graph-name> |
The name of the graph to inspect. |
SAMPLES <n> |
(Optional) Number of samples to take when estimating memory usage. A higher number improves accuracy but increases computation time. The samples are averaged to estimate the total size. Defaults to 100 if not specified. The value is clamped to the range [1, 10000]. |
Return
The command returns a set of key-value pairs, where each pair represents a specific memory metric and its value (in MB), corresponding to different components of the graph. In RESP2, this is encoded as a flat array of alternating field names and values:
| Metric Name / Field | Type | Description |
|---|---|---|
total_graph_sz_mb |
integer | Total memory consumed by the graph. |
label_matrices_sz_mb |
integer | Amount of memory used by label matrices (node labels tracking). |
relation_matrices_sz_mb |
integer | Amount of memory used by relationship type matrices (graph topology tracking). |
amortized_node_block_sz_mb |
integer | Memory used by node blocks (amortized node storage). |
amortized_node_attributes_by_label_sz_mb |
map | Memory used by node attributes, broken down by label. Each key is a label name and its value is the memory in MB. |
amortized_unlabeled_nodes_attributes_sz_mb |
integer | Memory used by attributes of nodes with no label. |
amortized_edge_block_sz_mb |
integer | Memory used by edge blocks (amortized edge storage). |
amortized_edge_attributes_by_type_sz_mb |
map | Memory used by edge attributes, broken down by relationship type. Each key is a relationship type name and its value is the memory in MB. |
indices_sz_mb |
integer | Amount of memory consumed by indices (if any). |
Examples
Basic Usage
import { FalkorDB } from 'falkordb';
const db = await FalkorDB.connect({
socket: { host: 'localhost', port: 6379 }
});
const graph = db.selectGraph('myGraph');
const memoryInfo = await graph.memoryUsage();
console.log(memoryInfo);
GRAPH.MEMORY USAGE myGraph
With Sampling
const memoryInfo = await graph.memoryUsage({ samples: 500 });
console.log(memoryInfo);
GRAPH.MEMORY USAGE myGraph SAMPLES 500
Sample Output
127.0.0.1:6379> GRAPH.MEMORY USAGE flights
1) "total_graph_sz_mb"
2) (integer) 1086
3) "label_matrices_sz_mb"
4) (integer) 96
5) "relation_matrices_sz_mb"
6) (integer) 64
7) "amortized_node_block_sz_mb"
8) (integer) 120
9) "amortized_node_attributes_by_label_sz_mb"
10) 1) "Airport"
2) (integer) 35
3) "City"
4) (integer) 12
11) "amortized_unlabeled_nodes_attributes_sz_mb"
12) (integer) 0
13) "amortized_edge_block_sz_mb"
14) (integer) 54
15) "amortized_edge_attributes_by_type_sz_mb"
16) 1) "ROUTE"
2) (integer) 68
17) "indices_sz_mb"
18) (integer) 752