-
Notifications
You must be signed in to change notification settings - Fork 160
/
Copy pathglobals-bench.nix
207 lines (191 loc) · 7.58 KB
/
globals-bench.nix
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
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
pkgs:
with pkgs.lib;
let
benchmarkingParamsFile = ./benchmarking-cluster-params.json;
benchmarkingParams =
if __pathExists benchmarkingParamsFile
then let r = __fromJSON (__readFile benchmarkingParamsFile);
in if __hasAttr "meta" r
then if __hasAttr "default_profile" r.meta then r
else abort "${benchmarkingParamsFile} must define 'meta.default_profile': please run 'bench reinit' to update it"
else abort "${benchmarkingParamsFile} must define the 'meta' section: please run 'bench reinit' to update it"
else abort "Benchmarking requires ${toString benchmarkingParamsFile} to exist. Please, refer to documentation.";
benchmarkingTopologyFile =
./topologies + "/bench-${benchmarkingParams.meta.topology}-${toString (__length benchmarkingParams.meta.node_names)}.nix";
benchmarkingTopology =
if __pathExists benchmarkingTopologyFile
then __trace "Using topology: ${benchmarkingTopologyFile}"
(rewriteTopologyForProfile
(import benchmarkingTopologyFile)
benchmarkingProfile)
else abort "Benchmarking topology file implied by configured node count ${toString (__length benchmarkingParams.meta.node_names)} does not exist: ${benchmarkingTopologyFile}";
AlonzoGenesisFile = ./keys/alonzo-genesis.json;
ShelleyGenesisFile = ./keys/genesis.json;
ShelleyGenesisHash = builtins.replaceStrings ["\n"] [""] (builtins.readFile ./keys/GENHASH);
ByronGenesisFile = ./keys/byron/genesis.json;
ByronGenesisHash = builtins.replaceStrings ["\n"] [""] (builtins.readFile ./keys/byron/GENHASH);
envConfigBase = pkgs.iohkNix.cardanoLib.environments.testnet;
### Benchmarking profiles are, currently, essentially name-tagger
### generator configs.
benchmarkingProfileNameEnv = __getEnv("BENCHMARKING_PROFILE");
## WARNING: this logic must correspond to select_benchmarking_profile
## in bench.sh.
benchmarkingProfileName = if benchmarkingProfileNameEnv == ""
then benchmarkingParams.meta.default_profile
else benchmarkingProfileNameEnv;
benchmarkingProfile =
if __hasAttr benchmarkingProfileName benchmarkingParams
then __trace "Using profile: ${benchmarkingProfileName}"
benchmarkingParams."${benchmarkingProfileName}"
else abort "${benchmarkingParamsFile} does not define benchmarking profile '${benchmarkingProfileName}'.";
rewriteTopologyForProfile =
topo: prof:
let fixupPools = core: (core //
{ pools = if __hasAttr "pools" core && core.pools != null
then (if core.pools == 1 then 1 else prof.genesis.dense_pool_density)
else 0; });
pooledCores = map fixupPools topo.coreNodes;
in (topo // {
coreNodes = map withEventlog pooledCores;
});
withEventlog = def: recursiveUpdate {
services.cardano-node.eventlog = mkForce true;
services.cardano-node.package = mkForce pkgs.cardano-node-eventlogged;
} def;
metadata = {
inherit benchmarkingProfileName benchmarkingProfile benchmarkingTopology;
};
benchmarkingLogConfig = name: {
defaultScribes = [
[ "StdoutSK" "stdout" ]
[ "FileSK" "logs/${name}.json" ]
];
setupScribes = [
{
scKind = "StdoutSK";
scName = "stdout";
scFormat = "ScJson"; }
{
scKind = "FileSK";
scName = "logs/${name}.json";
scFormat = "ScJson";
scRotation = {
rpLogLimitBytes = 300000000;
rpMaxAgeHours = 24;
rpKeepFilesNum = 20;
}; }
];
options = {
mapBackends = {
"cardano.node.resources" = [ "KatipBK" ];
"cardano.node.metrics" = [ "EKGViewBK" ];
};
};
};
in (rec {
inherit benchmarkingProfile;
networkName = "Benchmarking, size ${toString (__length benchmarkingTopology.coreNodes)}";
withExplorer = false;
withMonitoring = false;
explorerBackends = {};
explorerActiveBackends = [];
environmentName = "bench-${benchmarkingParams.meta.topology}-${benchmarkingProfileName}";
sourcesJsonOverride = ./nix/sources.bench.json;
environmentConfig = rec {
relays = "relays.${pkgs.globals.domain}";
edgePort = pkgs.globals.cardanoNodePort;
private = true;
networkConfig = (removeAttrs envConfigBase.networkConfig ["AlonzoGenesisHash"]) // {
Protocol = "Cardano";
inherit AlonzoGenesisFile;
inherit ShelleyGenesisFile ShelleyGenesisHash;
inherit ByronGenesisFile ByronGenesisHash;
};
nodeConfig = (removeAttrs envConfigBase.nodeConfig ["AlonzoGenesisHash"]) // {
Protocol = "Cardano";
inherit AlonzoGenesisFile;
inherit ShelleyGenesisFile ShelleyGenesisHash;
inherit ByronGenesisFile ByronGenesisHash;
} // {
shelley =
{ TestShelleyHardForkAtEpoch = 0;
};
allegra =
{ TestShelleyHardForkAtEpoch = 0;
TestAllegraHardForkAtEpoch = 0;
};
mary =
{ TestShelleyHardForkAtEpoch = 0;
TestAllegraHardForkAtEpoch = 0;
TestMaryHardForkAtEpoch = 0;
};
}.${pkgs.globals.environmentConfig.generatorConfig.era};
txSubmitConfig = {
inherit (networkConfig) RequiresNetworkMagic;
inherit AlonzoGenesisFile ShelleyGenesisFile ByronGenesisFile;
} // pkgs.iohkNix.cardanoLib.defaultExplorerLogConfig;
## This is overlaid atop the defaults in the tx-generator service,
## as specified in the 'cardano-node' repository.
generatorConfig = benchmarkingProfile.generator;
};
topology = {
relayNodes = map (recursiveUpdate {
## XXX: assumes we have `explorer` as our only relay.
imports = [
pkgs.cardano-ops.roles.tx-generator
# ({ config, ...}: {
# })
];
documentation = {
man.enable = false;
doc.enable = false;
};
networking.firewall.allowPing = mkForce true;
services.cardano-node.package = mkForce pkgs.cardano-node-eventlogged;
systemd.services.dump-registered-relays-topology.enable = mkForce false;
}) (benchmarkingTopology.relayNodes or []);
coreNodes = map (recursiveUpdate {
stakePool = true;
documentation = {
man.enable = false;
doc.enable = false;
};
networking.firewall.allowPing = mkForce true;
services.cardano-node.nodeConfig =
recursiveUpdate
(removeAttrs pkgs.globals.environmentConfig.nodeConfig ["AlonzoGenesisHash"])
(recursiveUpdate
(benchmarkingLogConfig "node")
({
inherit ShelleyGenesisHash ByronGenesisHash;
TracingVerbosity = "NormalVerbosity";
minSeverity = "Debug";
TurnOnLogMetrics = true;
TestEnableDevelopmentHardForkEras = true;
TestEnableDevelopmentNetworkProtocols = true;
TraceMempool = true;
TraceTxInbound = true;
TraceBlockFetchClient = true;
TraceBlockFetchServer = true;
TraceChainSyncHeaderServer = true;
TraceChainSyncClient = true;
TraceTxSubmissionProtocol = true;
TraceTxSubmission2Protocol = true;
} //
(benchmarkingProfile.node.extra_config or {})));
}) (benchmarkingTopology.coreNodes or []);
};
ec2 = with pkgs.iohk-ops-lib.physical.aws;
{
instances = {
core-node = c5-2xlarge;
relay-node = c5-2xlarge;
};
credentials = {
accessKeyIds = {
IOHK = "dev-deployer";
dns = "dev-deployer";
};
};
};
})