2015-12-30 09:52:24 +00:00
|
|
|
(* Copyright (C) 2015, Thomas Leonard <thomas.leonard@unikernel.com>
|
|
|
|
See the README file for details. *)
|
|
|
|
|
2016-01-02 15:59:59 +00:00
|
|
|
let src = Logs.Src.create "memory_pressure" ~doc:"Memory pressure monitor"
|
|
|
|
module Log = (val Logs.src_log src : Logs.LOG)
|
|
|
|
|
2020-08-19 14:09:01 +01:00
|
|
|
let fraction_free stats =
|
2022-03-30 03:12:01 -04:00
|
|
|
let { Xen_os.Memory.free_words; heap_words; _ } = stats in
|
2020-08-19 14:09:01 +01:00
|
|
|
float free_words /. float heap_words
|
|
|
|
|
2016-01-02 15:59:59 +00:00
|
|
|
let init () =
|
2023-05-26 10:27:29 +02:00
|
|
|
Gc.full_major ()
|
2015-12-30 09:52:24 +00:00
|
|
|
|
|
|
|
let status () =
|
2022-03-30 03:12:01 -04:00
|
|
|
let stats = Xen_os.Memory.quick_stat () in
|
2022-09-05 10:01:15 +02:00
|
|
|
if fraction_free stats > 0.5 then `Ok
|
2015-12-30 09:52:24 +00:00
|
|
|
else (
|
|
|
|
Gc.full_major ();
|
2022-07-27 14:26:58 +02:00
|
|
|
Xen_os.Memory.trim ();
|
2022-03-30 03:12:01 -04:00
|
|
|
let stats = Xen_os.Memory.quick_stat () in
|
2023-05-26 10:27:29 +02:00
|
|
|
if fraction_free stats < 0.6 then `Memory_critical
|
|
|
|
else `Ok
|
2015-12-30 09:52:24 +00:00
|
|
|
)
|