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 1763840044071805ℹ️ migrating to version 1... /build/pkg/database/migrations.go:66
5 1763840044071886ℹ️ migrating to version 2... /build/pkg/database/migrations.go:73
6 1763840044071912ℹ️ migrating to version 3... /build/pkg/database/migrations.go:80
7 1763840044071918ℹ️ cleaning up ephemeral events (kinds 20000-29999)... /build/pkg/database/migrations.go:294
8 1763840044071926ℹ️ cleaned up 0 ephemeral events from database /build/pkg/database/migrations.go:339
9 1763840044071941ℹ️ migrating to version 4... /build/pkg/database/migrations.go:87
10 1763840044071946ℹ️ converting events to optimized inline storage (Reiser4 optimization)... /build/pkg/database/migrations.go:347
11 1763840044071959ℹ️ found 0 events to convert (0 regular, 0 replaceable, 0 addressable) /build/pkg/database/migrations.go:436
12 1763840044071965ℹ️ migration complete: converted 0 events to optimized inline storage, deleted 0 old keys /build/pkg/database/migrations.go:545
13 1763840044071993ℹ️ migrating to version 5... /build/pkg/database/migrations.go:94
14 1763840044072003ℹ️ re-encoding events with optimized tag binary format... /build/pkg/database/migrations.go:552
15 1763840044072012ℹ️ found 0 events with e/p tags to re-encode /build/pkg/database/migrations.go:639
16 1763840044072017ℹ️ 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/22 19:34:04 WARN: Failed to load embedded library from /tmp/orly-libsecp256k1/libsecp256k1.so: Error relocating /tmp/orly-libsecp256k1/libsecp256k1.so: __fprintf_chk: symbol not found, falling back to system paths
27 2025/11/22 19:34:04 INFO: Successfully loaded libsecp256k1 v5.0.0 from system path: libsecp256k1.so.2
28 Events saved: 50000/50000 (100.0%), errors: 0
29 Duration: 3.370139282s
30 Events/sec: 14836.18
31 Avg latency: 1.545053ms
32 P90 latency: 2.163496ms
33 P95 latency: 2.562666ms
34 P99 latency: 3.871045ms
35 Bottom 10% Avg latency: 829.94µs
36 Wiping database between tests...
37 RunBurstPatternTest (Badger)..
38
39 === Burst Pattern Test ===
40 Burst completed: 5000 events in 291.316304ms
41 Burst completed: 5000 events in 318.38321ms
42 Burst completed: 5000 events in 369.717856ms
43 Burst completed: 5000 events in 386.679947ms
44 Burst completed: 5000 events in 313.894228ms
45 Burst completed: 5000 events in 375.7593ms
46 Burst completed: 5000 events in 300.682893ms
47 Burst completed: 5000 events in 270.421689ms
48 Burst completed: 5000 events in 281.989788ms
49 Burst completed: 5000 events in 265.54975ms
50 Burst test completed: 50000 events in 8.181579562s, errors: 0
51 Events/sec: 6111.29
52 Wiping database between tests...
53 RunMixedReadWriteTest (Badger)..
54
55 === Mixed Read/Write Test ===
56 Generating 1000 unique synthetic events (minimum 300 bytes each)...
57 Generated 1000 events:
58 Average content size: 312 bytes
59 All events are unique (incremental timestamps)
60 All events are properly signed
61
62 Pre-populating database for read tests...
63 Generating 50000 unique synthetic events (minimum 300 bytes each)...
64 Generated 50000 events:
65 Average content size: 314 bytes
66 All events are unique (incremental timestamps)
67 All events are properly signed
68
69 Mixed test completed: 25000 writes, 25000 reads in 24.611048938s
70 Combined ops/sec: 2031.61
71 Wiping database between tests...
72 RunQueryTest (Badger)..
73
74 === Query Test ===
75 Generating 10000 unique synthetic events (minimum 300 bytes each)...
76 Generated 10000 events:
77 Average content size: 313 bytes
78 All events are unique (incremental timestamps)
79 All events are properly signed
80
81 Pre-populating database with 10000 events for query tests...
82 Query test completed: 388576 queries in 1m0.007765782s
83 Queries/sec: 6475.43
84 Avg query latency: 1.737292ms
85 P95 query latency: 7.011739ms
86 P99 query latency: 11.25404ms
87 Wiping database between tests...
88 RunConcurrentQueryStoreTest (Badger)..
89
90 === Concurrent Query/Store Test ===
91 Generating 5000 unique synthetic events (minimum 300 bytes each)...
92 Generated 5000 events:
93 Average content size: 313 bytes
94 All events are unique (incremental timestamps)
95 All events are properly signed
96
97 Pre-populating database with 5000 events for concurrent query/store test...
98 Generating 50000 unique synthetic events (minimum 300 bytes each)...
99 Generated 50000 events:
100 Average content size: 314 bytes
101 All events are unique (incremental timestamps)
102 All events are properly signed
103
104 Concurrent test completed: 320770 operations (270770 queries, 50000 writes) in 1m0.003815149s
105 Operations/sec: 5345.83
106 Avg latency: 1.418636ms
107 Avg query latency: 1.407911ms
108 Avg write latency: 1.476716ms
109 P95 latency: 3.545655ms
110 P99 latency: 5.727035ms
111
112 === Badger benchmark completed ===
113
114
115 ================================================================================
116 BENCHMARK REPORT
117 ================================================================================
118
119 Test: Peak Throughput
120 Duration: 3.370139282s
121 Total Events: 50000
122 Events/sec: 14836.18
123 Success Rate: 100.0%
124 Concurrent Workers: 24
125 Memory Used: 131 MB
126 Avg Latency: 1.545053ms
127 P90 Latency: 2.163496ms
128 P95 Latency: 2.562666ms
129 P99 Latency: 3.871045ms
130 Bottom 10% Avg Latency: 829.94µs
131 ----------------------------------------
132
133 Test: Burst Pattern
134 Duration: 8.181579562s
135 Total Events: 50000
136 Events/sec: 6111.29
137 Success Rate: 100.0%
138 Concurrent Workers: 24
139 Memory Used: 205 MB
140 Avg Latency: 1.336805ms
141 P90 Latency: 2.051133ms
142 P95 Latency: 2.417039ms
143 P99 Latency: 3.368018ms
144 Bottom 10% Avg Latency: 499.404µs
145 ----------------------------------------
146
147 Test: Mixed Read/Write
148 Duration: 24.611048938s
149 Total Events: 50000
150 Events/sec: 2031.61
151 Success Rate: 100.0%
152 Concurrent Workers: 24
153 Memory Used: 112 MB
154 Avg Latency: 397.462µs
155 P90 Latency: 827.995µs
156 P95 Latency: 936.832µs
157 P99 Latency: 1.2249ms
158 Bottom 10% Avg Latency: 1.08713ms
159 ----------------------------------------
160
161 Test: Query Performance
162 Duration: 1m0.007765782s
163 Total Events: 388576
164 Events/sec: 6475.43
165 Success Rate: 100.0%
166 Concurrent Workers: 24
167 Memory Used: 117 MB
168 Avg Latency: 1.737292ms
169 P90 Latency: 5.250359ms
170 P95 Latency: 7.011739ms
171 P99 Latency: 11.25404ms
172 Bottom 10% Avg Latency: 7.872769ms
173 ----------------------------------------
174
175 Test: Concurrent Query/Store
176 Duration: 1m0.003815149s
177 Total Events: 320770
178 Events/sec: 5345.83
179 Success Rate: 100.0%
180 Concurrent Workers: 24
181 Memory Used: 112 MB
182 Avg Latency: 1.418636ms
183 P90 Latency: 2.830856ms
184 P95 Latency: 3.545655ms
185 P99 Latency: 5.727035ms
186 Bottom 10% Avg Latency: 4.081447ms
187 ----------------------------------------
188
189 Report saved to: /tmp/benchmark_nostr-rs-relay_8/benchmark_report.txt
190 AsciiDoc report saved to: /tmp/benchmark_nostr-rs-relay_8/benchmark_report.adoc
191
192 RELAY_NAME: nostr-rs-relay
193 RELAY_URL: ws://nostr-rs-relay:8080
194 TEST_TIMESTAMP: 2025-11-22T19:37:22+00:00
195 BENCHMARK_CONFIG:
196 Events: 50000
197 Workers: 24
198 Duration: 60s
199