Skip to content
This repository has been archived by the owner on Nov 15, 2023. It is now read-only.

R4R: prometheus exporter in substrate #4511

Closed
Closed
Show file tree
Hide file tree
Changes from 50 commits
Commits
Show all changes
59 commits
Select commit Hold shift + click to select a range
40762b6
Refactor rebase master prometheus_v0.3
nodebreaker0-0 Nov 28, 2019
472aca1
Milestone1: Final Version of v0.3
nodebreaker0-0 Dec 10, 2019
1974f94
no-std or warm compatibility issues, grapana-data -source code refere…
nodebreaker0-0 Jan 2, 2020
62a873d
Cargo.lock paritytech/master rebase
nodebreaker0-0 Jan 2, 2020
97e37e4
prometheus networking.rs del, grafana-data-source networking.rs pub e…
nodebreaker0-0 Jan 3, 2020
f3e444e
chore: reflect various feedback
nodebreaker0-0 Jan 10, 2020
8145df7
Spaces to tabs.
gavofyork Jan 6, 2020
fca71be
Replace grafana and tidy
expenses Jan 10, 2020
855ceed
Add generics
expenses Jan 10, 2020
70c6bcc
Add photo back
expenses Jan 10, 2020
5941041
Re-fix spaces in primitives/consensus/babe/src/inherents.rs
expenses Jan 10, 2020
7d9d341
Refactor rebase master prometheus_v0.3
nodebreaker0-0 Nov 28, 2019
52316ae
Milestone1: Final Version of v0.3
nodebreaker0-0 Dec 10, 2019
82cd8cf
no-std or warm compatibility issues, grapana-data -source code refere…
nodebreaker0-0 Jan 2, 2020
b052829
prometheus networking.rs del, grafana-data-source networking.rs pub e…
nodebreaker0-0 Jan 3, 2020
4e831e9
chore: reflect various feedback
nodebreaker0-0 Jan 10, 2020
0b15bc4
Replace grafana and tidy
expenses Jan 10, 2020
8025361
Add generics
expenses Jan 10, 2020
fd081c9
Add photo back
expenses Jan 10, 2020
f00bb9b
Re-fix spaces in primitives/consensus/babe/src/inherents.rs
expenses Jan 10, 2020
398da97
chore: revert this file back to paritytech/master inherents.rs.
nodebreaker0-0 Jan 14, 2020
84c458f
Add newline at EOF
expenses Jan 14, 2020
f931588
Merge remote-tracking branch 'nodebreaker/prometheus_v0.3' into ashle…
expenses Jan 16, 2020
5796c85
Merge remote-tracking branch 'parity/master' into ashley-prometheus
expenses Jan 16, 2020
2a45de8
Merge remote-tracking branch 'parity/master' into ashley-prometheus
expenses Jan 16, 2020
8bae73b
Merge remote-tracking branch 'parity/master' into ashley-prometheus
expenses Jan 17, 2020
1caa0f1
Merge remote-tracking branch 'parity/master' into ashley-prometheus
expenses Jan 17, 2020
ffb4746
Tidy
expenses Jan 17, 2020
8a6e3c5
Use local registry
expenses Jan 17, 2020
53c95de
fix typo
hskang9 Jan 17, 2020
23cb72e
chore: Apply review feedback
nodebreaker0-0 Jan 20, 2020
3d1634b
Merge remote-tracking branch 'nodebreaker/prometheus_v0.3' into ashle…
expenses Jan 20, 2020
55ac4f8
Merge remote-tracking branch 'parity/master' into ashley-prometheus
expenses Jan 20, 2020
3cfe43c
endpoint -> exporter
expenses Jan 20, 2020
0af2369
fix readme
expenses Jan 20, 2020
44f8c0e
Merge pull request #3 from paritytech/ashley-prometheus
nodebreaker0-0 Jan 21, 2020
d2bba61
Remove lazy_static, use ServiceMetrics struct instead
expenses Jan 21, 2020
5d3d9a7
Merge pull request #4 from paritytech/ashley-prometheus
nodebreaker0-0 Jan 22, 2020
32c04b4
Merge branch 'paritytech/master' into prometheus_v0.3
mxinden Jan 23, 2020
9bde830
Switch to using GaugeVecs
expenses Jan 23, 2020
97faad6
Merge pull request #5 from mxinden/prometheus_v0.3
nodebreaker0-0 Jan 24, 2020
f64a482
chore: without nightly , edit README
nodebreaker0-0 Jan 24, 2020
5d56d93
Merge branch 'prometheus_v0.3' into ashley-prometheus
nodebreaker0-0 Jan 24, 2020
50f2928
block_height -> block_height_number
expenses Jan 27, 2020
8edb710
Merge branch 'ashley-prometheus' of github.com:paritytech/substrate i…
expenses Jan 27, 2020
6a25ea8
Switch to a ready_transactions_number gauge
expenses Jan 29, 2020
18cf2be
Merge pull request #7 from paritytech/ashley-prometheus
nodebreaker0-0 Jan 29, 2020
bb388f5
Update utils/prometheus/src/lib.rs
hskang9 Jan 31, 2020
77ba252
no-prometheus flag add
nodebreaker0-0 Jan 31, 2020
5e327c2
/metrics url Input check
nodebreaker0-0 Jan 31, 2020
ccb3179
remove prometheus in Tracing
nodebreaker0-0 Feb 5, 2020
152176f
remove prometheus in Tracing
nodebreaker0-0 Feb 14, 2020
8de57c2
Merge branch 'master' into prometheus_v0.3
nodebreaker0-0 Feb 14, 2020
e76f200
chore: master code rebase edit
nodebreaker0-0 Feb 14, 2020
55428b7
gitlab-check-web-wasm edit code
nodebreaker0-0 Feb 14, 2020
d1003e6
From:from and cargo.lock update
nodebreaker0-0 Feb 17, 2020
5c2e085
Merge commit 'db1ab7d18fbe7876cdea43bbf30f147ddd263f94' into promethe…
nodebreaker0-0 Feb 17, 2020
b4b4432
with_prometheus_registry add background_tasks
nodebreaker0-0 Feb 17, 2020
ee421a6
Merge commit '419e5fd0026cfd528cd3b327789bb0a3a8215703' into promethe…
nodebreaker0-0 Feb 18, 2020
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
60 changes: 29 additions & 31 deletions Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

3 changes: 1 addition & 2 deletions Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -48,9 +48,8 @@ members = [
"client/telemetry",
"client/transaction-pool",
"client/transaction-pool/graph",
"utils/prometheus",
"utils/wasm-builder-runner",
"utils/grafana-data-source",
"utils/grafana-data-source/test",
"frame/assets",
"frame/aura",
"frame/authority-discovery",
Expand Down
1 change: 1 addition & 0 deletions client/cli/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -29,6 +29,7 @@ sp-core = { version = "2.0.0", path = "../../primitives/core" }
sc-service = { version = "0.8", default-features = false, path = "../service" }
sp-state-machine = { version = "0.8", path = "../../primitives/state-machine" }
sc-telemetry = { version = "2.0.0", path = "../telemetry" }
prometheus-exporter = { path = "../../utils/prometheus" }
sp-keyring = { version = "2.0.0", path = "../../primitives/keyring" }
names = "0.11.0"
structopt = "=0.3.7"
Expand Down
13 changes: 8 additions & 5 deletions client/cli/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -1065,13 +1065,9 @@ where

let rpc_interface: &str = interface_str(cli.rpc_external, cli.unsafe_rpc_external, cli.validator)?;
let ws_interface: &str = interface_str(cli.ws_external, cli.unsafe_ws_external, cli.validator)?;
let grafana_interface: &str = if cli.grafana_external { "0.0.0.0" } else { "127.0.0.1" };

config.rpc_http = Some(parse_address(&format!("{}:{}", rpc_interface, 9933), cli.rpc_port)?);
config.rpc_ws = Some(parse_address(&format!("{}:{}", ws_interface, 9944), cli.ws_port)?);
config.grafana_port = Some(
parse_address(&format!("{}:{}", grafana_interface, 9955), cli.grafana_port)?
);

config.rpc_ws_max_connections = cli.ws_max_connections;
config.rpc_cors = cli.rpc_cors.unwrap_or_else(|| if is_dev {
Expand All @@ -1094,7 +1090,14 @@ where
} else if !cli.telemetry_endpoints.is_empty() {
config.telemetry_endpoints = Some(TelemetryEndpoints::new(cli.telemetry_endpoints));
}

// Override prometheus
if cli.no_prometheus {
config.prometheus_port = None;
} else {
let prometheus_interface: &str = if cli.prometheus_external { "0.0.0.0" } else { "127.0.0.1" };
config.prometheus_port = Some(
parse_address(&format!("{}:{}", prometheus_interface, 9615), cli.prometheus_port)?);
}
config.tracing_targets = cli.tracing_targets.into();
config.tracing_receiver = cli.tracing_receiver.into();

Expand Down
22 changes: 14 additions & 8 deletions client/cli/src/params.rs
Original file line number Diff line number Diff line change
Expand Up @@ -299,7 +299,7 @@ arg_enum! {
pub enum TracingReceiver {
Log,
Telemetry,
Grafana,
Prometheus,
}
}

Expand All @@ -308,7 +308,7 @@ impl Into<sc_tracing::TracingReceiver> for TracingReceiver {
match self {
TracingReceiver::Log => sc_tracing::TracingReceiver::Log,
TracingReceiver::Telemetry => sc_tracing::TracingReceiver::Telemetry,
TracingReceiver::Grafana => sc_tracing::TracingReceiver::Grafana,
TracingReceiver::Prometheus => sc_tracing::TracingReceiver::Prometheus,
}
}
}
Expand Down Expand Up @@ -448,11 +448,11 @@ pub struct RunCmd {
#[structopt(long = "unsafe-ws-external")]
pub unsafe_ws_external: bool,

/// Listen to all Grafana data source interfaces.
/// Listen to all Prometheus endpoint interfaces.
///
/// Default is local.
#[structopt(long = "grafana-external")]
pub grafana_external: bool,
#[structopt(long = "prometheus-external")]
pub prometheus_external: bool,

/// Specify HTTP RPC server TCP port.
#[structopt(long = "rpc-port", value_name = "PORT")]
Expand All @@ -476,9 +476,15 @@ pub struct RunCmd {
#[structopt(long = "rpc-cors", value_name = "ORIGINS", parse(try_from_str = parse_cors))]
pub rpc_cors: Option<Cors>,

/// Specify Grafana data source server TCP Port.
#[structopt(long = "grafana-port", value_name = "PORT")]
pub grafana_port: Option<u16>,
/// Specify Prometheus endpoint TCP Port.
#[structopt(long = "prometheus-port", value_name = "PORT")]
pub prometheus_port: Option<u16>,

/// Disable connecting to the Substrate prometheus.
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
/// Disable connecting to the Substrate prometheus.
/// Do not expose a Prometheus metric endpoint.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

One does not disable others to connect to it, but the exposition in itself.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

complete

///
/// prometheus is on by default on global chains.
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
/// prometheus is on by default on global chains.
/// Prometheus metric endpoint is enabled by default.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

complete

#[structopt(long = "no-prometheus")]
pub no_prometheus: bool,

/// The human-readable name for this node.
///
Expand Down
2 changes: 1 addition & 1 deletion client/service/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -51,7 +51,7 @@ sc-rpc = { version = "2.0.0", path = "../rpc" }
sc-telemetry = { version = "2.0.0", path = "../telemetry" }
sc-offchain = { version = "2.0.0", path = "../offchain" }
parity-multiaddr = { package = "parity-multiaddr", version = "0.5.0" }
grafana-data-source = { version = "0.8", path = "../../utils/grafana-data-source" }
prometheus-exporter = { path = "../../utils/prometheus" }
sc-tracing = { version = "2.0.0", path = "../tracing" }
tracing = "0.1.10"

Expand Down
Loading