2015-12-30 04:52:24 -05:00
|
|
|
(* Copyright (C) 2015, Thomas Leonard <thomas.leonard@unikernel.com>
|
|
|
|
See the README file for details. *)
|
|
|
|
|
2016-01-02 10:59:59 -05:00
|
|
|
open Lwt
|
|
|
|
|
|
|
|
let src = Logs.Src.create "memory_pressure" ~doc:"Memory pressure monitor"
|
|
|
|
module Log = (val Logs.src_log src : Logs.LOG)
|
|
|
|
|
2020-08-19 09:09:01 -04:00
|
|
|
let wordsize_in_bytes = Sys.word_size / 8
|
|
|
|
|
|
|
|
let fraction_free stats =
|
|
|
|
let { OS.Memory.free_words; heap_words; _ } = stats in
|
|
|
|
float free_words /. float heap_words
|
|
|
|
|
|
|
|
let meminfo stats =
|
|
|
|
let { OS.Memory.free_words; heap_words; _ } = stats in
|
|
|
|
let mem_total = heap_words * wordsize_in_bytes in
|
|
|
|
let mem_free = free_words * wordsize_in_bytes in
|
|
|
|
Log.info (fun f -> f "Writing meminfo: free %a / %a (%.2f %%)"
|
|
|
|
Fmt.bi_byte_size mem_free
|
|
|
|
Fmt.bi_byte_size mem_total
|
|
|
|
(fraction_free stats *. 100.0));
|
2016-01-02 10:59:59 -05:00
|
|
|
Printf.sprintf "MemTotal: %d kB\n\
|
|
|
|
MemFree: %d kB\n\
|
|
|
|
Buffers: 0 kB\n\
|
|
|
|
Cached: 0 kB\n\
|
|
|
|
SwapTotal: 0 kB\n\
|
2020-08-19 09:09:01 -04:00
|
|
|
SwapFree: 0 kB\n" (mem_total / 1024) (mem_free / 1024)
|
2016-01-02 10:59:59 -05:00
|
|
|
|
2020-08-19 09:09:01 -04:00
|
|
|
let report_mem_usage stats =
|
2016-01-02 10:59:59 -05:00
|
|
|
Lwt.async (fun () ->
|
2020-01-11 08:34:25 -05:00
|
|
|
let open OS in
|
2016-01-02 10:59:59 -05:00
|
|
|
Xs.make () >>= fun xs ->
|
|
|
|
Xs.immediate xs (fun h ->
|
2020-08-19 09:09:01 -04:00
|
|
|
Xs.write h "memory/meminfo" (meminfo stats)
|
2016-01-02 10:59:59 -05:00
|
|
|
)
|
|
|
|
)
|
|
|
|
|
|
|
|
let init () =
|
|
|
|
Gc.full_major ();
|
2020-08-19 09:09:01 -04:00
|
|
|
let stats = OS.Memory.quick_stat () in
|
|
|
|
report_mem_usage stats
|
2015-12-30 04:52:24 -05:00
|
|
|
|
|
|
|
let status () =
|
2020-08-19 09:09:01 -04:00
|
|
|
let stats = OS.Memory.quick_stat () in
|
|
|
|
if fraction_free stats > 0.1 then `Ok
|
2015-12-30 04:52:24 -05:00
|
|
|
else (
|
|
|
|
Gc.full_major ();
|
2020-08-19 09:09:01 -04:00
|
|
|
let stats = OS.Memory.quick_stat () in
|
|
|
|
report_mem_usage stats;
|
|
|
|
if fraction_free stats < 0.1 then `Memory_critical
|
2015-12-30 04:52:24 -05:00
|
|
|
else `Ok
|
|
|
|
)
|