-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathobservability.star
121 lines (107 loc) · 3.93 KB
/
observability.star
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
prometheus_package = import_module(
"github.com/kurtosis-tech/prometheus-package/main.star"
)
grafana_package = import_module(
"github.com/kurtosis-tech/grafana-package/main.star@6772a4e4ae07cf5256b8a10e466587b73119bab5"
)
service_package = import_module("./lib/service.star")
databases_package = import_module("./databases.star")
def start_panoptichain(plan, args):
# Create the panoptichain config.
panoptichain_config_template = read_file(
src="./templates/observability/panoptichain-config.yml"
)
contract_setup_addresses = service_package.get_contract_setup_addresses(plan, args)
panoptichain_config_artifact = plan.render_templates(
name="panoptichain-config",
config={
"config.yml": struct(
template=panoptichain_config_template,
data={
"l1_rpc_url": args["l1_rpc_url"],
"zkevm_rpc_url": args["zkevm_rpc_url"],
"l1_chain_id": args["l1_chain_id"],
"zkevm_rollup_chain_id": args["zkevm_rollup_chain_id"],
}
| contract_setup_addresses,
)
},
)
# Start panoptichain.
return plan.add_service(
name="panoptichain" + args["deployment_suffix"],
config=ServiceConfig(
image=args["panoptichain_image"],
ports={
"prometheus": PortSpec(9090, application_protocol="http"),
},
files={"/etc/panoptichain": panoptichain_config_artifact},
),
)
def run(plan, args):
for service in plan.get_services():
if service.name == args["l2_rpc_name"] + args["deployment_suffix"]:
args["zkevm_rpc_url"] = "http://{}:{}".format(
service.ip_address, service.ports["http-rpc"].number
)
if (
service.name
== databases_package.POSTGRES_SERVICE_NAME + args["deployment_suffix"]
):
args["postgres_url"] = "{}:{}".format(
service.ip_address, service.ports["postgres"].number
)
# Start panoptichain.
start_panoptichain(plan, args)
metrics_jobs = []
for service in plan.get_services():
if "prometheus" not in service.ports:
continue
metrics_path = "/metrics"
if service.name.startswith("cdk-erigon"):
metrics_path = "/debug/metrics/prometheus"
metrics_jobs.append(
{
"Name": service.name,
"Endpoint": "{0}:{1}".format(
service.ip_address,
service.ports["prometheus"].number,
),
"MetricsPath": metrics_path,
}
)
# Start prometheus.
prometheus_url = prometheus_package.run(
plan,
metrics_jobs,
name="prometheus" + args["deployment_suffix"],
)
grafana_alerting_data = {}
if "slack_alerts" in args:
grafana_alerting_data = {
"SlackChannel": args["slack_alerts"]["slack_channel"],
"SlackToken": args["slack_alerts"]["slack_token"],
"MentionUsers": args["slack_alerts"]["mention_users"],
}
databases = []
for database in databases_package.DATABASES.values():
databases.append(
{
"URL": args["postgres_url"],
"Name": database["name"],
"User": database["user"],
"Password": database["password"],
"Version": 1500,
}
)
# Start grafana.
grafana_package.run(
plan,
prometheus_url,
"github.com/0xPolygon/kurtosis-cdk/static-files/dashboards",
name="grafana" + args["deployment_suffix"],
grafana_version="11.1.0",
grafana_alerting_template="github.com/0xPolygon/kurtosis-cdk/static-files/alerting.yml.tmpl",
grafana_alerting_data=grafana_alerting_data,
postgres_databases=databases,
)