E.6 MON$MEMORY_USAGE

MON$MEMORY_USAGE displays memory usage statistics.

Column NameData TypeDescription

MON$STAT_ID

INTEGER

Statistics identifier

MON$STAT_GROUP

SMALLINT

Statistics group:

0 - database 1 - connection 2 - transaction 3 - operator 4 - call

MON$MEMORY_USED

BIGINT

The amount of memory in use, in bytes. This data is about the high-level memory allocation performed by the server. It can be useful to track down memory leaks and excessive memory usage in connections, procedures, etc.

MON$MEMORY_ALLOCATED

BIGINT

The amount of memory allocated by the operating system, in bytes. This data is about the low-level memory allocation performed by the Firebird memory manager — the amount of memory allocated by the operating system — which can allow you to control the physical memory usage.

MON$MAX_MEMORY_USED

BIGINT

The maximum number of bytes used by this object

MON$MAX_MEMORY_ALLOCATED

BIGINT

The maximum number of bytes allocated for this object by the operating system

Note

Counters associated with database-level records MON$DATABASE (MON$STAT_GROUP = 0), display memory allocation for all connections. In the Classic and SuperClassic zero values of the counters indicate that these architectures have no common cache.

Minor memory allocations are not accrued here but are added to the database memory pool instead.

Getting 10 requests consuming the most memory

  1. SELECT
  2. STMT.MON$ATTACHMENT_ID,
  3. STMT.MON$SQL_TEXT,
  4. MEM.MON$MEMORY_USED
  5. FROM MON$MEMORY_USAGE MEM
  6. NATURAL JOIN MON$STATEMENTS STMT
  7. ORDER BY MEM.MON$MEMORY_USED DESC
  8. FETCH FIRST 10 ROWS ONLY