Revision 5e19e357b79a1626c3f27e918e50d21e3fe66c74 authored by Diane Gallois-Wong on 03 October 2022, 16:23:32 UTC, committed by Marge Bot on 10 October 2022, 09:36:45 UTC
- Validate: rename application_info to block_finalization_info - Validate: remove unneeded Alpha_context - Apply: update module name Validate_operation -> Validate in a comment - Apply & Contract_storage: use Lwt_tzresult_syntax (notably, fail is now implicitly Error_monad.fail)
1 parent c3a3cf5
stat_services.ml
(*****************************************************************************)
(* Open Source License *)
(* Copyright (c) 2018 Nomadic Labs, <contact@nomadic-labs.com> *)
(* *)
(* Permission is hereby granted, free of charge, to any person obtaining a *)
(* copy of this software and associated documentation files (the "Software"),*)
(* to deal in the Software without restriction, including without limitation *)
(* the rights to use, copy, modify, merge, publish, distribute, sublicense, *)
(* and/or sell copies of the Software, and to permit persons to whom the *)
(* Software is furnished to do so, subject to the following conditions: *)
(* *)
(* The above copyright notice and this permission notice shall be included *)
(* in all copies or substantial portions of the Software. *)
(* *)
(* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR*)
(* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, *)
(* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL *)
(* THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER*)
(* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING *)
(* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER *)
(* DEALINGS IN THE SOFTWARE. *)
(* *)
(*****************************************************************************)
open Gc
let gc_stat_encoding =
let open Data_encoding in
conv
(fun {
minor_words;
promoted_words;
major_words;
minor_collections;
major_collections;
forced_major_collections;
heap_words;
heap_chunks;
live_words;
live_blocks;
free_words;
free_blocks;
largest_free;
fragments;
compactions;
top_heap_words;
stack_size;
} ->
( ( minor_words,
promoted_words,
major_words,
minor_collections,
major_collections,
forced_major_collections ),
( (heap_words, heap_chunks, live_words, live_blocks, free_words),
( free_blocks,
largest_free,
fragments,
compactions,
top_heap_words,
stack_size ) ) ))
(fun ( ( minor_words,
promoted_words,
major_words,
minor_collections,
major_collections,
forced_major_collections ),
( (heap_words, heap_chunks, live_words, live_blocks, free_words),
( free_blocks,
largest_free,
fragments,
compactions,
top_heap_words,
stack_size ) ) ) ->
{
minor_words;
promoted_words;
major_words;
minor_collections;
major_collections;
forced_major_collections;
heap_words;
heap_chunks;
live_words;
live_blocks;
free_words;
free_blocks;
largest_free;
fragments;
compactions;
top_heap_words;
stack_size;
})
(merge_objs
(obj6
(req "minor_words" float)
(req "promoted_words" float)
(req "major_words" float)
(req "minor_collections" int31)
(req "major_collections" int31)
(req "forced_major_collections" int31))
(merge_objs
(obj5
(req "heap_words" int31)
(req "heap_chunks" int31)
(req "live_words" int31)
(req "live_blocks" int31)
(req "free_words" int31))
(obj6
(req "free_blocks" int31)
(req "largest_free" int31)
(req "fragments" int31)
(req "compactions" int31)
(req "top_heap_words" int31)
(req "stack_size" int31))))
let proc_stat_encoding =
let open Memory in
let open Data_encoding in
union
~tag_size:`Uint8
[
case
(Tag 0)
(conv
(fun {page_size; size; resident; shared; text; lib; data; dt} ->
(page_size, size, resident, shared, text, lib, data, dt))
(fun (page_size, size, resident, shared, text, lib, data, dt) ->
{page_size; size; resident; shared; text; lib; data; dt})
(obj8
(req "page_size" int31)
(req "size" int64)
(req "resident" int64)
(req "shared" int64)
(req "text" int64)
(req "lib" int64)
(req "data" int64)
(req "dt" int64)))
~title:"Linux_proc_statm"
(function Statm x -> Some x | _ -> None)
(function res -> Statm res);
case
(Tag 1)
(conv
(fun {page_size; mem; resident} -> (page_size, mem, resident))
(fun (page_size, mem, resident) -> {page_size; mem; resident})
(obj3
(req "page_size" int31)
(req "mem" float)
(req "resident" int64)))
~title:"Darwin_ps"
(function Ps x -> Some x | _ -> None)
(function res -> Ps res);
]
module S = struct
let gc =
RPC_service.get_service
~description:"Gets stats from the OCaml Garbage Collector"
~query:RPC_query.empty
~output:gc_stat_encoding
RPC_path.(root / "stats" / "gc")
let memory =
RPC_service.get_service
~description:"Gets memory usage stats"
~query:RPC_query.empty
~output:proc_stat_encoding
RPC_path.(root / "stats" / "memory")
end
let gc ctxt = RPC_context.make_call S.gc ctxt () () ()
let memory ctxt = RPC_context.make_call S.memory ctxt () () ()
Computing file changes ...