The System Utilization monitor contains an embedded collector daemon that runs on systems affected by a Java process fork memory issue (RFE 5049299).
When a process attempts to fork a child process, the system attempts to allocate the same amount of memory for the child process, which will likely fail when the parent process consumes a large amount of memory.
The embedded collector daemon is started automatically for the server and inspects the Host System Monitor provider configuration to conditionally determine whether the external daemon process is required.
The external collector daemon operates by having an internal table of repeatable commands that run on a schedule. The collector creates a simulated filesystem in the <server-root>/logs directory for each command type so that the Host System Monitor Provider can find the output of the most recently collected data.
Repeating commands use a subdirectory for each command type to keep results isolated from other
command types and to help organize file cleanup. The filename of the output contains the
sample timestamp, such as iostats-[sampletimestamp]
. If the collector
daemon fails for any reason, the Host System Monitor provider is not left reading stale
system data because the expected timestamp files is missing. To handle clock-edge
timing, the monitor sampler will also look for data in a filename of the previous
second. Timestamp files are deleted after their data have been collected.
The collector daemon runs with no inter-process communication and can be stopped if no longer necessary.