next-orly-neo4j_results.txt raw
1 Starting Nostr Relay Benchmark (Badger Backend)
2 Data Directory: /tmp/benchmark_next-orly-neo4j_8
3 Events: 50000, Workers: 24, Duration: 1m0s
4 1764845495230040ℹ️ migrating to version 1... /build/pkg/database/migrations.go:68
5 1764845495230118ℹ️ migrating to version 2... /build/pkg/database/migrations.go:75
6 1764845495230154ℹ️ migrating to version 3... /build/pkg/database/migrations.go:82
7 1764845495230159ℹ️ cleaning up ephemeral events (kinds 20000-29999)... /build/pkg/database/migrations.go:304
8 1764845495230168ℹ️ cleaned up 0 ephemeral events from database /build/pkg/database/migrations.go:349
9 1764845495230182ℹ️ migrating to version 4... /build/pkg/database/migrations.go:89
10 1764845495230187ℹ️ converting events to optimized inline storage (Reiser4 optimization)... /build/pkg/database/migrations.go:357
11 1764845495230198ℹ️ found 0 events to convert (0 regular, 0 replaceable, 0 addressable) /build/pkg/database/migrations.go:446
12 1764845495230204ℹ️ migration complete: converted 0 events to optimized inline storage, deleted 0 old keys /build/pkg/database/migrations.go:555
13 1764845495230219ℹ️ migrating to version 5... /build/pkg/database/migrations.go:96
14 1764845495230224ℹ️ re-encoding events with optimized tag binary format... /build/pkg/database/migrations.go:562
15 1764845495230232ℹ️ found 0 events with e/p tags to re-encode /build/pkg/database/migrations.go:649
16 1764845495230237ℹ️ no events need re-encoding /build/pkg/database/migrations.go:652
17 1764845495230250ℹ️ migrating to version 6... /build/pkg/database/migrations.go:103
18 1764845495230255ℹ️ converting events to compact serial-reference format... /build/pkg/database/migrations.go:706
19 1764845495230265ℹ️ found 0 events to convert to compact format /build/pkg/database/migrations.go:846
20 1764845495230269ℹ️ no events need conversion /build/pkg/database/migrations.go:849
21
22 ╔════════════════════════════════════════════════════════╗
23 ║ BADGER BACKEND BENCHMARK SUITE ║
24 ╚════════════════════════════════════════════════════════╝
25
26 === Starting Badger benchmark ===
27 RunPeakThroughputTest (Badger)..
28
29 === Peak Throughput Test ===
30 2025/12/04 10:51:35 INFO: Successfully loaded embedded libsecp256k1 v5.0.0 from /tmp/orly-libsecp256k1/libsecp256k1.so
31 Events saved: 50000/50000 (100.0%), errors: 0
32 Duration: 3.737037757s
33 Events/sec: 13379.58
34 Avg latency: 1.744659ms
35 P90 latency: 2.47401ms
36 P95 latency: 2.895953ms
37 P99 latency: 4.909556ms
38 Bottom 10% Avg latency: 897.762µs
39 Wiping database between tests...
40 RunBurstPatternTest (Badger)..
41
42 === Burst Pattern Test ===
43 Burst completed: 5000 events in 421.882059ms
44 Burst completed: 5000 events in 412.531799ms
45 Burst completed: 5000 events in 429.098267ms
46 Burst completed: 5000 events in 390.670143ms
47 Burst completed: 5000 events in 438.603112ms
48 Burst completed: 5000 events in 366.944086ms
49 Burst completed: 5000 events in 534.455064ms
50 Burst completed: 5000 events in 559.621403ms
51 Burst completed: 5000 events in 393.427363ms
52 Burst completed: 5000 events in 371.875354ms
53 Burst test completed: 50000 events in 9.324705477s, errors: 0
54 Events/sec: 5362.10
55 Wiping database between tests...
56 RunMixedReadWriteTest (Badger)..
57
58 === Mixed Read/Write Test ===
59 Generating 1000 unique synthetic events (minimum 300 bytes each)...
60 Generated 1000 events:
61 Average content size: 312 bytes
62 All events are unique (incremental timestamps)
63 All events are properly signed
64
65 Pre-populating database for read tests...
66 Generating 50000 unique synthetic events (minimum 300 bytes each)...
67 Generated 50000 events:
68 Average content size: 314 bytes
69 All events are unique (incremental timestamps)
70 All events are properly signed
71
72 Mixed test completed: 25000 writes, 25000 reads in 24.924958418s
73 Combined ops/sec: 2006.02
74 Wiping database between tests...
75 RunQueryTest (Badger)..
76
77 === Query Test ===
78 Generating 10000 unique synthetic events (minimum 300 bytes each)...
79 Generated 10000 events:
80 Average content size: 313 bytes
81 All events are unique (incremental timestamps)
82 All events are properly signed
83
84 Pre-populating database with 10000 events for query tests...
85 Query test completed: 244167 queries in 1m0.008740456s
86 Queries/sec: 4068.86
87 Avg query latency: 4.157543ms
88 P95 query latency: 15.724716ms
89 P99 query latency: 24.284362ms
90 Wiping database between tests...
91 RunConcurrentQueryStoreTest (Badger)..
92
93 === Concurrent Query/Store Test ===
94 Generating 5000 unique synthetic events (minimum 300 bytes each)...
95 Generated 5000 events:
96 Average content size: 313 bytes
97 All events are unique (incremental timestamps)
98 All events are properly signed
99
100 Pre-populating database with 5000 events for concurrent query/store test...
101 Generating 50000 unique synthetic events (minimum 300 bytes each)...
102 Generated 50000 events:
103 Average content size: 314 bytes
104 All events are unique (incremental timestamps)
105 All events are properly signed
106
107 Concurrent test completed: 227664 operations (177664 queries, 50000 writes) in 1m0.005538199s
108 Operations/sec: 3794.05
109 Avg latency: 2.523997ms
110 Avg query latency: 2.668863ms
111 Avg write latency: 2.009247ms
112 P95 latency: 7.235855ms
113 P99 latency: 20.657306ms
114
115 === Badger benchmark completed ===
116
117
118 ================================================================================
119 BENCHMARK REPORT
120 ================================================================================
121
122 Test: Peak Throughput
123 Duration: 3.737037757s
124 Total Events: 50000
125 Events/sec: 13379.58
126 Success Rate: 100.0%
127 Concurrent Workers: 24
128 Memory Used: 217 MB
129 Avg Latency: 1.744659ms
130 P90 Latency: 2.47401ms
131 P95 Latency: 2.895953ms
132 P99 Latency: 4.909556ms
133 Bottom 10% Avg Latency: 897.762µs
134 ----------------------------------------
135
136 Test: Burst Pattern
137 Duration: 9.324705477s
138 Total Events: 50000
139 Events/sec: 5362.10
140 Success Rate: 100.0%
141 Concurrent Workers: 24
142 Memory Used: 304 MB
143 Avg Latency: 2.063122ms
144 P90 Latency: 3.130188ms
145 P95 Latency: 3.8975ms
146 P99 Latency: 6.378352ms
147 Bottom 10% Avg Latency: 954.959µs
148 ----------------------------------------
149
150 Test: Mixed Read/Write
151 Duration: 24.924958418s
152 Total Events: 50000
153 Events/sec: 2006.02
154 Success Rate: 100.0%
155 Concurrent Workers: 24
156 Memory Used: 272 MB
157 Avg Latency: 475.177µs
158 P90 Latency: 996.497µs
159 P95 Latency: 1.205595ms
160 P99 Latency: 1.873106ms
161 Bottom 10% Avg Latency: 1.414397ms
162 ----------------------------------------
163
164 Test: Query Performance
165 Duration: 1m0.008740456s
166 Total Events: 244167
167 Events/sec: 4068.86
168 Success Rate: 100.0%
169 Concurrent Workers: 24
170 Memory Used: 148 MB
171 Avg Latency: 4.157543ms
172 P90 Latency: 12.228439ms
173 P95 Latency: 15.724716ms
174 P99 Latency: 24.284362ms
175 Bottom 10% Avg Latency: 17.427943ms
176 ----------------------------------------
177
178 Test: Concurrent Query/Store
179 Duration: 1m0.005538199s
180 Total Events: 227664
181 Events/sec: 3794.05
182 Success Rate: 100.0%
183 Concurrent Workers: 24
184 Memory Used: 211 MB
185 Avg Latency: 2.523997ms
186 P90 Latency: 5.269722ms
187 P95 Latency: 7.235855ms
188 P99 Latency: 20.657306ms
189 Bottom 10% Avg Latency: 10.288906ms
190 ----------------------------------------
191
192 Report saved to: /tmp/benchmark_next-orly-neo4j_8/benchmark_report.txt
193 AsciiDoc report saved to: /tmp/benchmark_next-orly-neo4j_8/benchmark_report.adoc
194
195 RELAY_NAME: next-orly-neo4j
196 RELAY_URL: ws://next-orly-neo4j:8080
197 TEST_TIMESTAMP: 2025-12-04T10:54:54+00:00
198 BENCHMARK_CONFIG:
199 Events: 50000
200 Workers: 24
201 Duration: 60s
202