nostr-rs-relay_results.txt raw
1 Starting Nostr Relay Benchmark (Badger Backend)
2 Data Directory: /tmp/benchmark_nostr-rs-relay_8
3 Events: 50000, Workers: 24, Duration: 1m0s
4 1764144072428228ℹ️ migrating to version 1... /build/pkg/database/migrations.go:66
5 1764144072428311ℹ️ migrating to version 2... /build/pkg/database/migrations.go:73
6 1764144072428332ℹ️ migrating to version 3... /build/pkg/database/migrations.go:80
7 1764144072428337ℹ️ cleaning up ephemeral events (kinds 20000-29999)... /build/pkg/database/migrations.go:294
8 1764144072428348ℹ️ cleaned up 0 ephemeral events from database /build/pkg/database/migrations.go:339
9 1764144072428362ℹ️ migrating to version 4... /build/pkg/database/migrations.go:87
10 1764144072428367ℹ️ converting events to optimized inline storage (Reiser4 optimization)... /build/pkg/database/migrations.go:347
11 1764144072428382ℹ️ found 0 events to convert (0 regular, 0 replaceable, 0 addressable) /build/pkg/database/migrations.go:436
12 1764144072428388ℹ️ migration complete: converted 0 events to optimized inline storage, deleted 0 old keys /build/pkg/database/migrations.go:545
13 1764144072428403ℹ️ migrating to version 5... /build/pkg/database/migrations.go:94
14 1764144072428407ℹ️ re-encoding events with optimized tag binary format... /build/pkg/database/migrations.go:552
15 1764144072428461ℹ️ found 0 events with e/p tags to re-encode /build/pkg/database/migrations.go:639
16 1764144072428504ℹ️ no events need re-encoding /build/pkg/database/migrations.go:642
17
18 ╔════════════════════════════════════════════════════════╗
19 ║ BADGER BACKEND BENCHMARK SUITE ║
20 ╚════════════════════════════════════════════════════════╝
21
22 === Starting Badger benchmark ===
23 RunPeakThroughputTest (Badger)..
24
25 === Peak Throughput Test ===
26 2025/11/26 08:01:12 INFO: Successfully loaded embedded libsecp256k1 v5.0.0 from /tmp/orly-libsecp256k1/libsecp256k1.so
27 Events saved: 50000/50000 (100.0%), errors: 0
28 Duration: 3.174311581s
29 Events/sec: 15751.45
30 Avg latency: 1.442411ms
31 P90 latency: 1.94422ms
32 P95 latency: 2.22848ms
33 P99 latency: 3.230197ms
34 Bottom 10% Avg latency: 812.222µs
35 Wiping database between tests...
36 RunBurstPatternTest (Badger)..
37
38 === Burst Pattern Test ===
39 Burst completed: 5000 events in 307.983371ms
40 Burst completed: 5000 events in 362.020748ms
41 Burst completed: 5000 events in 287.762195ms
42 Burst completed: 5000 events in 312.062236ms
43 Burst completed: 5000 events in 293.876571ms
44 Burst completed: 5000 events in 374.103253ms
45 Burst completed: 5000 events in 310.909244ms
46 Burst completed: 5000 events in 283.004205ms
47 Burst completed: 5000 events in 298.739839ms
48 Burst completed: 5000 events in 276.165042ms
49 Burst test completed: 50000 events in 8.112460039s, errors: 0
50 Events/sec: 6163.36
51 Wiping database between tests...
52 RunMixedReadWriteTest (Badger)..
53
54 === Mixed Read/Write Test ===
55 Generating 1000 unique synthetic events (minimum 300 bytes each)...
56 Generated 1000 events:
57 Average content size: 312 bytes
58 All events are unique (incremental timestamps)
59 All events are properly signed
60
61 Pre-populating database for read tests...
62 Generating 50000 unique synthetic events (minimum 300 bytes each)...
63 Generated 50000 events:
64 Average content size: 314 bytes
65 All events are unique (incremental timestamps)
66 All events are properly signed
67
68 Mixed test completed: 25000 writes, 25000 reads in 24.41340672s
69 Combined ops/sec: 2048.06
70 Wiping database between tests...
71 RunQueryTest (Badger)..
72
73 === Query Test ===
74 Generating 10000 unique synthetic events (minimum 300 bytes each)...
75 Generated 10000 events:
76 Average content size: 313 bytes
77 All events are unique (incremental timestamps)
78 All events are properly signed
79
80 Pre-populating database with 10000 events for query tests...
81 Query test completed: 370248 queries in 1m0.004253098s
82 Queries/sec: 6170.36
83 Avg query latency: 1.845097ms
84 P95 query latency: 7.60818ms
85 P99 query latency: 11.65437ms
86 Wiping database between tests...
87 RunConcurrentQueryStoreTest (Badger)..
88
89 === Concurrent Query/Store Test ===
90 Generating 5000 unique synthetic events (minimum 300 bytes each)...
91 Generated 5000 events:
92 Average content size: 313 bytes
93 All events are unique (incremental timestamps)
94 All events are properly signed
95
96 Pre-populating database with 5000 events for concurrent query/store test...
97 Generating 50000 unique synthetic events (minimum 300 bytes each)...
98 Generated 50000 events:
99 Average content size: 314 bytes
100 All events are unique (incremental timestamps)
101 All events are properly signed
102
103 Concurrent test completed: 309475 operations (259475 queries, 50000 writes) in 1m0.004403417s
104 Operations/sec: 5157.54
105 Avg latency: 1.523601ms
106 Avg query latency: 1.501844ms
107 Avg write latency: 1.63651ms
108 P95 latency: 3.938186ms
109 P99 latency: 6.342582ms
110
111 === Badger benchmark completed ===
112
113
114 ================================================================================
115 BENCHMARK REPORT
116 ================================================================================
117
118 Test: Peak Throughput
119 Duration: 3.174311581s
120 Total Events: 50000
121 Events/sec: 15751.45
122 Success Rate: 100.0%
123 Concurrent Workers: 24
124 Memory Used: 205 MB
125 Avg Latency: 1.442411ms
126 P90 Latency: 1.94422ms
127 P95 Latency: 2.22848ms
128 P99 Latency: 3.230197ms
129 Bottom 10% Avg Latency: 812.222µs
130 ----------------------------------------
131
132 Test: Burst Pattern
133 Duration: 8.112460039s
134 Total Events: 50000
135 Events/sec: 6163.36
136 Success Rate: 100.0%
137 Concurrent Workers: 24
138 Memory Used: 254 MB
139 Avg Latency: 1.414472ms
140 P90 Latency: 1.957275ms
141 P95 Latency: 2.267184ms
142 P99 Latency: 3.19513ms
143 Bottom 10% Avg Latency: 750.181µs
144 ----------------------------------------
145
146 Test: Mixed Read/Write
147 Duration: 24.41340672s
148 Total Events: 50000
149 Events/sec: 2048.06
150 Success Rate: 100.0%
151 Concurrent Workers: 24
152 Memory Used: 129 MB
153 Avg Latency: 400.791µs
154 P90 Latency: 826.182µs
155 P95 Latency: 921.434µs
156 P99 Latency: 1.143516ms
157 Bottom 10% Avg Latency: 1.063808ms
158 ----------------------------------------
159
160 Test: Query Performance
161 Duration: 1m0.004253098s
162 Total Events: 370248
163 Events/sec: 6170.36
164 Success Rate: 100.0%
165 Concurrent Workers: 24
166 Memory Used: 156 MB
167 Avg Latency: 1.845097ms
168 P90 Latency: 5.757979ms
169 P95 Latency: 7.60818ms
170 P99 Latency: 11.65437ms
171 Bottom 10% Avg Latency: 8.384135ms
172 ----------------------------------------
173
174 Test: Concurrent Query/Store
175 Duration: 1m0.004403417s
176 Total Events: 309475
177 Events/sec: 5157.54
178 Success Rate: 100.0%
179 Concurrent Workers: 24
180 Memory Used: 142 MB
181 Avg Latency: 1.523601ms
182 P90 Latency: 3.071867ms
183 P95 Latency: 3.938186ms
184 P99 Latency: 6.342582ms
185 Bottom 10% Avg Latency: 4.516506ms
186 ----------------------------------------
187
188 Report saved to: /tmp/benchmark_nostr-rs-relay_8/benchmark_report.txt
189 AsciiDoc report saved to: /tmp/benchmark_nostr-rs-relay_8/benchmark_report.adoc
190
191 RELAY_NAME: nostr-rs-relay
192 RELAY_URL: ws://nostr-rs-relay:8080
193 TEST_TIMESTAMP: 2025-11-26T08:04:30+00:00
194 BENCHMARK_CONFIG:
195 Events: 50000
196 Workers: 24
197 Duration: 60s
198