semantic logging for client baking

AMENDED: Syn has always been DSL, Semantic has always been
Make_semantic.
This commit is contained in:
dbornside 2018-06-12 15:07:50 -04:00 committed by Pierre Boutillier
parent 98961c9335
commit e7dba18980
47 changed files with 720 additions and 290 deletions

View File

@ -7,7 +7,10 @@
(* *) (* *)
(**************************************************************************) (**************************************************************************)
let log = Signer_logging.lwt_log_notice open Signer_logging
let log = lwt_log_notice
module Authorized_key = module Authorized_key =
Client_aliases.Alias (struct Client_aliases.Alias (struct
@ -32,10 +35,12 @@ let sign
(cctxt : #Client_context.wallet) (cctxt : #Client_context.wallet)
Signer_messages.Sign.Request.{ pkh ; data ; signature } Signer_messages.Sign.Request.{ pkh ; data ; signature }
?magic_bytes ~require_auth = ?magic_bytes ~require_auth =
log "Request for signing %d bytes of data for key %a, magic byte = %02X" log Tag.DSL.(fun f ->
(MBytes.length data) f "Request for signing %d bytes of data for key %a, magic byte = %02X"
Signature.Public_key_hash.pp pkh -% t event "request_for_signing"
(MBytes.get_uint8 data 0) >>= fun () -> -% s num_bytes (MBytes.length data)
-% a Signature.Public_key_hash.Logging.tag pkh
-% s magic_byte (MBytes.get_uint8 data 0)) >>= fun () ->
check_magic_byte magic_bytes data >>=? fun () -> check_magic_byte magic_bytes data >>=? fun () ->
begin match require_auth, signature with begin match require_auth, signature with
| false, _ -> return_unit | false, _ -> return_unit
@ -52,24 +57,36 @@ let sign
failwith "invalid authentication signature" failwith "invalid authentication signature"
end >>=? fun () -> end >>=? fun () ->
Client_keys.get_key cctxt pkh >>=? fun (name, _pkh, sk_uri) -> Client_keys.get_key cctxt pkh >>=? fun (name, _pkh, sk_uri) ->
log "Signing data for key %s" name >>= fun () -> log Tag.DSL.(fun f ->
f "Signing data for key %s"
-% t event "signing_data"
-% s Client_keys.Logging.tag name) >>= fun () ->
Client_keys.sign cctxt sk_uri data >>=? fun signature -> Client_keys.sign cctxt sk_uri data >>=? fun signature ->
return signature return signature
let public_key (cctxt : #Client_context.wallet) pkh = let public_key (cctxt : #Client_context.wallet) pkh =
log "Request for public key %a" log Tag.DSL.(fun f ->
Signature.Public_key_hash.pp pkh >>= fun () -> f "Request for public key %a"
-% t event "request_for_public_key"
-% a Signature.Public_key_hash.Logging.tag pkh) >>= fun () ->
Client_keys.list_keys cctxt >>=? fun all_keys -> Client_keys.list_keys cctxt >>=? fun all_keys ->
match List.find (fun (_, h, _, _) -> Signature.Public_key_hash.equal h pkh) all_keys with match List.find (fun (_, h, _, _) -> Signature.Public_key_hash.equal h pkh) all_keys with
| exception Not_found -> | exception Not_found ->
log "No public key found for hash %a" log Tag.DSL.(fun f ->
Signature.Public_key_hash.pp pkh >>= fun () -> f "No public key found for hash %a"
-% t event "not_found_public_key"
-% a Signature.Public_key_hash.Logging.tag pkh) >>= fun () ->
Lwt.fail Not_found Lwt.fail Not_found
| (_, _, None, _) -> | (_, _, None, _) ->
log "No public key found for hash %a" log Tag.DSL.(fun f ->
Signature.Public_key_hash.pp pkh >>= fun () -> f "No public key found for hash %a"
-% t event "not_found_public_key"
-% a Signature.Public_key_hash.Logging.tag pkh) >>= fun () ->
Lwt.fail Not_found Lwt.fail Not_found
| (name, _, Some pk, _) -> | (name, _, Some pk, _) ->
log "Found public key for hash %a (name: %s)" log Tag.DSL.(fun f ->
Signature.Public_key_hash.pp pkh name >>= fun () -> f "Found public key for hash %a (name: %s)"
-% t event "found_public_key"
-% a Signature.Public_key_hash.Logging.tag pkh
-% s Client_keys.Logging.tag name) >>= fun () ->
return pk return pk

View File

@ -8,6 +8,7 @@
(**************************************************************************) (**************************************************************************)
let log = Signer_logging.lwt_log_notice let log = Signer_logging.lwt_log_notice
open Signer_logging
let run (cctxt : #Client_context.wallet) ~hosts ?magic_bytes ~require_auth mode = let run (cctxt : #Client_context.wallet) ~hosts ?magic_bytes ~require_auth mode =
let dir = RPC_directory.empty in let dir = RPC_directory.empty in
@ -32,7 +33,10 @@ let run (cctxt : #Client_context.wallet) ~hosts ?magic_bytes ~require_auth mode
List.map List.map
(fun host -> (fun host ->
let host = Ipaddr.V6.to_string host in let host = Ipaddr.V6.to_string host in
log "Listening on address %s" host >>= fun () -> log Tag.DSL.(fun f ->
f "Listening on address %s"
-% t event "signer_listening"
-% s host_name host) >>= fun () ->
RPC_server.launch ~host mode dir RPC_server.launch ~host mode dir
~media_types:Media_type.all_media_types ~media_types:Media_type.all_media_types
>>= fun _server -> >>= fun _server ->
@ -49,7 +53,10 @@ let run_https (cctxt : #Client_context.wallet) ~host ~port ~cert ~key ?magic_byt
failwith "Cannot resolve listening address: %S" host failwith "Cannot resolve listening address: %S" host
| points -> | points ->
let hosts = fst (List.split points) in let hosts = fst (List.split points) in
log "Accepting HTTPS requests on port %d" port >>= fun () -> log Tag.DSL.(fun f ->
f "Accepting HTTPS requests on port %d"
-% t event "accepting_https_requests"
-% s port_number port) >>= fun () ->
let mode : Conduit_lwt_unix.server = let mode : Conduit_lwt_unix.server =
`TLS (`Crt_file_path cert, `Key_file_path key, `No_password, `Port port) in `TLS (`Crt_file_path cert, `Key_file_path key, `No_password, `Port port) in
run (cctxt : #Client_context.wallet) ~hosts ?magic_bytes ~require_auth mode run (cctxt : #Client_context.wallet) ~hosts ?magic_bytes ~require_auth mode
@ -60,7 +67,10 @@ let run_http (cctxt : #Client_context.wallet) ~host ~port ?magic_bytes ~require_
failwith "Cannot resolve listening address: %S" host failwith "Cannot resolve listening address: %S" host
| points -> | points ->
let hosts = fst (List.split points) in let hosts = fst (List.split points) in
log "Accepting HTTP requests on port %d" port >>= fun () -> log Tag.DSL.(fun f ->
f "Accepting HTTP requests on port %d"
-% t event "accepting_http_requests"
-% s port_number port) >>= fun () ->
let mode : Conduit_lwt_unix.server = let mode : Conduit_lwt_unix.server =
`TCP (`Port port) in `TCP (`Port port) in
run (cctxt : #Client_context.wallet) ~hosts ?magic_bytes ~require_auth mode run (cctxt : #Client_context.wallet) ~hosts ?magic_bytes ~require_auth mode

View File

@ -7,4 +7,10 @@
(* *) (* *)
(**************************************************************************) (**************************************************************************)
include Tezos_stdlib.Logging.Make(struct let name = "client.signer" end) include Tezos_stdlib.Logging.Make_semantic(struct let name = "client.signer" end)
let host_name = Tag.def ~doc:"Host name" "host" Format.pp_print_text
let magic_byte = Tag.def ~doc:"Magic byte" "magic_byte" Format.pp_print_int
let num_bytes = Tag.def ~doc:"Number of bytes" "num_bytes" Format.pp_print_int
let port_number = Tag.def ~doc:"Port number" "port" Format.pp_print_int
let unix_socket_path = Tag.def ~doc:"UNIX socket file path" "unix_socket" Format.pp_print_text

View File

@ -7,4 +7,10 @@
(* *) (* *)
(**************************************************************************) (**************************************************************************)
include Tezos_stdlib.Logging.LOG include Tezos_stdlib.Logging.SEMLOG
val host_name: string Tag.def
val magic_byte: int Tag.def
val num_bytes: int Tag.def
val port_number: int Tag.def
val unix_socket_path: string Tag.def

View File

@ -7,9 +7,10 @@
(* *) (* *)
(**************************************************************************) (**************************************************************************)
open Signer_logging
open Signer_messages open Signer_messages
let log = Signer_logging.lwt_log_notice let log = lwt_log_notice
let run (cctxt : #Client_context.wallet) path ?magic_bytes ~require_auth = let run (cctxt : #Client_context.wallet) path ?magic_bytes ~require_auth =
Lwt_utils_unix.Socket.bind path >>=? fun fd -> Lwt_utils_unix.Socket.bind path >>=? fun fd ->
@ -46,13 +47,20 @@ let run (cctxt : #Client_context.wallet) path ?magic_bytes ~require_auth =
begin begin
match path with match path with
| Tcp (host, port) -> | Tcp (host, port) ->
log "Accepting TCP requests on port %s:%d" host port log Tag.DSL.(fun f ->
f "Accepting TCP requests on port %s:%d"
-% t event "accepting_tcp_requests"
-% s host_name host
-% s port_number port)
| Unix path -> | Unix path ->
Sys.set_signal Sys.sigint (Signal_handle begin fun _ -> Sys.set_signal Sys.sigint (Signal_handle begin fun _ ->
Format.printf "Removing the local socket file and quitting.@." ; Format.printf "Removing the local socket file and quitting.@." ;
Unix.unlink path ; Unix.unlink path ;
exit 0 exit 0
end) ; end) ;
log "Accepting UNIX requests on %s" path log Tag.DSL.(fun f ->
f "Accepting UNIX requests on %s"
-% t event "accepting_unix_requests"
-% s unix_socket_path path)
end >>= fun () -> end >>= fun () ->
loop () loop ()

View File

@ -133,6 +133,8 @@ type step = {
strict_step: bool ; strict_step: bool ;
} }
let pp_step ppf step = Format.fprintf ppf "%d%s" step.step (if step.strict_step then "" else " max")
let to_steps seed locator = let to_steps seed locator =
fold locator seed fold locator seed
~init:[] ~init:[]

View File

@ -50,6 +50,8 @@ type step = {
locator, and the expected difference of level between the two locator, and the expected difference of level between the two
blocks (or an upper bounds when [strict_step = false]). *) blocks (or an upper bounds when [strict_step = false]). *)
val pp_step: Format.formatter -> step -> unit
val to_steps: seed -> t -> step list val to_steps: seed -> t -> step list
(** Build all the 'steps' composing the locator using a given seed, (** Build all the 'steps' composing the locator using a given seed,
starting with the oldest one (typically the predecessor of the starting with the oldest one (typically the predecessor of the

View File

@ -15,3 +15,17 @@ let rpc_arg =
~descr:"A cryptographic node identity (Base58Check-encoded)" ~descr:"A cryptographic node identity (Base58Check-encoded)"
"peer_id" "peer_id"
let pp_source ppf = function
| None -> ()
| Some peer -> Format.fprintf ppf " from peer %a" pp peer
module Logging = struct
open Tezos_stdlib.Logging
include Make_semantic(struct let name = "node.distributed_db.p2p_reader" end)
let mk_tag pp = Tag.def ~doc:"P2P peer ID" "p2p_peer_id" pp
let tag = mk_tag pp_short
let tag_opt = mk_tag (fun ppf -> function
| None -> ()
| Some peer -> pp_short ppf peer)
let tag_source = Tag.def ~doc:"Peer which provided information" "p2p_peer_id_source" pp_source
end

View File

@ -8,3 +8,9 @@
(**************************************************************************) (**************************************************************************)
include Tezos_crypto.S.HASH with type t = Crypto_box.Public_key_hash.t include Tezos_crypto.S.HASH with type t = Crypto_box.Public_key_hash.t
module Logging: sig
val tag: t Tag.def
val tag_opt: t option Tag.def
val tag_source: t option Tag.def
end

View File

@ -33,13 +33,19 @@ let () =
(function Invalid_uri s -> Some (Uri.to_string s) | _ -> None) (function Invalid_uri s -> Some (Uri.to_string s) | _ -> None)
(fun s -> Invalid_uri (Uri.of_string s)) (fun s -> Invalid_uri (Uri.of_string s))
module Public_key_hash = Client_aliases.Alias (struct module Public_key_hash = struct
type t = Signature.Public_key_hash.t include Client_aliases.Alias (struct
let encoding = Signature.Public_key_hash.encoding type t = Signature.Public_key_hash.t
let of_source s = Lwt.return (Signature.Public_key_hash.of_b58check s) let encoding = Signature.Public_key_hash.encoding
let to_source p = return (Signature.Public_key_hash.to_b58check p) let of_source s = Lwt.return (Signature.Public_key_hash.of_b58check s)
let name = "public key hash" let to_source p = return (Signature.Public_key_hash.to_b58check p)
end) let name = "public key hash"
end)
end
module Logging = struct
let tag = Tag.def ~doc:"Identity" "pk_alias" Format.pp_print_text
end
module type KEY = sig module type KEY = sig
type t type t

View File

@ -29,6 +29,10 @@ module Public_key :
module Secret_key : module Secret_key :
Client_aliases.Alias with type t = sk_uri Client_aliases.Alias with type t = sk_uri
module Logging : sig
val tag : string Tag.def
end
(** {2 Interface for external signing modules.} *) (** {2 Interface for external signing modules.} *)
module type SIGNER = sig module type SIGNER = sig

View File

@ -14,5 +14,11 @@ include Blake2B.Make (Base58) (struct
let size = None let size = None
end) end)
module Logging = struct
let tag = Tag.def ~doc:"Block Hash" "block_hash" pp_short
let predecessor_tag = Tag.def ~doc:"Block Predecessor Hash" "predecessor_hash" pp_short
end
let () = let () =
Base58.check_encoded_prefix b58check_encoding "B" 51 Base58.check_encoded_prefix b58check_encoding "B" 51

View File

@ -8,3 +8,8 @@
(**************************************************************************) (**************************************************************************)
include S.HASH include S.HASH
module Logging : sig
val tag : t Tag.def
val predecessor_tag : t Tag.def
end

View File

@ -9,13 +9,17 @@
open Error_monad open Error_monad
module Public_key_hash = Blake2B.Make(Base58)(struct module Public_key_hash = struct
let name = "Ed25519.Public_key_hash" include Blake2B.Make(Base58)(struct
let title = "An Ed25519 public key hash" let name = "Ed25519.Public_key_hash"
let b58check_prefix = Base58.Prefix.ed25519_public_key_hash let title = "An Ed25519 public key hash"
let size = Some 20 let b58check_prefix = Base58.Prefix.ed25519_public_key_hash
end) let size = Some 20
end)
module Logging = struct
let tag = Tag.def ~doc:title name pp
end
end
let () = let () =
Base58.check_encoded_prefix Public_key_hash.b58check_encoding "tz1" 36 Base58.check_encoded_prefix Public_key_hash.b58check_encoding "tz1" 36

View File

@ -17,3 +17,6 @@ include Blake2B.Make (Base58) (struct
let () = let () =
Base58.check_encoded_prefix b58check_encoding "o" 51 Base58.check_encoded_prefix b58check_encoding "o" 51
module Logging = struct
let tag = Tag.def ~doc:title name pp
end

View File

@ -8,3 +8,7 @@
(**************************************************************************) (**************************************************************************)
include S.HASH include S.HASH
module Logging : sig
val tag : t Tag.def
end

View File

@ -7,12 +7,18 @@
(* *) (* *)
(**************************************************************************) (**************************************************************************)
module Public_key_hash = Blake2B.Make(Base58)(struct module Public_key_hash = struct
let name = "P256.Public_key_hash" include Blake2B.Make(Base58)(struct
let title = "A P256 public key hash" let name = "P256.Public_key_hash"
let b58check_prefix = Base58.Prefix.p256_public_key_hash let title = "A P256 public key hash"
let size = Some 20 let b58check_prefix = Base58.Prefix.p256_public_key_hash
end) let size = Some 20
end)
module Logging = struct
let tag = Tag.def ~doc:title name pp
end
end
let () = let () =
Base58.check_encoded_prefix Public_key_hash.b58check_encoding "tz3" 36 Base58.check_encoded_prefix Public_key_hash.b58check_encoding "tz3" 36

View File

@ -17,3 +17,6 @@ include Blake2B.Make (Base58) (struct
let () = let () =
Base58.check_encoded_prefix b58check_encoding "P" 51 Base58.check_encoded_prefix b58check_encoding "P" 51
module Logging = struct
let tag = Tag.def ~doc:title name pp
end

View File

@ -8,3 +8,7 @@
(**************************************************************************) (**************************************************************************)
include S.HASH include S.HASH
module Logging : sig
val tag : t Tag.def
end

View File

@ -169,6 +169,9 @@ module type SIGNATURE = sig
val zero: t val zero: t
module Logging : sig
val tag : t Tag.def
end
end end
module Public_key : sig module Public_key : sig

View File

@ -7,12 +7,17 @@
(* *) (* *)
(**************************************************************************) (**************************************************************************)
module Public_key_hash = Blake2B.Make(Base58)(struct module Public_key_hash = struct
let name = "Secp256k1.Public_key_hash" include Blake2B.Make(Base58)(struct
let title = "A Secp256k1 public key hash" let name = "Secp256k1.Public_key_hash"
let b58check_prefix = Base58.Prefix.secp256k1_public_key_hash let title = "A Secp256k1 public key hash"
let size = Some 20 let b58check_prefix = Base58.Prefix.secp256k1_public_key_hash
end) let size = Some 20
end)
module Logging = struct
let tag = Tag.def ~doc:title name pp
end
end
let () = let () =
Base58.check_encoded_prefix Public_key_hash.b58check_encoding "tz2" 36 Base58.check_encoded_prefix Public_key_hash.b58check_encoding "tz2" 36

View File

@ -193,6 +193,9 @@ module Public_key_hash = struct
~descr:"A Secp256k1 of a Ed25519 public key hash (Base58Check-encoded)" ~descr:"A Secp256k1 of a Ed25519 public key hash (Base58Check-encoded)"
"pkh" "pkh"
module Logging = struct
let tag = Tag.def ~doc:title name pp
end
end end
module Public_key = struct module Public_key = struct

View File

@ -711,3 +711,5 @@ let with_timeout ?(canceler = Lwt_canceler.create ()) timeout f =
Lwt_canceler.cancel canceler >>= fun () -> Lwt_canceler.cancel canceler >>= fun () ->
fail Timeout fail Timeout
end end
let errs_tag = Tag.def ~doc:"Errors" "errs" pp_print_error

View File

@ -69,3 +69,5 @@ module Make(Prefix : sig val id : string end) : Error_monad_sig.S
(**/**) (**/**)
val json_to_string : (Data_encoding.json -> string) ref val json_to_string : (Data_encoding.json -> string) ref
val errs_tag : error list Tag.def

View File

@ -7,7 +7,10 @@
(* *) (* *)
(**************************************************************************) (**************************************************************************)
include Logging.Make(struct let name = "node.validator.bootstrap_pipeline" end) include Logging.Make_semantic(struct let name = "node.validator.bootstrap_pipeline" end)
let node_time_tag = Tag.def ~doc:"local time at this node" "node_time" Time.pp_hum
let block_time_tag = Tag.def ~doc:"claimed creation time of block" "block_time" Time.pp_hum
open Validation_errors open Validation_errors
@ -31,6 +34,8 @@ type t = {
mutable errors: Error_monad.error list ; mutable errors: Error_monad.error list ;
} }
let operations_index_tag = Tag.def ~doc:"Operations index" "operations_index" Format.pp_print_int
let assert_acceptable_header pipeline let assert_acceptable_header pipeline
hash (header : Block_header.t) = hash (header : Block_header.t) =
let chain_state = Distributed_db.chain_state pipeline.chain_db in let chain_state = Distributed_db.chain_state pipeline.chain_db in
@ -60,29 +65,36 @@ let assert_acceptable_header pipeline
return_unit return_unit
let fetch_step pipeline (step : Block_locator.step) = let fetch_step pipeline (step : Block_locator.step) =
lwt_log_info "fetching step %a -> %a (%d%s) from peer %a." lwt_log_info Tag.DSL.(fun f ->
Block_hash.pp_short step.block f "fetching step %a -> %a (%a) from peer %a."
Block_hash.pp_short step.predecessor -% t event "fetching_step_from_peer"
step.step -% a Block_hash.Logging.tag step.block
(if step.strict_step then "" else " max") -% a Block_hash.Logging.predecessor_tag step.predecessor
P2p_peer.Id.pp_short pipeline.peer_id >>= fun () -> -% a (Tag.def ~doc:"" "" Block_locator.pp_step) step
-% a P2p_peer.Id.Logging.tag pipeline.peer_id) >>= fun () ->
let rec fetch_loop acc hash cpt = let rec fetch_loop acc hash cpt =
Lwt_unix.yield () >>= fun () -> Lwt_unix.yield () >>= fun () ->
if cpt < 0 then if cpt < 0 then
lwt_log_info "invalid step from peer %a (too long)." lwt_log_info Tag.DSL.(fun f ->
P2p_peer.Id.pp_short pipeline.peer_id >>= fun () -> f "invalid step from peer %a (too long)."
-% t event "step_too_long"
-% a P2p_peer.Id.Logging.tag pipeline.peer_id) >>= fun () ->
fail (Invalid_locator (pipeline.peer_id, pipeline.locator)) fail (Invalid_locator (pipeline.peer_id, pipeline.locator))
else if Block_hash.equal hash step.predecessor then else if Block_hash.equal hash step.predecessor then
if step.strict_step && cpt <> 0 then if step.strict_step && cpt <> 0 then
lwt_log_info "invalid step from peer %a (too short)." lwt_log_info Tag.DSL.(fun f ->
P2p_peer.Id.pp_short pipeline.peer_id >>= fun () -> f "invalid step from peer %a (too short)."
-% t event "step_too_short"
-% a P2p_peer.Id.Logging.tag pipeline.peer_id) >>= fun () ->
fail (Invalid_locator (pipeline.peer_id, pipeline.locator)) fail (Invalid_locator (pipeline.peer_id, pipeline.locator))
else else
return acc return acc
else else
lwt_debug "fetching block header %a from peer %a." lwt_debug Tag.DSL.(fun f ->
Block_hash.pp_short hash f "fetching block header %a from peer %a."
P2p_peer.Id.pp_short pipeline.peer_id >>= fun () -> -% t event "fetching_block_header_from_peer"
-% a Block_hash.Logging.tag hash
-% a P2p_peer.Id.Logging.tag pipeline.peer_id) >>= fun () ->
protect ~canceler:pipeline.canceler begin fun () -> protect ~canceler:pipeline.canceler begin fun () ->
Distributed_db.Block_header.fetch Distributed_db.Block_header.fetch
~timeout:pipeline.block_header_timeout ~timeout:pipeline.block_header_timeout
@ -90,9 +102,11 @@ let fetch_step pipeline (step : Block_locator.step) =
hash () hash ()
end >>=? fun header -> end >>=? fun header ->
assert_acceptable_header pipeline hash header >>=? fun () -> assert_acceptable_header pipeline hash header >>=? fun () ->
lwt_debug "fetched block header %a from peer %a." lwt_debug Tag.DSL.(fun f ->
Block_hash.pp_short hash f "fetched block header %a from peer %a."
P2p_peer.Id.pp_short pipeline.peer_id >>= fun () -> -% t event "fetched_block_header_from_peer"
-% a Block_hash.Logging.tag hash
-% a P2p_peer.Id.Logging.tag pipeline.peer_id) >>= fun () ->
fetch_loop ((hash, header) :: acc) header.shell.predecessor (cpt - 1) fetch_loop ((hash, header) :: acc) header.shell.predecessor (cpt - 1)
in in
fetch_loop [] step.block step.step >>=? fun headers -> fetch_loop [] step.block step.step >>=? fun headers ->
@ -116,31 +130,39 @@ let headers_fetch_worker_loop pipeline =
return_unit return_unit
end >>= function end >>= function
| Ok () -> | Ok () ->
lwt_log_info "fetched all step from peer %a." lwt_log_info Tag.DSL.(fun f ->
P2p_peer.Id.pp_short pipeline.peer_id >>= fun () -> f "fetched all steps from peer %a."
-% t event "fetched_all_steps_from_peer"
-% a P2p_peer.Id.Logging.tag pipeline.peer_id) >>= fun () ->
Lwt_pipe.close pipeline.fetched_headers ; Lwt_pipe.close pipeline.fetched_headers ;
Lwt.return_unit Lwt.return_unit
| Error [Exn Lwt.Canceled | Canceled | Exn Lwt_pipe.Closed] -> | Error [Exn Lwt.Canceled | Canceled | Exn Lwt_pipe.Closed] ->
Lwt.return_unit Lwt.return_unit
| Error [ Distributed_db.Block_header.Timeout bh ] -> | Error [ Distributed_db.Block_header.Timeout bh ] ->
lwt_log_info "request for header %a from peer %a timed out." lwt_log_info Tag.DSL.(fun f ->
Block_hash.pp_short bh f "request for header %a from peer %a timed out."
P2p_peer.Id.pp_short pipeline.peer_id >>= fun () -> -% t event "header_request_timeout"
-% a Block_hash.Logging.tag bh
-% a P2p_peer.Id.Logging.tag pipeline.peer_id) >>= fun () ->
Lwt_canceler.cancel pipeline.canceler >>= fun () -> Lwt_canceler.cancel pipeline.canceler >>= fun () ->
Lwt.return_unit Lwt.return_unit
| Error [ Future_block_header { block; block_time; time } ] -> | Error [ Future_block_header { block; block_time; time } ] ->
lwt_log_notice "Block locator %a from peer %a contains future blocks. \ lwt_log_notice Tag.DSL.(fun f ->
local time: %a, block time: %a" f "Block locator %a from peer %a contains future blocks. \
Block_hash.pp_short block local time: %a, block time: %a"
Time.pp_hum time -% t event "locator_contains_future_blocks"
Time.pp_hum block_time -% a Block_hash.Logging.tag block
P2p_peer.Id.pp_short pipeline.peer_id >>= fun () -> -% a P2p_peer.Id.Logging.tag pipeline.peer_id
-% a node_time_tag time
-% a block_time_tag block_time) >>= fun () ->
Lwt_canceler.cancel pipeline.canceler >>= fun () -> Lwt_canceler.cancel pipeline.canceler >>= fun () ->
Lwt.return_unit Lwt.return_unit
| Error err -> | Error err ->
pipeline.errors <- pipeline.errors @ err ; pipeline.errors <- pipeline.errors @ err ;
lwt_log_error "@[Unexpected error (headers fetch):@ %a@]" lwt_log_error Tag.DSL.(fun f ->
pp_print_error err >>= fun () -> f "@[Unexpected error (headers fetch):@ %a@]"
-% t event "unexpected_error"
-% a errs_tag err) >>= fun () ->
Lwt_canceler.cancel pipeline.canceler >>= fun () -> Lwt_canceler.cancel pipeline.canceler >>= fun () ->
Lwt.return_unit Lwt.return_unit
@ -150,9 +172,11 @@ let rec operations_fetch_worker_loop pipeline =
protect ~canceler:pipeline.canceler begin fun () -> protect ~canceler:pipeline.canceler begin fun () ->
Lwt_pipe.pop pipeline.fetched_headers >>= return Lwt_pipe.pop pipeline.fetched_headers >>= return
end >>=? fun (hash, header) -> end >>=? fun (hash, header) ->
lwt_log_info "fetching operations of block %a from peer %a." lwt_log_info Tag.DSL.(fun f ->
Block_hash.pp_short hash f "fetching operations of block %a from peer %a."
P2p_peer.Id.pp_short pipeline.peer_id >>= fun () -> -% t event "fetching_operations"
-% a Block_hash.Logging.tag hash
-% a P2p_peer.Id.Logging.tag pipeline.peer_id) >>= fun () ->
let operations = let operations =
map_p map_p
(fun i -> (fun i ->
@ -163,9 +187,11 @@ let rec operations_fetch_worker_loop pipeline =
(hash, i) header.shell.operations_hash (hash, i) header.shell.operations_hash
end) end)
(0 -- (header.shell.validation_passes - 1)) >>=? fun operations -> (0 -- (header.shell.validation_passes - 1)) >>=? fun operations ->
lwt_log_info "fetched operations of block %a from peer %a." lwt_log_info Tag.DSL.(fun f ->
Block_hash.pp_short hash f "fetched operations of block %a from peer %a."
P2p_peer.Id.pp_short pipeline.peer_id >>= fun () -> -% t event "fetched_operations"
-% a Block_hash.Logging.tag hash
-% a P2p_peer.Id.Logging.tag pipeline.peer_id) >>= fun () ->
return operations in return operations in
protect ~canceler:pipeline.canceler begin fun () -> protect ~canceler:pipeline.canceler begin fun () ->
Lwt_pipe.push pipeline.fetched_blocks Lwt_pipe.push pipeline.fetched_blocks
@ -178,15 +204,20 @@ let rec operations_fetch_worker_loop pipeline =
Lwt_pipe.close pipeline.fetched_blocks ; Lwt_pipe.close pipeline.fetched_blocks ;
Lwt.return_unit Lwt.return_unit
| Error [ Distributed_db.Operations.Timeout (bh, n) ] -> | Error [ Distributed_db.Operations.Timeout (bh, n) ] ->
lwt_log_info "request for operations %a:%d from peer %a timed out." lwt_log_info Tag.DSL.(fun f ->
Block_hash.pp_short bh n f "request for operations %a:%d from peer %a timed out."
P2p_peer.Id.pp_short pipeline.peer_id >>= fun () -> -% t event "request_operations_timeout"
-% a Block_hash.Logging.tag bh
-% s operations_index_tag n
-% a P2p_peer.Id.Logging.tag pipeline.peer_id) >>= fun () ->
Lwt_canceler.cancel pipeline.canceler >>= fun () -> Lwt_canceler.cancel pipeline.canceler >>= fun () ->
Lwt.return_unit Lwt.return_unit
| Error err -> | Error err ->
pipeline.errors <- pipeline.errors @ err ; pipeline.errors <- pipeline.errors @ err ;
lwt_log_error "@[Unexpected error (operations fetch):@ %a@]" lwt_log_error Tag.DSL.(fun f ->
pp_print_error err >>= fun () -> f "@[Unexpected error (operations fetch):@ %a@]"
-% t event "unexpected_error"
-% a errs_tag err) >>= fun () ->
Lwt_canceler.cancel pipeline.canceler >>= fun () -> Lwt_canceler.cancel pipeline.canceler >>= fun () ->
Lwt.return_unit Lwt.return_unit
@ -196,9 +227,11 @@ let rec validation_worker_loop pipeline =
protect ~canceler:pipeline.canceler begin fun () -> protect ~canceler:pipeline.canceler begin fun () ->
Lwt_pipe.pop pipeline.fetched_blocks >>= return Lwt_pipe.pop pipeline.fetched_blocks >>= return
end >>=? fun (hash, header, operations) -> end >>=? fun (hash, header, operations) ->
lwt_log_info "requesting validation for block %a from peer %a." lwt_log_info Tag.DSL.(fun f ->
Block_hash.pp_short hash f "requesting validation for block %a from peer %a."
P2p_peer.Id.pp_short pipeline.peer_id >>= fun () -> -% t event "requesting_validation"
-% a Block_hash.Logging.tag hash
-% a P2p_peer.Id.Logging.tag pipeline.peer_id) >>= fun () ->
operations >>=? fun operations -> operations >>=? fun operations ->
protect ~canceler:pipeline.canceler begin fun () -> protect ~canceler:pipeline.canceler begin fun () ->
Block_validator.validate Block_validator.validate
@ -207,9 +240,11 @@ let rec validation_worker_loop pipeline =
pipeline.block_validator pipeline.block_validator
pipeline.chain_db hash header operations pipeline.chain_db hash header operations
end >>=? fun _block -> end >>=? fun _block ->
lwt_log_info "validated block %a from peer %a." lwt_log_info Tag.DSL.(fun f ->
Block_hash.pp_short hash f "validated block %a from peer %a."
P2p_peer.Id.pp_short pipeline.peer_id >>= fun () -> -% t event "validated_block"
-% a Block_hash.Logging.tag hash
-% a P2p_peer.Id.Logging.tag pipeline.peer_id) >>= fun () ->
return_unit return_unit
end >>= function end >>= function
| Ok () -> validation_worker_loop pipeline | Ok () -> validation_worker_loop pipeline
@ -223,8 +258,10 @@ let rec validation_worker_loop pipeline =
Lwt.return_unit Lwt.return_unit
| Error err -> | Error err ->
pipeline.errors <- pipeline.errors @ err ; pipeline.errors <- pipeline.errors @ err ;
lwt_log_error "@[Unexpected error (validator):@ %a@]" lwt_log_error Tag.DSL.(fun f ->
pp_print_error err >>= fun () -> f "@[Unexpected error (validator):@ %a@]"
-% t event "unexpected_error"
-% a errs_tag err) >>= fun () ->
Lwt_canceler.cancel pipeline.canceler >>= fun () -> Lwt_canceler.cancel pipeline.canceler >>= fun () ->
Lwt.return_unit Lwt.return_unit

View File

@ -9,6 +9,8 @@
open State_logging open State_logging
let block_hash_tag = Tag.def ~doc:"Block hash" "block_hash" Block_hash.pp_short
let mempool_encoding = Mempool.encoding let mempool_encoding = Mempool.encoding
let genesis chain_state = let genesis chain_state =
@ -57,7 +59,10 @@ let locked_set_head chain_store data block =
if Block_hash.equal hash ancestor then if Block_hash.equal hash ancestor then
Lwt.return_unit Lwt.return_unit
else else
lwt_debug "pop_block %a" Block_hash.pp_short hash >>= fun () -> lwt_debug Tag.DSL.(fun f ->
f "pop_block %a"
-% t event "pop_block"
-% a block_hash_tag hash) >>= fun () ->
Store.Chain_data.In_main_branch.remove (chain_store, hash) >>= fun () -> Store.Chain_data.In_main_branch.remove (chain_store, hash) >>= fun () ->
State.Block.predecessor block >>= function State.Block.predecessor block >>= function
| Some predecessor -> | Some predecessor ->
@ -66,7 +71,10 @@ let locked_set_head chain_store data block =
in in
let push_block pred_hash block = let push_block pred_hash block =
let hash = State.Block.hash block in let hash = State.Block.hash block in
lwt_debug "push_block %a" Block_hash.pp_short hash >>= fun () -> lwt_debug Tag.DSL.(fun f ->
f "push_block %a"
-% t event "push_block"
-% a block_hash_tag hash) >>= fun () ->
Store.Chain_data.In_main_branch.store Store.Chain_data.In_main_branch.store
(chain_store, pred_hash) hash >>= fun () -> (chain_store, pred_hash) hash >>= fun () ->
Lwt.return hash Lwt.return hash

View File

@ -24,6 +24,10 @@ module Make_raw
val name : string val name : string
val encoding : t Data_encoding.t val encoding : t Data_encoding.t
val pp : Format.formatter -> t -> unit val pp : Format.formatter -> t -> unit
module Logging : sig
val tag : t Tag.def
end
end) end)
(Disk_table : (Disk_table :
Distributed_db_functors.DISK_TABLE with type key := Hash.t) Distributed_db_functors.DISK_TABLE with type key := Hash.t)
@ -164,6 +168,9 @@ module Raw_operation_hashes = struct
let encoding = let encoding =
let open Data_encoding in let open Data_encoding in
obj2 (req "block" Block_hash.encoding) (req "index" uint16) obj2 (req "block" Block_hash.encoding) (req "index" uint16)
module Logging = struct
let tag = Tag.def ~doc:"Operation hashes" "operation_hashes" pp
end
end) end)
(Operation_hashes_storage) (Operation_hashes_storage)
(Operations_table) (Operations_table)
@ -233,6 +240,9 @@ module Raw_operations = struct
let encoding = let encoding =
let open Data_encoding in let open Data_encoding in
obj2 (req "block" Block_hash.encoding) (req "index" uint16) obj2 (req "block" Block_hash.encoding) (req "index" uint16)
module Logging = struct
let tag = Tag.def ~doc:"Operations" "operations" pp
end
end) end)
(Operations_storage) (Operations_storage)
(Operations_table) (Operations_table)
@ -458,15 +468,18 @@ module P2p_reader = struct
f chain_db f chain_db
module Handle_msg_Logging = module Handle_msg_Logging =
Logging.Make(struct let name = "node.distributed_db.p2p_reader" end) Tezos_stdlib.Logging.Make_semantic(struct let name = "node.distributed_db.p2p_reader" end)
let handle_msg global_db state msg = let handle_msg global_db state msg =
let open Message in let open Message in
let open Handle_msg_Logging in let open Handle_msg_Logging in
lwt_debug "Read message from %a: %a" lwt_debug Tag.DSL.(fun f ->
P2p_peer.Id.pp_short state.gid Message.pp_json msg >>= fun () -> f "Read message from %a: %a"
-% t event "read_message"
-% a P2p_peer.Id.Logging.tag state.gid
-% a Message.Logging.tag msg) >>= fun () ->
match msg with match msg with
@ -497,9 +510,11 @@ module P2p_reader = struct
Lwt.return_unit Lwt.return_unit
end else if Time.(add (now ()) 15L < head.shell.timestamp) then begin end else if Time.(add (now ()) 15L < head.shell.timestamp) then begin
(* TODO some penalty *) (* TODO some penalty *)
lwt_log_notice "Received future block %a from peer %a." lwt_log_notice Tag.DSL.(fun f ->
Block_hash.pp_short (Block_header.hash head) f "Received future block %a from peer %a."
P2p_peer.Id.pp_short state.gid >>= fun () -> -% t event "received_future_block"
-% a Block_hash.Logging.tag (Block_header.hash head)
-% a P2p_peer.Id.Logging.tag state.gid) >>= fun () ->
Lwt.return_unit Lwt.return_unit
end else begin end else begin
chain_db.callback.notify_branch state.gid locator ; chain_db.callback.notify_branch state.gid locator ;
@ -548,9 +563,11 @@ module P2p_reader = struct
Lwt.return_unit Lwt.return_unit
end else if Time.(add (now ()) 15L < header.shell.timestamp) then begin end else if Time.(add (now ()) 15L < header.shell.timestamp) then begin
(* TODO some penalty *) (* TODO some penalty *)
lwt_log_notice "Received future block %a from peer %a." lwt_log_notice Tag.DSL.(fun f ->
Block_hash.pp_short head f "Received future block %a from peer %a."
P2p_peer.Id.pp_short state.gid >>= fun () -> -% t event "received_future_block"
-% a Block_hash.Logging.tag head
-% a P2p_peer.Id.Logging.tag state.gid) >>= fun () ->
Lwt.return_unit Lwt.return_unit
end else begin end else begin
chain_db.callback.notify_head state.gid header mempool ; chain_db.callback.notify_head state.gid header mempool ;

View File

@ -320,6 +320,10 @@ module Make_request_scheduler
val name : string val name : string
val encoding : t Data_encoding.t val encoding : t Data_encoding.t
val pp : Format.formatter -> t -> unit val pp : Format.formatter -> t -> unit
module Logging : sig
val tag : t Tag.def
end
end) end)
(Table : MEMORY_TABLE with type key := Hash.t) (Table : MEMORY_TABLE with type key := Hash.t)
(Request : REQUEST with type key := Hash.t) : sig (Request : REQUEST with type key := Hash.t) : sig
@ -331,7 +335,7 @@ module Make_request_scheduler
end = struct end = struct
include Logging.Make(struct let name = "node.distributed_db.scheduler." ^ Hash.name end) include Logging.Make_semantic(struct let name = "node.distributed_db.scheduler." ^ Hash.name end)
type key = Hash.t type key = Hash.t
@ -363,24 +367,38 @@ end = struct
let request t p k = let request t p k =
assert (Lwt_pipe.push_now t.queue (Request (p, k))) assert (Lwt_pipe.push_now t.queue (Request (p, k)))
let notify t p k = let notify t p k =
debug "push received %a from %a" debug Tag.DSL.(fun f ->
Hash.pp k P2p_peer.Id.pp_short p ; f "push received %a from %a"
-% t event "push_received"
-% a Hash.Logging.tag k
-% a P2p_peer.Id.Logging.tag p);
assert (Lwt_pipe.push_now t.queue (Notify (p, k))) assert (Lwt_pipe.push_now t.queue (Notify (p, k)))
let notify_cancelation t k = let notify_cancelation t k =
debug "push cancelation %a" debug Tag.DSL.(fun f ->
Hash.pp k ; f "push cancelation %a"
-% t event "push_cancelation"
-% a Hash.Logging.tag k);
assert (Lwt_pipe.push_now t.queue (Notify_cancelation k)) assert (Lwt_pipe.push_now t.queue (Notify_cancelation k))
let notify_invalid t p k = let notify_invalid t p k =
debug "push received invalid %a from %a" debug Tag.DSL.(fun f ->
Hash.pp k P2p_peer.Id.pp_short p ; f "push received invalid %a from %a"
-% t event "push_received_invalid"
-% a Hash.Logging.tag k
-% a P2p_peer.Id.Logging.tag p);
assert (Lwt_pipe.push_now t.queue (Notify_invalid (p, k))) assert (Lwt_pipe.push_now t.queue (Notify_invalid (p, k)))
let notify_duplicate t p k = let notify_duplicate t p k =
debug "push received duplicate %a from %a" debug Tag.DSL.(fun f ->
Hash.pp k P2p_peer.Id.pp_short p ; f "push received duplicate %a from %a"
-% t event "push_received_duplicate"
-% a Hash.Logging.tag k
-% a P2p_peer.Id.Logging.tag p);
assert (Lwt_pipe.push_now t.queue (Notify_duplicate (p, k))) assert (Lwt_pipe.push_now t.queue (Notify_duplicate (p, k)))
let notify_unrequested t p k = let notify_unrequested t p k =
debug "push received unrequested %a from %a" debug Tag.DSL.(fun f ->
Hash.pp k P2p_peer.Id.pp_short p ; f "push received unrequested %a from %a"
-% t event "push_received_unrequested"
-% a Hash.Logging.tag k
-% a P2p_peer.Id.Logging.tag p);
assert (Lwt_pipe.push_now t.queue (Notify_unrequested (p, k))) assert (Lwt_pipe.push_now t.queue (Notify_unrequested (p, k)))
let compute_timeout state = let compute_timeout state =
@ -401,17 +419,16 @@ end = struct
Lwt_unix.sleep delay Lwt_unix.sleep delay
end end
let may_pp_peer ppf = function
| None -> ()
| Some peer -> P2p_peer.Id.pp_short ppf peer
(* TODO should depend on the ressource kind... *) (* TODO should depend on the ressource kind... *)
let initial_delay = 0.5 let initial_delay = 0.5
let process_event state now = function let process_event state now = function
| Request (peer, key) -> begin | Request (peer, key) -> begin
lwt_debug "registering request %a from %a" lwt_debug Tag.DSL.(fun f ->
Hash.pp key may_pp_peer peer >>= fun () -> f "registering request %a from %a"
-% t event "registering_request"
-% a Hash.Logging.tag key
-% a P2p_peer.Id.Logging.tag_opt peer) >>= fun () ->
try try
let data = Table.find state.pending key in let data = Table.find state.pending key in
let peers = let peers =
@ -423,8 +440,11 @@ end = struct
next_request = min data.next_request (now +. initial_delay) ; next_request = min data.next_request (now +. initial_delay) ;
peers ; peers ;
} ; } ;
lwt_debug "registering request %a from %a -> replaced" lwt_debug Tag.DSL.(fun f ->
Hash.pp key may_pp_peer peer >>= fun () -> f "registering request %a from %a -> replaced"
-% t event "registering_request_replaced"
-% a Hash.Logging.tag key
-% a P2p_peer.Id.Logging.tag_opt peer) >>= fun () ->
Lwt.return_unit Lwt.return_unit
with Not_found -> with Not_found ->
let peers = let peers =
@ -436,33 +456,50 @@ end = struct
next_request = now ; next_request = now ;
delay = initial_delay ; delay = initial_delay ;
} ; } ;
lwt_debug "registering request %a from %a -> added" lwt_debug Tag.DSL.(fun f ->
Hash.pp key may_pp_peer peer >>= fun () -> f "registering request %a from %a -> added"
-% t event "registering_request_added"
-% a Hash.Logging.tag key
-% a P2p_peer.Id.Logging.tag_opt peer) >>= fun () ->
Lwt.return_unit Lwt.return_unit
end end
| Notify (peer, key) -> | Notify (peer, key) ->
Table.remove state.pending key ; Table.remove state.pending key ;
lwt_debug "received %a from %a" lwt_debug Tag.DSL.(fun f ->
Hash.pp key P2p_peer.Id.pp_short peer >>= fun () -> f "received %a from %a"
-% t event "received"
-% a Hash.Logging.tag key
-% a P2p_peer.Id.Logging.tag peer) >>= fun () ->
Lwt.return_unit Lwt.return_unit
| Notify_cancelation key -> | Notify_cancelation key ->
Table.remove state.pending key ; Table.remove state.pending key ;
lwt_debug "canceled %a" lwt_debug Tag.DSL.(fun f ->
Hash.pp key >>= fun () -> f "canceled %a"
-% t event "canceled"
-% a Hash.Logging.tag key) >>= fun () ->
Lwt.return_unit Lwt.return_unit
| Notify_invalid (peer, key) -> | Notify_invalid (peer, key) ->
lwt_debug "received invalid %a from %a" lwt_debug Tag.DSL.(fun f ->
Hash.pp key P2p_peer.Id.pp_short peer >>= fun () -> f "received invalid %a from %a"
-% t event "received_invalid"
-% a Hash.Logging.tag key
-% a P2p_peer.Id.Logging.tag peer) >>= fun () ->
(* TODO *) (* TODO *)
Lwt.return_unit Lwt.return_unit
| Notify_unrequested (peer, key) -> | Notify_unrequested (peer, key) ->
lwt_debug "received unrequested %a from %a" lwt_debug Tag.DSL.(fun f ->
Hash.pp key P2p_peer.Id.pp_short peer >>= fun () -> f "received unrequested %a from %a"
-% t event "received_unrequested"
-% a Hash.Logging.tag key
-% a P2p_peer.Id.Logging.tag peer) >>= fun () ->
(* TODO *) (* TODO *)
Lwt.return_unit Lwt.return_unit
| Notify_duplicate (peer, key) -> | Notify_duplicate (peer, key) ->
lwt_debug "received duplicate %a from %a" lwt_debug Tag.DSL.(fun f ->
Hash.pp key P2p_peer.Id.pp_short peer >>= fun () -> f "received duplicate %a from %a"
-% t event "received_duplicate"
-% a Hash.Logging.tag key
-% a P2p_peer.Id.Logging.tag peer) >>= fun () ->
(* TODO *) (* TODO *)
Lwt.return_unit Lwt.return_unit
@ -473,7 +510,8 @@ end = struct
Lwt.choose Lwt.choose
[ (state.events >|= fun _ -> ()) ; timeout ; shutdown ] >>= fun () -> [ (state.events >|= fun _ -> ()) ; timeout ; shutdown ] >>= fun () ->
if Lwt.state shutdown <> Lwt.Sleep then if Lwt.state shutdown <> Lwt.Sleep then
lwt_debug "terminating" >>= fun () -> lwt_debug Tag.DSL.(fun f ->
f "terminating" -% t event "terminating") >>= fun () ->
Lwt.return_unit Lwt.return_unit
else if Lwt.state state.events <> Lwt.Sleep then else if Lwt.state state.events <> Lwt.Sleep then
let now = Unix.gettimeofday () in let now = Unix.gettimeofday () in
@ -482,7 +520,8 @@ end = struct
Lwt_list.iter_s (process_event state now) events >>= fun () -> Lwt_list.iter_s (process_event state now) events >>= fun () ->
loop state loop state
else else
lwt_debug "timeout" >>= fun () -> lwt_debug Tag.DSL.(fun f ->
f "timeout" -% t event "timeout") >>= fun () ->
let now = Unix.gettimeofday () in let now = Unix.gettimeofday () in
let active_peers = Request.active state.param in let active_peers = Request.active state.param in
let requests = let requests =
@ -515,8 +554,11 @@ end = struct
P2p_peer.Map.fold begin fun peer request acc -> P2p_peer.Map.fold begin fun peer request acc ->
acc >>= fun () -> acc >>= fun () ->
Lwt_list.iter_s (fun key -> Lwt_list.iter_s (fun key ->
lwt_debug "requested %a from %a" lwt_debug Tag.DSL.(fun f ->
Hash.pp key P2p_peer.Id.pp_short peer) f "requested %a from %a"
-% t event "requested"
-% a Hash.Logging.tag key
-% a P2p_peer.Id.Logging.tag peer))
request request
end requests Lwt.return_unit >>= fun () -> end requests Lwt.return_unit >>= fun () ->
loop state loop state

View File

@ -172,6 +172,10 @@ module Make_request_scheduler
val name : string val name : string
val encoding : t Data_encoding.t val encoding : t Data_encoding.t
val pp : Format.formatter -> t -> unit val pp : Format.formatter -> t -> unit
module Logging : sig
val tag : t Tag.def
end
end) end)
(Table : MEMORY_TABLE with type key := Hash.t) (Table : MEMORY_TABLE with type key := Hash.t)
(Request : REQUEST with type key := Hash.t) : sig (Request : REQUEST with type key := Hash.t) : sig

View File

@ -302,3 +302,7 @@ let raw_encoding = P2p.Raw.encoding encoding
let pp_json ppf msg = let pp_json ppf msg =
Data_encoding.Json.pp ppf Data_encoding.Json.pp ppf
(Data_encoding.Json.construct raw_encoding (Message msg)) (Data_encoding.Json.construct raw_encoding (Message msg))
module Logging = struct
let tag = Tag.def ~doc:"Message" "message" pp_json
end

View File

@ -50,3 +50,7 @@ module Bounded_encoding : sig
val set_protocol_max_size: int option -> unit val set_protocol_max_size: int option -> unit
val set_mempool_max_operations: int option -> unit val set_mempool_max_operations: int option -> unit
end end
module Logging : sig
val tag : t Tag.def
end

View File

@ -46,12 +46,14 @@ let init_p2p p2p_params =
match p2p_params with match p2p_params with
| None -> | None ->
let c_meta = init_connection_metadata None in let c_meta = init_connection_metadata None in
lwt_log_notice "P2P layer is disabled" >>= fun () -> lwt_log_notice Tag.DSL.(fun f ->
f "P2P layer is disabled" -% t event "p2p_disabled") >>= fun () ->
return (P2p.faked_network peer_metadata_cfg c_meta) return (P2p.faked_network peer_metadata_cfg c_meta)
| Some (config, limits) -> | Some (config, limits) ->
let c_meta = init_connection_metadata (Some config) in let c_meta = init_connection_metadata (Some config) in
let conn_metadata_cfg = connection_metadata_cfg c_meta in let conn_metadata_cfg = connection_metadata_cfg c_meta in
lwt_log_notice "bootstrapping chain..." >>= fun () -> lwt_log_notice Tag.DSL.(fun f ->
f "bootstrapping chain..." -% t event "bootstrapping_chain") >>= fun () ->
P2p.create P2p.create
~config ~limits ~config ~limits
peer_metadata_cfg peer_metadata_cfg

View File

@ -9,7 +9,7 @@
open Validation_errors open Validation_errors
include Logging.Make(struct let name = "node.validator.block" end) include Logging.Make_semantic(struct let name = "node.validator.block" end)
type 'a request = type 'a request =
| Request_validation: { | Request_validation: {
@ -68,11 +68,14 @@ let rec worker_loop bv =
| Ok () -> | Ok () ->
worker_loop bv worker_loop bv
| Error [Canceled | Exn Lwt_pipe.Closed] -> | Error [Canceled | Exn Lwt_pipe.Closed] ->
lwt_log_notice "terminating" >>= fun () -> lwt_log_notice Tag.DSL.(fun f ->
f "terminating" -% t event "terminating") >>= fun () ->
Lwt.return_unit Lwt.return_unit
| Error err -> | Error err ->
lwt_log_error "@[Unexpected error (worker):@ %a@]" lwt_log_error Tag.DSL.(fun f ->
pp_print_error err >>= fun () -> f "@[Unexpected error (worker):@ %a@]"
-% t event "unexpected_error"
-% a errs_tag err) >>= fun () ->
Lwt_canceler.cancel bv.canceler >>= fun () -> Lwt_canceler.cancel bv.canceler >>= fun () ->
Lwt.return_unit Lwt.return_unit
@ -99,13 +102,17 @@ let shutdown { canceler ; worker } =
let validate { messages } hash protocol = let validate { messages } hash protocol =
match Registered_protocol.get hash with match Registered_protocol.get hash with
| Some protocol -> | Some protocol ->
lwt_debug "previously validated protocol %a (before pipe)" lwt_debug Tag.DSL.(fun f ->
Protocol_hash.pp_short hash >>= fun () -> f "previously validated protocol %a (before pipe)"
-% t event "previously_validated_protocol"
-% a Protocol_hash.Logging.tag hash) >>= fun () ->
return protocol return protocol
| None -> | None ->
let res, wakener = Lwt.task () in let res, wakener = Lwt.task () in
lwt_debug "pushing validation request for protocol %a" lwt_debug Tag.DSL.(fun f ->
Protocol_hash.pp_short hash >>= fun () -> f "pushing validation request for protocol %a"
-% t event "pushing_validation_request"
-% a Protocol_hash.Logging.tag hash) >>= fun () ->
Lwt_pipe.push messages Lwt_pipe.push messages
(Message (Request_validation { hash ; protocol }, (Message (Request_validation { hash ; protocol },
Some wakener)) >>= fun () -> Some wakener)) >>= fun () ->
@ -119,14 +126,11 @@ let fetch_and_compile_protocol pv ?peer ?timeout hash =
Distributed_db.Protocol.read_opt pv.db hash >>= function Distributed_db.Protocol.read_opt pv.db hash >>= function
| Some protocol -> return protocol | Some protocol -> return protocol
| None -> | None ->
let may_print_peer ppf = function lwt_log_notice Tag.DSL.(fun f ->
| None -> () f "Fetching protocol %a%a"
| Some peer -> -% t event "fetching_protocol"
Format.fprintf ppf " from peer %a" -% a Protocol_hash.Logging.tag hash
P2p_peer.Id.pp peer in -% a P2p_peer.Id.Logging.tag_source peer) >>= fun () ->
lwt_log_notice "Fetching protocol %a%a"
Protocol_hash.pp_short hash
may_print_peer peer >>= fun () ->
Distributed_db.Protocol.fetch pv.db ?peer ?timeout hash () Distributed_db.Protocol.fetch pv.db ?peer ?timeout hash ()
end >>=? fun protocol -> end >>=? fun protocol ->
validate pv hash protocol >>=? fun proto -> validate pv hash protocol >>=? fun proto ->

View File

@ -577,7 +577,10 @@ module Chain = struct
end end
let destroy state chain = let destroy state chain =
lwt_debug "destroy %a" Chain_id.pp (id chain) >>= fun () -> lwt_debug Tag.DSL.(fun f ->
f "destroy %a"
-% t event "destroy"
-% a chain_id (id chain)) >>= fun () ->
Shared.use state.global_data begin fun { global_store ; chains } -> Shared.use state.global_data begin fun { global_store ; chains } ->
Chain_id.Table.remove chains (id chain) ; Chain_id.Table.remove chains (id chain) ;
Store.Chain.destroy global_store (id chain) >>= fun () -> Store.Chain.destroy global_store (id chain) >>= fun () ->

View File

@ -7,4 +7,6 @@
(* *) (* *)
(**************************************************************************) (**************************************************************************)
include Tezos_stdlib.Logging.Make(struct let name = "node.state" end) include Tezos_stdlib.Logging.Make_semantic(struct let name = "node.state" end)
let chain_id = Tag.def ~doc:"Chain ID" "chain_id" Chain_id.pp

View File

@ -7,4 +7,6 @@
(* *) (* *)
(**************************************************************************) (**************************************************************************)
include Tezos_stdlib.Logging.LOG include Tezos_stdlib.Logging.SEMLOG
val chain_id: Chain_id.t Tag.def

View File

@ -7,7 +7,7 @@
(* *) (* *)
(**************************************************************************) (**************************************************************************)
include Logging.Make(struct let name = "node.validator" end) include Logging.Make_semantic(struct let name = "node.validator" end)
type t = { type t = {
@ -40,7 +40,10 @@ let create state db
let activate v ?max_child_ttl ~start_prevalidator chain_state = let activate v ?max_child_ttl ~start_prevalidator chain_state =
let chain_id = State.Chain.id chain_state in let chain_id = State.Chain.id chain_state in
lwt_log_notice "activate chain %a" Chain_id.pp chain_id >>= fun () -> lwt_log_notice Tag.DSL.(fun f ->
f "activate chain %a"
-% t event "active_chain"
-% a State_logging.chain_id chain_id) >>= fun () ->
try Chain_id.Table.find v.active_chains chain_id try Chain_id.Table.find v.active_chains chain_id
with Not_found -> with Not_found ->
let nv = let nv =

View File

@ -7,4 +7,4 @@
(* *) (* *)
(**************************************************************************) (**************************************************************************)
include Tezos_stdlib.Logging.Make(struct let name = "node.worker" end) include Tezos_stdlib.Logging.Make_semantic(struct let name = "node.worker" end)

View File

@ -7,4 +7,4 @@
(* *) (* *)
(**************************************************************************) (**************************************************************************)
include Tezos_stdlib.Logging.LOG include Tezos_stdlib.Logging.SEMLOG

View File

@ -9,7 +9,7 @@
open Client_keys open Client_keys
include Logging.Make(struct let name = "client.signer.ledger" end) include Tezos_stdlib.Logging.Make(struct let name = "client.signer.ledger" end)
let scheme = "ledger" let scheme = "ledger"

View File

@ -7,12 +7,13 @@
(* *) (* *)
(**************************************************************************) (**************************************************************************)
include Logging.Make(struct let name = "client.denunciation" end) include Tezos_stdlib.Logging.Make_semantic(struct let name = "client.denunciation" end)
open Proto_alpha open Proto_alpha
open Alpha_context open Alpha_context
open Client_baking_blocks open Client_baking_blocks
open Logging
module HLevel = Hashtbl.Make(struct module HLevel = Hashtbl.Make(struct
include Raw_level include Raw_level
@ -55,7 +56,10 @@ let get_block_offset level =
else else
`Head 5) `Head 5)
| Error errs -> | Error errs ->
lwt_log_error "Invalid level conversion : %a" pp_print_error errs >>= fun () -> lwt_log_error Tag.DSL.(fun f ->
f "Invalid level conversion : %a"
-% t event "invalid_level_conversion"
-% a errs_tag errs) >>= fun () ->
Lwt.return (`Head 0) Lwt.return (`Head 0)
let process_endorsements (cctxt : #Proto_alpha.full) state ~chain let process_endorsements (cctxt : #Proto_alpha.full) state ~chain
@ -83,17 +87,24 @@ let process_endorsements (cctxt : #Proto_alpha.full) state ~chain
~op1:existing_endorsement ~op1:existing_endorsement
~op2:new_endorsement () >>=? fun bytes -> ~op2:new_endorsement () >>=? fun bytes ->
let bytes = Signature.concat bytes Signature.zero in let bytes = Signature.concat bytes Signature.zero in
lwt_log_notice "Double endorsement detected" >>= fun () -> lwt_log_notice Tag.DSL.(fun f ->
f "Double endorsement detected"
-% t event "double_endorsement_detected"
-% t conflicting_endorsements_tag (existing_endorsement, new_endorsement)) >>= fun () ->
(* A denunciation may have already occured *) (* A denunciation may have already occured *)
Shell_services.Injection.operation cctxt ~chain bytes >>=? fun op_hash -> Shell_services.Injection.operation cctxt ~chain bytes >>=? fun op_hash ->
lwt_log_notice "Double endorsement evidence injected %a" lwt_log_notice Tag.DSL.(fun f ->
Operation_hash.pp op_hash >>= fun () -> f "Double endorsement evidence injected %a"
-% t event "double_endorsement_denounced"
-% a Operation_hash.Logging.tag op_hash) >>= fun () ->
return @@ HLevel.replace state.endorsements_table level return @@ HLevel.replace state.endorsements_table level
(Delegate_Map.add delegate new_endorsement map) (Delegate_Map.add delegate new_endorsement map)
end end
| _ -> | _ ->
lwt_log_error "Inconsistent endorsement found %a" lwt_log_error Tag.DSL.(fun f ->
Operation_hash.pp hash >>= fun () -> f "Inconsistent endorsement found %a"
-% t event "inconsistent_endorsement"
-% a Operation_hash.Logging.tag hash) >>= fun () ->
return_unit return_unit
) endorsements >>=? fun () -> ) endorsements >>=? fun () ->
return_unit return_unit
@ -108,7 +119,7 @@ let process_block (cctxt : #Proto_alpha.full) state ~chain (header : Alpha_block
(Delegate_Map.add baker hash map) (Delegate_Map.add baker hash map)
| Some existing_hash when Block_hash.(=) existing_hash hash -> | Some existing_hash when Block_hash.(=) existing_hash hash ->
(* This case should never happen *) (* This case should never happen *)
lwt_debug "Double baking detected but block hashes are equivalent. Skipping..." >>= fun () -> lwt_debug Tag.DSL.(fun f -> f "Double baking detected but block hashes are equivalent. Skipping..." -% t event "double_baking_but_not") >>= fun () ->
return @@ HLevel.replace state.blocks_table level return @@ HLevel.replace state.blocks_table level
(Delegate_Map.add baker hash map) (Delegate_Map.add baker hash map)
| Some existing_hash -> | Some existing_hash ->
@ -126,11 +137,15 @@ let process_block (cctxt : #Proto_alpha.full) state ~chain (header : Alpha_block
Alpha_services.Forge.double_baking_evidence cctxt (`Main, block) ~branch:block_hash Alpha_services.Forge.double_baking_evidence cctxt (`Main, block) ~branch:block_hash
~bh1 ~bh2 () >>=? fun bytes -> ~bh1 ~bh2 () >>=? fun bytes ->
let bytes = Signature.concat bytes Signature.zero in let bytes = Signature.concat bytes Signature.zero in
lwt_log_notice "Double baking detected" >>= fun () -> lwt_log_notice Tag.DSL.(fun f ->
f "Double baking detected"
-% t event "double_baking_detected") >>= fun () ->
(* A denunciation may have already occured *) (* A denunciation may have already occured *)
Shell_services.Injection.operation cctxt ~chain bytes >>=? fun op_hash -> Shell_services.Injection.operation cctxt ~chain bytes >>=? fun op_hash ->
lwt_log_notice "Double baking evidence injected %a" lwt_log_notice Tag.DSL.(fun f ->
Operation_hash.pp op_hash >>= fun () -> f "Double baking evidence injected %a"
-% t event "double_baking_denounced"
-% a Operation_hash.Logging.tag op_hash) >>= fun () ->
return @@ HLevel.replace state.blocks_table level return @@ HLevel.replace state.blocks_table level
(Delegate_Map.add baker hash map) (Delegate_Map.add baker hash map)
end end
@ -166,10 +181,18 @@ let endorsements_index = 0
*) *)
let process_new_block (cctxt : #Proto_alpha.full) state { hash ; chain_id ; level ; protocol ; next_protocol } = let process_new_block (cctxt : #Proto_alpha.full) state { hash ; chain_id ; level ; protocol ; next_protocol } =
if Protocol_hash.(protocol <> next_protocol) then if Protocol_hash.(protocol <> next_protocol) then
lwt_log_error "Protocol changing detected. Skipping the block." >>= fun () -> lwt_log_error Tag.DSL.(fun f ->
f "Protocol changing detected. Skipping the block."
-% t event "protocol_change_detected"
(* TODO which protocols -- in tag *)
) >>= fun () ->
return_unit return_unit
else else
lwt_debug "Block level : %a" Raw_level.pp level >>= fun () -> lwt_debug Tag.DSL.(fun f ->
f "Block level : %a"
-% t event "accuser_saw_block"
-% a level_tag level
-% t Block_hash.Logging.tag hash) >>= fun () ->
let chain = `Hash chain_id in let chain = `Hash chain_id in
let block = `Hash (hash, 0) in let block = `Hash (hash, 0) in
state.highest_level_encountered <- Raw_level.max level state.highest_level_encountered ; state.highest_level_encountered <- Raw_level.max level state.highest_level_encountered ;
@ -179,9 +202,11 @@ let process_new_block (cctxt : #Proto_alpha.full) state { hash ; chain_id ; leve
| Ok block_info -> | Ok block_info ->
process_block cctxt state ~chain block_info process_block cctxt state ~chain block_info
| Error errs -> | Error errs ->
lwt_log_error "Error while fetching operations in block %a@\n%a" lwt_log_error Tag.DSL.(fun f ->
Block_hash.pp_short hash f "Error while fetching operations in block %a@\n%a"
pp_print_error errs >>= fun () -> -% t event "fetch_operations_error"
-% a Block_hash.Logging.tag hash
-% a errs_tag errs) >>= fun () ->
return_unit return_unit
end >>=? fun () -> end >>=? fun () ->
(* Processing endorsements *) (* Processing endorsements *)
@ -192,9 +217,11 @@ let process_new_block (cctxt : #Proto_alpha.full) state { hash ; chain_id ; leve
process_endorsements cctxt state ~chain endorsements level process_endorsements cctxt state ~chain endorsements level
else return_unit else return_unit
| Error errs -> | Error errs ->
lwt_log_error "Error while fetching operations in block %a@\n%a" lwt_log_error Tag.DSL.(fun f ->
Block_hash.pp_short hash f "Error while fetching operations in block %a@\n%a"
pp_print_error errs >>= fun () -> -% t event "fetch_operations_error"
-% a Block_hash.Logging.tag hash
-% a errs_tag errs) >>= fun () ->
return_unit return_unit
end >>=? fun () -> end >>=? fun () ->
cleanup_old_operations state ; cleanup_old_operations state ;
@ -205,14 +232,17 @@ let create (cctxt : #Proto_alpha.full) ~preserved_levels valid_blocks_stream =
let process_block cctxt state bi = let process_block cctxt state bi =
process_new_block cctxt state bi >>= function process_new_block cctxt state bi >>= function
| Ok () -> | Ok () ->
lwt_log_notice lwt_log_notice Tag.DSL.(fun f ->
"Block %a registered" f "Block %a registered"
Block_hash.pp_short bi.Client_baking_blocks.hash -% t event "accuser_processed_block"
-% a Block_hash.Logging.tag bi.Client_baking_blocks.hash)
>>= return >>= return
| Error errs -> | Error errs ->
lwt_log_error "Error while processing block %a@\n%a" lwt_log_error Tag.DSL.(fun f ->
Block_hash.pp_short bi.hash f "Error while processing block %a@\n%a"
pp_print_error errs -% t event "accuser_block_error"
-% a Block_hash.Logging.tag bi.hash
-% a errs_tag errs)
>>= return >>= return
in in

View File

@ -10,7 +10,9 @@
open Proto_alpha open Proto_alpha
open Alpha_context open Alpha_context
include Logging.Make(struct let name = "client.endorsement" end) include Tezos_stdlib.Logging.Make_semantic(struct let name = "client.endorsement" end)
open Logging
module State = Daemon_state.Make(struct let name = "endorsement" end) module State = Daemon_state.Make(struct let name = "endorsement" end)
@ -104,51 +106,71 @@ let endorse_for_delegate cctxt block delegate =
let { Client_baking_blocks.hash ; level } = block in let { Client_baking_blocks.hash ; level } = block in
let b = `Hash (hash, 0) in let b = `Hash (hash, 0) in
Client_keys.get_key cctxt delegate >>=? fun (name, _pk, sk) -> Client_keys.get_key cctxt delegate >>=? fun (name, _pk, sk) ->
lwt_debug "Endorsing %a for %s (level %a)!" lwt_debug Tag.DSL.(fun f ->
Block_hash.pp_short hash name f "Endorsing %a for %s (level %a)!"
Raw_level.pp level >>= fun () -> -% t event "endorsing"
-% a Block_hash.Logging.tag hash
-% s Client_keys.Logging.tag name
-% a level_tag level) >>= fun () ->
inject_endorsement cctxt inject_endorsement cctxt
b hash level b hash level
sk delegate >>=? fun oph -> sk delegate >>=? fun oph ->
lwt_log_notice lwt_log_notice Tag.DSL.(fun f ->
"Injected endorsement for block '%a' \ f "Injected endorsement for block '%a' \
(level %a, contract %s) '%a'" (level %a, contract %s) '%a'"
Block_hash.pp_short hash -% t event "injected_endorsement"
Raw_level.pp level -% a Block_hash.Logging.tag hash
name -% a level_tag level
Operation_hash.pp_short oph >>= fun () -> -% s Client_keys.Logging.tag name
-% a Operation_hash.Logging.tag oph) >>= fun () ->
return_unit return_unit
let allowed_to_endorse cctxt bi delegate = let allowed_to_endorse cctxt bi delegate =
Client_keys.Public_key_hash.name cctxt delegate >>=? fun name -> Client_keys.Public_key_hash.name cctxt delegate >>=? fun name ->
lwt_debug "Checking if allowed to endorse block %a for %s" lwt_debug Tag.DSL.(fun f ->
Block_hash.pp_short bi.Client_baking_blocks.hash name >>= fun () -> f "Checking if allowed to endorse block %a for %s"
-% t event "check_endorsement_ok"
-% a Block_hash.Logging.tag bi.Client_baking_blocks.hash
-% s Client_keys.Logging.tag name) >>= fun () ->
let b = `Hash (bi.hash, 0) in let b = `Hash (bi.hash, 0) in
let level = bi.level in let level = bi.level in
get_signing_slots cctxt b delegate level >>=? function get_signing_slots cctxt b delegate level >>=? function
| None | Some [] -> | None | Some [] ->
lwt_debug "No slot found for %a/%s" lwt_debug Tag.DSL.(fun f ->
Block_hash.pp_short bi.hash name >>= fun () -> f "No slot found for %a/%s"
-% t event "endorsement_no_slots_found"
-% a Block_hash.Logging.tag bi.hash
-% s Client_keys.Logging.tag name) >>= fun () ->
return_false return_false
| Some (_ :: _ as slots) -> | Some (_ :: _ as slots) ->
lwt_debug "Found slots for %a/%s (%d)" lwt_debug Tag.DSL.(fun f ->
Block_hash.pp_short bi.hash name (List.length slots) >>= fun () -> f "Found slots for %a/%s (%a)"
-% t event "endorsement_slots_found"
-% a Block_hash.Logging.tag bi.hash
-% s Client_keys.Logging.tag name
-% a endorsement_slots_tag slots) >>= fun () ->
previously_endorsed_level cctxt delegate level >>=? function previously_endorsed_level cctxt delegate level >>=? function
| true -> | true ->
lwt_debug "Level %a (or higher) previously endorsed: do not endorse." lwt_debug Tag.DSL.(fun f ->
Raw_level.pp level >>= fun () -> f "Level %a (or higher) previously endorsed: do not endorse."
-% t event "previously_endorsed"
-% a level_tag level) >>= fun () ->
return_false return_false
| false -> | false ->
return_true return_true
let prepare_endorsement ~(max_past:int64) () (cctxt : #Proto_alpha.full) state bi = let prepare_endorsement ~(max_past:int64) () (cctxt : #Proto_alpha.full) state bi =
if Time.diff (Time.now ()) bi.Client_baking_blocks.timestamp > max_past then if Time.diff (Time.now ()) bi.Client_baking_blocks.timestamp > max_past then
lwt_log_info "Ignore block %a: forged too far the past" lwt_log_info Tag.DSL.(fun f ->
Block_hash.pp_short bi.hash >>= fun () -> f "Ignore block %a: forged too far the past"
-% t event "endorsement_stale_block"
-% a Block_hash.Logging.tag bi.hash) >>= fun () ->
return_unit return_unit
else else
lwt_log_info "Received new block %a" lwt_log_info Tag.DSL.(fun f ->
Block_hash.pp_short bi.hash >>= fun () -> f "Received new block %a"
-% t event "endorsement_got_block"
-% a Block_hash.Logging.tag bi.hash) >>= fun () ->
let time = Time.(add (now ()) state.delay) in let time = Time.(add (now ()) state.delay) in
let timeout = Lwt_unix.sleep (Int64.to_float state.delay) in let timeout = Lwt_unix.sleep (Int64.to_float state.delay) in
get_delegates cctxt state >>=? fun delegates -> get_delegates cctxt state >>=? fun delegates ->
@ -168,11 +190,6 @@ let compute_timeout state =
timeout >>= fun () -> timeout >>= fun () ->
Lwt.return (block, delegates) Lwt.return (block, delegates)
let check_error f =
f >>= function
| Ok () -> Lwt.return_unit
| Error errs -> lwt_log_error "Error while endorsing:@\n%a" pp_print_error errs
let create let create
(cctxt: #Proto_alpha.full) (cctxt: #Proto_alpha.full)
?(max_past=110L) ?(max_past=110L)

View File

@ -10,7 +10,8 @@
open Proto_alpha open Proto_alpha
open Alpha_context open Alpha_context
include Logging.Make(struct let name = "client.baking" end) include Tezos_stdlib.Logging.Make_semantic(struct let name = "client.baking" end)
open Logging
(* The index of the different components of the protocol's validation passes *) (* The index of the different components of the protocol's validation passes *)
@ -326,11 +327,13 @@ let forge_block cctxt ?(chain = `Main) block
List.fold_left List.fold_left
(fun acc r -> acc + List.length r.Preapply_result.applied) (fun acc r -> acc + List.length r.Preapply_result.applied)
0 result in 0 result in
lwt_log_info "Found %d valid operations (%d refused) for timestamp %a" lwt_log_info Tag.DSL.(fun f ->
valid_op_count (total_op_count - valid_op_count) f "Found %d valid operations (%d refused) for timestamp %a@.Computed fitness %a"
Time.pp_hum timestamp >>= fun () -> -% t event "found_valid_operations"
lwt_log_info "Computed fitness %a" -% s valid_ops valid_op_count
Fitness.pp shell_header.fitness >>= fun () -> -% s refused_ops (total_op_count - valid_op_count)
-% a timestamp_tag timestamp
-% a fitness_tag shell_header.fitness) >>= fun () ->
(* everything went well (or we don't care about errors): GO! *) (* everything went well (or we don't care about errors): GO! *)
if best_effort || all_ops_valid result then if best_effort || all_ops_valid result then
@ -359,6 +362,7 @@ let previously_baked_level cctxt pkh new_lvl =
| Some last_lvl -> | Some last_lvl ->
return (Raw_level.(last_lvl >= new_lvl)) return (Raw_level.(last_lvl >= new_lvl))
let get_baking_slot cctxt let get_baking_slot cctxt
?max_priority (bi: Client_baking_blocks.block_info) delegates = ?max_priority (bi: Client_baking_blocks.block_info) delegates =
let chain = `Hash bi.chain_id in let chain = `Hash bi.chain_id in
@ -370,12 +374,16 @@ let get_baking_slot cctxt
~delegates ~delegates
(chain, block) >>= function (chain, block) >>= function
| Error errs -> | Error errs ->
lwt_log_error "Error while fetching baking possibilities:\n%a" lwt_log_error Tag.DSL.(fun f ->
pp_print_error errs >>= fun () -> f "Error while fetching baking possibilities:\n%a"
-% t event "baking_slot_fetch_errors"
-% a errs_tag errs) >>= fun () ->
Lwt.return_nil Lwt.return_nil
| Ok [] -> | Ok [] ->
lwt_log_info "Found no baking rights for level %a" lwt_log_info Tag.DSL.(fun f ->
Raw_level.pp level >>= fun () -> f "Found no baking rights for level %a"
-% t event "no_baking_rights"
-% a level_tag level) >>= fun () ->
Lwt.return_nil Lwt.return_nil
| Ok slots -> | Ok slots ->
let slots = let slots =
@ -447,7 +455,11 @@ let safe_get_unrevealed_nonces cctxt block =
get_unrevealed_nonces cctxt block >>= function get_unrevealed_nonces cctxt block >>= function
| Ok r -> Lwt.return r | Ok r -> Lwt.return r
| Error err -> | Error err ->
lwt_warn "Cannot read nonces: %a@." pp_print_error err >>= fun () -> lwt_warn Tag.DSL.(fun f ->
f "Cannot read nonces: %a@."
-% t event "read_nonce_fail"
-% a errs_tag err)
>>= fun () ->
Lwt.return_nil Lwt.return_nil
let insert_block let insert_block
@ -470,16 +482,22 @@ let insert_block
get_baking_slot cctxt ?max_priority bi delegates >>= function get_baking_slot cctxt ?max_priority bi delegates >>= function
| [] -> | [] ->
lwt_debug lwt_debug
"Can't compute slots for %a" Block_hash.pp_short bi.hash >>= fun () -> Tag.DSL.(fun f ->
f "Can't compute slots for %a"
-% t event "cannot_compute_slot"
-% a Block_hash.Logging.tag bi.hash) >>= fun () ->
return_unit return_unit
| (_ :: _) as slots -> | (_ :: _) as slots ->
iter_p iter_p
(fun ((timestamp, (_, _, delegate)) as slot) -> (fun ((timestamp, (_, _, delegate)) as slot) ->
Client_keys.Public_key_hash.name cctxt delegate >>=? fun name -> Client_keys.Public_key_hash.name cctxt delegate >>=? fun name ->
lwt_log_info "New baking slot at %a for %s after %a" lwt_log_info Tag.DSL.(fun f ->
Time.pp_hum timestamp f "New baking slot at %a for %s after %a"
name -% t event "have_baking_slot"
Block_hash.pp_short bi.hash >>= fun () -> -% a timestamp_tag timestamp
-% s Client_keys.Logging.tag name
-% a Block_hash.Logging.tag bi.hash
-% t Signature.Public_key_hash.Logging.tag delegate) >>= fun () ->
state.future_slots <- insert_baking_slot slot state.future_slots ; state.future_slots <- insert_baking_slot slot state.future_slots ;
return_unit return_unit
) )
@ -498,14 +516,18 @@ let pop_baking_slots state =
let filter_invalid_operations (cctxt : #full) state block_info (operations : packed_operation list list) = let filter_invalid_operations (cctxt : #full) state block_info (operations : packed_operation list list) =
let open Client_baking_simulator in let open Client_baking_simulator in
lwt_debug "Starting client-side validation %a" lwt_debug Tag.DSL.(fun f ->
Block_hash.pp block_info.Client_baking_blocks.hash >>= fun () -> f "Starting client-side validation %a"
-% t event "baking_local_validation_start"
-% a Block_hash.Logging.tag block_info.Client_baking_blocks.hash) >>= fun () ->
begin begin_construction cctxt state.index block_info >>= function begin begin_construction cctxt state.index block_info >>= function
| Ok inc -> return inc | Ok inc -> return inc
| Error errs -> | Error errs ->
lwt_log_error "Error while fetching current context : %a" lwt_log_error Tag.DSL.(fun f ->
pp_print_error errs >>= fun () -> f "Error while fetching current context : %a"
lwt_log_notice "Retrying to open the context" >>= fun () -> -% t event "context_fetch_error"
-% a errs_tag errs) >>= fun () ->
lwt_log_notice Tag.DSL.(fun f -> f "Retrying to open the context" -% t event "reopen_context") >>= fun () ->
Client_baking_simulator.load_context ~context_path:state.context_path >>= fun index -> Client_baking_simulator.load_context ~context_path:state.context_path >>= fun index ->
begin_construction cctxt index block_info >>=? fun inc -> begin_construction cctxt index block_info >>=? fun inc ->
state.index <- index; state.index <- index;
@ -518,9 +540,11 @@ let filter_invalid_operations (cctxt : #full) state block_info (operations : pac
let validate_operation inc op = let validate_operation inc op =
add_operation inc op >>= function add_operation inc op >>= function
| Error errs -> | Error errs ->
lwt_log_info "Client-side validation: invalid operation filtered %a\n%a" lwt_log_info Tag.DSL.(fun f ->
Operation_hash.pp (Operation.hash_packed op) f "Client-side validation: invalid operation filtered %a\n%a"
pp_print_error errs -% t event "baking_rejected_invalid_operation"
-% a Operation_hash.Logging.tag (Operation.hash_packed op)
-% a errs_tag errs)
>>= fun () -> >>= fun () ->
return_none return_none
| Ok inc -> return_some inc | Ok inc -> return_some inc
@ -548,8 +572,10 @@ let filter_invalid_operations (cctxt : #full) state block_info (operations : pac
filter_map_s (is_valid_endorsement inc) endorsements >>=? fun endorsements -> filter_map_s (is_valid_endorsement inc) endorsements >>=? fun endorsements ->
finalize_construction inc >>= function finalize_construction inc >>= function
| Error errs -> | Error errs ->
lwt_log_error "Client-side validation: invalid block built. Building an empty block...\n%a" lwt_log_error Tag.DSL.(fun f ->
pp_print_error errs >>= fun () -> f "Client-side validation: invalid block built. Building an empty block...\n%a"
-% t event "built_invalid_block_error"
-% a errs_tag errs) >>= fun () ->
return [ [] ; [] ; [] ; [] ] return [ [] ; [] ; [] ; [] ]
| Ok () -> | Ok () ->
let quota : Alpha_environment.Updater.quota list = Main.validation_passes in let quota : Alpha_environment.Updater.quota list = Main.validation_passes in
@ -586,11 +612,13 @@ let bake_slot
else else
timestamp in timestamp in
Client_keys.Public_key_hash.name cctxt delegate >>=? fun name -> Client_keys.Public_key_hash.name cctxt delegate >>=? fun name ->
lwt_debug "Try baking after %a (slot %d) for %s (%a)" lwt_debug Tag.DSL.(fun f ->
Block_hash.pp_short bi.hash f "Try baking after %a (slot %d) for %s (%a)"
priority -% t event "try_baking"
name -% a Block_hash.Logging.tag bi.hash
Time.pp_hum timestamp >>= fun () -> -% s bake_priorty_tag priority
-% s Client_keys.Logging.tag name
-% a timestamp_tag timestamp) >>= fun () ->
(* get and process operations *) (* get and process operations *)
Alpha_block_services.Mempool.pending_operations cctxt ~chain () >>=? fun mpool -> Alpha_block_services.Mempool.pending_operations cctxt ~chain () >>=? fun mpool ->
let operations = ops_of_mempool mpool in let operations = ops_of_mempool mpool in
@ -611,9 +639,10 @@ let bake_slot
return operations return operations
end >>= function end >>= function
| Error errs -> | Error errs ->
lwt_log_error "Client-side validation: error while filtering invalid operations :@\n%a" lwt_log_error Tag.DSL.(fun f ->
pp_print_error f "Client-side validation: error while filtering invalid operations :@\n%a"
errs >>= fun () -> -% t event "client_side_validation_error"
-% a errs_tag errs) >>= fun () ->
return_none return_none
| Ok operations -> | Ok operations ->
Alpha_block_services.Helpers.Preapply.block Alpha_block_services.Helpers.Preapply.block
@ -621,21 +650,20 @@ let bake_slot
~timestamp ~sort:true ~protocol_data operations ~timestamp ~sort:true ~protocol_data operations
>>= function >>= function
| Error errs -> | Error errs ->
lwt_log_error "Error while prevalidating operations:@\n%a" lwt_log_error Tag.DSL.(fun f ->
pp_print_error f "Error while prevalidating operations:@\n%a"
errs >>= fun () -> -% t event "prevalidate_operations_error"
-% a errs_tag errs) >>= fun () ->
return_none return_none
| Ok (shell_header, operations) -> | Ok (shell_header, operations) ->
lwt_debug lwt_debug Tag.DSL.(fun f ->
"Computed candidate block after %a (slot %d): %a/%d fitness: %a" f "Computed candidate block after %a (slot %d): %a/%d fitness: %a"
Block_hash.pp_short bi.hash priority -% t event "candidate_block"
(Format.pp_print_list -% a Block_hash.Logging.tag bi.hash
~pp_sep:(fun ppf () -> Format.fprintf ppf "+") -% s bake_priorty_tag priority
(fun ppf operations -> Format.fprintf ppf "%d" -% a operations_tag operations
(List.length operations.Preapply_result.applied))) -% s bake_op_count_tag total_op_count
operations -% a fitness_tag shell_header.fitness) >>= fun () ->
total_op_count
Fitness.pp shell_header.fitness >>= fun () ->
let operations = let operations =
List.map (fun l -> List.map snd l.Preapply_result.applied) operations in List.map (fun l -> List.map snd l.Preapply_result.applied) operations in
return return
@ -674,9 +702,11 @@ let bake
state state
() = () =
let slots = pop_baking_slots state in let slots = pop_baking_slots state in
lwt_log_info "Found %d current slots and %d future slots." lwt_log_info Tag.DSL.(fun f ->
(List.length slots) f "Found %d current slots and %d future slots."
(List.length state.future_slots) >>= fun () -> -% t event "pop_baking_slots"
-% s current_slots_tag (List.length slots)
-% s future_slots_tag (List.length state.future_slots)) >>= fun () ->
let seed_nonce = generate_seed_nonce () in let seed_nonce = generate_seed_nonce () in
let seed_nonce_hash = Nonce.hash seed_nonce in let seed_nonce_hash = Nonce.hash seed_nonce in
@ -704,8 +734,10 @@ let bake
(* avoid double baking *) (* avoid double baking *)
previously_baked_level cctxt src_pkh level >>=? function previously_baked_level cctxt src_pkh level >>=? function
| true -> lwt_log_error "Level %a : previously baked" | true -> lwt_log_error Tag.DSL.(fun f ->
Raw_level.pp level >>= return f "Level %a : previously baked"
-% t event "double_bake_near_miss"
-% a level_tag level) >>= return
| false -> | false ->
inject_block cctxt inject_block cctxt
~force:true ~chain ~force:true ~chain
@ -727,9 +759,9 @@ let bake
pp_operation_list_list operations >>= fun () -> pp_operation_list_list operations >>= fun () ->
return_unit return_unit
end end
| _ -> (* no candidates, or none fit-enough *) | _ -> (* no candidates, or none fit-enough *)
lwt_debug "No valid candidates." >>= fun () -> lwt_debug Tag.DSL.(fun f ->
f "No valid candidates." -% t event "no_baking_candidates") >>= fun () ->
return_unit return_unit

View File

@ -7,7 +7,9 @@
(* *) (* *)
(**************************************************************************) (**************************************************************************)
include Logging.Make(struct let name = "client.scheduling" end) include Tezos_stdlib.Logging.Make_semantic(struct let name = "client.scheduling" end)
open Logging
let sleep_until time = let sleep_until time =
let delay = Time.diff time (Time.now ()) in let delay = Time.diff time (Time.now ()) in
@ -16,19 +18,26 @@ let sleep_until time =
else else
Some (Lwt_unix.sleep (Int64.to_float delay)) Some (Lwt_unix.sleep (Int64.to_float delay))
let rec wait_for_first_event stream = let rec wait_for_first_event ~name stream =
Lwt_stream.get stream >>= function Lwt_stream.get stream >>= function
| None | Some (Error _) -> | None | Some (Error _) ->
lwt_log_info "Can't fetch the current event. Waiting for new event." >>= fun () -> lwt_log_info Tag.DSL.(fun f ->
f "Can't fetch the current event. Waiting for new event."
-% t event "cannot_fetch_event"
-% t worker_tag name) >>= fun () ->
(* NOTE: this is not a tight loop because of Lwt_stream.get *) (* NOTE: this is not a tight loop because of Lwt_stream.get *)
wait_for_first_event stream wait_for_first_event ~name stream
| Some (Ok bi) -> | Some (Ok bi) ->
Lwt.return bi Lwt.return bi
let log_errors_and_continue p = let log_errors_and_continue ~name p =
p >>= function p >>= function
| Ok () -> Lwt.return_unit | Ok () -> Lwt.return_unit
| Error errs -> lwt_log_error "Error while baking:@\n%a" pp_print_error errs | Error errs -> lwt_log_error Tag.DSL.(fun f ->
f "Error while baking:@\n%a"
-% t event "daemon_error"
-% t worker_tag name
-% a errs_tag errs)
let main let main
~(name: string) ~(name: string)
@ -52,9 +61,12 @@ let main
unit tzresult Lwt.t)) unit tzresult Lwt.t))
= =
lwt_log_info "Setting up before the %s can start." name >>= fun () -> lwt_log_info Tag.DSL.(fun f ->
f "Setting up before the %s can start."
-% t event "daemon_setup"
-% s worker_tag name) >>= fun () ->
wait_for_first_event stream >>= fun first_event -> wait_for_first_event ~name stream >>= fun first_event ->
Shell_services.Blocks.hash cctxt ~block:`Genesis () >>=? fun genesis_hash -> Shell_services.Blocks.hash cctxt ~block:`Genesis () >>=? fun genesis_hash ->
(* statefulness *) (* statefulness *)
@ -68,7 +80,7 @@ let main
| Some t -> t in | Some t -> t in
state_maker genesis_hash first_event >>=? fun state -> state_maker genesis_hash first_event >>=? fun state ->
log_errors_and_continue @@ pre_loop cctxt state first_event >>= fun () -> log_errors_and_continue ~name @@ pre_loop cctxt state first_event >>= fun () ->
(* main loop *) (* main loop *)
let rec worker_loop () = let rec worker_loop () =
@ -82,23 +94,32 @@ let main
| `Event (None | Some (Error _)) -> | `Event (None | Some (Error _)) ->
(* exit when the node is unavailable *) (* exit when the node is unavailable *)
last_get_event := None ; last_get_event := None ;
lwt_log_error "Connection to node lost, %s exiting." name >>= fun () -> lwt_log_error Tag.DSL.(fun f ->
f "Connection to node lost, %s exiting."
-% t event "daemon_connection_lost"
-% s worker_tag name) >>= fun () ->
exit 1 exit 1
| `Event (Some (Ok event)) -> begin | `Event (Some (Ok event)) -> begin
(* new event: cancel everything and execute callback *) (* new event: cancel everything and execute callback *)
last_get_event := None ; last_get_event := None ;
(* TODO: pretty-print events (requires passing a pp as argument) *) (* TODO: pretty-print events (requires passing a pp as argument) *)
log_errors_and_continue @@ event_k cctxt state event log_errors_and_continue ~name @@ event_k cctxt state event
end end
| `Timeout timesup -> | `Timeout timesup ->
(* main event: it's time *) (* main event: it's time *)
lwt_debug "Waking up for %s." name >>= fun () -> lwt_debug Tag.DSL.(fun f ->
f "Waking up for %s."
-% t event "daemon_wakeup"
-% s worker_tag name) >>= fun () ->
(* core functionality *) (* core functionality *)
log_errors_and_continue @@ timeout_k cctxt state timesup log_errors_and_continue ~name @@ timeout_k cctxt state timesup
end >>= fun () -> end >>= fun () ->
(* and restart *) (* and restart *)
worker_loop () in worker_loop () in
(* ignition *) (* ignition *)
lwt_log_info "Starting %s daemon" name >>= fun () -> lwt_log_info Tag.DSL.(fun f ->
f "Starting %s daemon"
-% t event "daemon_start"
-% s worker_tag name) >>= fun () ->
worker_loop () worker_loop ()

View File

@ -11,6 +11,7 @@
val sleep_until: Time.t -> unit Lwt.t option val sleep_until: Time.t -> unit Lwt.t option
val wait_for_first_event: val wait_for_first_event:
name:string ->
'event tzresult Lwt_stream.t -> 'event tzresult Lwt_stream.t ->
'event Lwt.t 'event Lwt.t

View File

@ -0,0 +1,38 @@
(**************************************************************************)
(* *)
(* Copyright (c) 2014 - 2018. *)
(* Dynamic Ledger Solutions, Inc. <contact@tezos.com> *)
(* *)
(* All rights reserved. No warranty, explicit or implicit, provided. *)
(* *)
(**************************************************************************)
open Proto_alpha
open Alpha_context
let timestamp_tag = Tag.def ~doc:"Timestamp when event occurred" "timestamp" Time.pp_hum
let valid_ops = Tag.def ~doc:"Valid Operations" "valid_ops" Format.pp_print_int
let refused_ops = Tag.def ~doc:"Refused Operations" "refused_ops" Format.pp_print_int
let bake_priorty_tag = Tag.def ~doc:"Baking Priority" "bake_priority" Format.pp_print_int
let fitness_tag = Tag.def ~doc:"Fitness" "fitness" Fitness.pp
let current_slots_tag = Tag.def ~doc:"Number of baking slots that can be baked at this time" "current_slots" Format.pp_print_int
let future_slots_tag = Tag.def ~doc:"Number of baking slots in the foreseeable future but not yet bakeable" "future_slots" Format.pp_print_int
let operations_tag = Tag.def ~doc:"Block Operations" "operations"
(Format.pp_print_list
~pp_sep:(fun ppf () -> Format.fprintf ppf "+")
(fun ppf operations -> Format.fprintf ppf "%d" (List.length operations.Preapply_result.applied)))
let bake_op_count_tag = Tag.def ~doc:"Bake Operation Count" "operation_count" Format.pp_print_int
let endorsement_slot_tag = Tag.def ~doc:"Endorsement Slot" "endorsement_slot" Format.pp_print_int
let endorsement_slots_tag = Tag.def ~doc:"Endorsement Slots" "endorsement_slots" Format.(fun ppf v -> pp_print_int ppf (List.length v))
let denounced_endorsements_slots_tag = Tag.def ~doc:"Endorsement Slots" "denounced_endorsement_slots" Format.(pp_print_list pp_print_int)
let denouncement_source_tag = Tag.def ~doc:"Denounce Source" "source" Format.pp_print_text
let level_tag = Tag.def ~doc:"Level" "level" Raw_level.pp
let worker_tag = Tag.def ~doc:"Worker in which event occurred" "worker" Format.pp_print_text
let conflicting_endorsements_tag = Tag.def ~doc:"Two conflicting endorsements signed by the same key" "conflicting_endorsements" Format.(
fun ppf (a,b) -> fprintf ppf "%a / %a" Operation_hash.pp (Operation.hash a) Operation_hash.pp (Operation.hash b))

View File

@ -0,0 +1,28 @@
(**************************************************************************)
(* *)
(* Copyright (c) 2014 - 2018. *)
(* Dynamic Ledger Solutions, Inc. <contact@tezos.com> *)
(* *)
(* All rights reserved. No warranty, explicit or implicit, provided. *)
(* *)
(**************************************************************************)
val timestamp_tag : Time.t Tag.def
val valid_ops : int Tag.def
val refused_ops : int Tag.def
val bake_priorty_tag : int Tag.def
val fitness_tag : Fitness.t Tag.def
val current_slots_tag : int Tag.def
val future_slots_tag : int Tag.def
val operations_tag : error Preapply_result.t list Tag.def
val bake_op_count_tag : int Tag.def
val endorsement_slot_tag : int Tag.def
val endorsement_slots_tag : int list Tag.def
val denounced_endorsements_slots_tag : int list Tag.def
val denouncement_source_tag : string Tag.def
val level_tag : Proto_alpha.Alpha_context.Raw_level.t Tag.def
val worker_tag : string Tag.def
open Proto_alpha.Alpha_context
val conflicting_endorsements_tag : (Kind.endorsement operation * Kind.endorsement operation) Tag.def