hungry-ghost-hive 0.45.0 → 0.46.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cli/commands/cluster.d.ts.map +1 -1
- package/dist/cli/commands/cluster.js +348 -1
- package/dist/cli/commands/cluster.js.map +1 -1
- package/dist/cli/commands/cluster.test.js +313 -9
- package/dist/cli/commands/cluster.test.js.map +1 -1
- package/dist/cli/commands/req-spawn.test.d.ts +2 -0
- package/dist/cli/commands/req-spawn.test.d.ts.map +1 -0
- package/dist/cli/commands/req-spawn.test.js +116 -0
- package/dist/cli/commands/req-spawn.test.js.map +1 -0
- package/dist/cli/commands/req.d.ts.map +1 -1
- package/dist/cli/commands/req.js +21 -13
- package/dist/cli/commands/req.js.map +1 -1
- package/dist/cluster/cluster-http-server.d.ts +32 -0
- package/dist/cluster/cluster-http-server.d.ts.map +1 -1
- package/dist/cluster/cluster-http-server.js +42 -0
- package/dist/cluster/cluster-http-server.js.map +1 -1
- package/dist/cluster/distributed-runtime-coverage.test.js +9 -0
- package/dist/cluster/distributed-runtime-coverage.test.js.map +1 -1
- package/dist/cluster/distributed-system.test.js +135 -0
- package/dist/cluster/distributed-system.test.js.map +1 -1
- package/dist/cluster/events.d.ts +23 -0
- package/dist/cluster/events.d.ts.map +1 -1
- package/dist/cluster/events.js +74 -0
- package/dist/cluster/events.js.map +1 -1
- package/dist/cluster/heartbeat-manager.d.ts +2 -0
- package/dist/cluster/heartbeat-manager.d.ts.map +1 -1
- package/dist/cluster/heartbeat-manager.js +42 -6
- package/dist/cluster/heartbeat-manager.js.map +1 -1
- package/dist/cluster/membership.test.d.ts +2 -0
- package/dist/cluster/membership.test.d.ts.map +1 -0
- package/dist/cluster/membership.test.js +416 -0
- package/dist/cluster/membership.test.js.map +1 -0
- package/dist/cluster/partition-safety.test.d.ts +2 -0
- package/dist/cluster/partition-safety.test.d.ts.map +1 -0
- package/dist/cluster/partition-safety.test.js +440 -0
- package/dist/cluster/partition-safety.test.js.map +1 -0
- package/dist/cluster/raft-state-machine.d.ts +33 -1
- package/dist/cluster/raft-state-machine.d.ts.map +1 -1
- package/dist/cluster/raft-state-machine.js +65 -3
- package/dist/cluster/raft-state-machine.js.map +1 -1
- package/dist/cluster/raft-store.d.ts +26 -1
- package/dist/cluster/raft-store.d.ts.map +1 -1
- package/dist/cluster/raft-store.js +137 -0
- package/dist/cluster/raft-store.js.map +1 -1
- package/dist/cluster/replication-lag.test.d.ts +2 -0
- package/dist/cluster/replication-lag.test.d.ts.map +1 -0
- package/dist/cluster/replication-lag.test.js +239 -0
- package/dist/cluster/replication-lag.test.js.map +1 -0
- package/dist/cluster/replication.d.ts +2 -2
- package/dist/cluster/replication.d.ts.map +1 -1
- package/dist/cluster/replication.js +1 -1
- package/dist/cluster/replication.js.map +1 -1
- package/dist/cluster/runtime.d.ts +78 -0
- package/dist/cluster/runtime.d.ts.map +1 -1
- package/dist/cluster/runtime.js +400 -13
- package/dist/cluster/runtime.js.map +1 -1
- package/dist/cluster/state-recovery.test.d.ts +2 -0
- package/dist/cluster/state-recovery.test.d.ts.map +1 -0
- package/dist/cluster/state-recovery.test.js +310 -0
- package/dist/cluster/state-recovery.test.js.map +1 -0
- package/dist/cluster/types.d.ts +30 -0
- package/dist/cluster/types.d.ts.map +1 -1
- package/dist/config/schema.d.ts +48 -0
- package/dist/config/schema.d.ts.map +1 -1
- package/dist/config/schema.js +11 -0
- package/dist/config/schema.js.map +1 -1
- package/dist/context-files/generator.js +1 -1
- package/dist/context-files/generator.js.map +1 -1
- package/dist/context-files/generator.test.js +51 -0
- package/dist/context-files/generator.test.js.map +1 -1
- package/dist/orchestrator/orphan-recovery.d.ts +1 -1
- package/dist/orchestrator/orphan-recovery.d.ts.map +1 -1
- package/dist/orchestrator/orphan-recovery.js +4 -4
- package/dist/orchestrator/orphan-recovery.js.map +1 -1
- package/dist/orchestrator/prompt-templates.d.ts +3 -1
- package/dist/orchestrator/prompt-templates.d.ts.map +1 -1
- package/dist/orchestrator/prompt-templates.js +45 -8
- package/dist/orchestrator/prompt-templates.js.map +1 -1
- package/dist/orchestrator/prompt-templates.test.js +210 -0
- package/dist/orchestrator/prompt-templates.test.js.map +1 -1
- package/dist/orchestrator/scheduler.d.ts +1 -0
- package/dist/orchestrator/scheduler.d.ts.map +1 -1
- package/dist/orchestrator/scheduler.js +15 -10
- package/dist/orchestrator/scheduler.js.map +1 -1
- package/dist/orchestrator/scheduler.test.js +97 -6
- package/dist/orchestrator/scheduler.test.js.map +1 -1
- package/package.json +1 -1
- package/src/cli/commands/cluster.test.ts +387 -9
- package/src/cli/commands/cluster.ts +486 -1
- package/src/cli/commands/req-spawn.test.ts +153 -0
- package/src/cli/commands/req.ts +31 -18
- package/src/cluster/cluster-http-server.ts +80 -0
- package/src/cluster/distributed-runtime-coverage.test.ts +9 -0
- package/src/cluster/distributed-system.test.ts +168 -0
- package/src/cluster/events.ts +90 -0
- package/src/cluster/heartbeat-manager.ts +48 -6
- package/src/cluster/membership.test.ts +498 -0
- package/src/cluster/partition-safety.test.ts +523 -0
- package/src/cluster/raft-state-machine.ts +76 -4
- package/src/cluster/raft-store.ts +167 -1
- package/src/cluster/replication-lag.test.ts +284 -0
- package/src/cluster/replication.ts +6 -0
- package/src/cluster/runtime.ts +551 -12
- package/src/cluster/state-recovery.test.ts +420 -0
- package/src/cluster/types.ts +32 -0
- package/src/config/schema.ts +11 -0
- package/src/context-files/generator.test.ts +55 -0
- package/src/context-files/generator.ts +5 -5
- package/src/orchestrator/orphan-recovery.ts +32 -13
- package/src/orchestrator/prompt-templates.test.ts +263 -0
- package/src/orchestrator/prompt-templates.ts +49 -8
- package/src/orchestrator/scheduler.test.ts +129 -6
- package/src/orchestrator/scheduler.ts +46 -20
package/dist/cluster/runtime.js
CHANGED
|
@@ -1,9 +1,11 @@
|
|
|
1
1
|
// Licensed under the Hungry Ghost Hive License. See LICENSE.
|
|
2
2
|
import { join } from 'path';
|
|
3
|
-
import {
|
|
3
|
+
import { queryAll } from '../db/client.js';
|
|
4
|
+
import { REPLICATED_TABLES } from './adapters.js';
|
|
5
|
+
import { ClusterHttpServer, } from './cluster-http-server.js';
|
|
4
6
|
import { HeartbeatManager } from './heartbeat-manager.js';
|
|
5
7
|
import { RaftStateMachine } from './raft-state-machine.js';
|
|
6
|
-
import { applyRemoteEvents, ensureClusterTables, getAllClusterEvents, getVersionVector, mergeSimilarStories, scanLocalChanges, } from './replication.js';
|
|
8
|
+
import { applyRemoteEvents, ensureClusterTables, getAllClusterEvents, getClusterEventCount, getEffectiveVersionVector, getVersionVector, mergeSimilarStories, pruneClusterEvents, scanLocalChanges, setSnapshotVersionVector, } from './replication.js';
|
|
7
9
|
export class ClusterRuntime {
|
|
8
10
|
config;
|
|
9
11
|
options;
|
|
@@ -11,6 +13,11 @@ export class ClusterRuntime {
|
|
|
11
13
|
stopping = false;
|
|
12
14
|
eventCache = [];
|
|
13
15
|
versionVectorCache = {};
|
|
16
|
+
lastCompactionAt = 0;
|
|
17
|
+
peerLagMap = new Map();
|
|
18
|
+
lastSyncAt = null;
|
|
19
|
+
/** Cached full snapshot refreshed on every sync, served to recovering nodes. */
|
|
20
|
+
cachedSnapshot = null;
|
|
14
21
|
raft;
|
|
15
22
|
heartbeat;
|
|
16
23
|
httpServer;
|
|
@@ -27,6 +34,10 @@ export class ClusterRuntime {
|
|
|
27
34
|
postJson: (peer, path, body) => this.postJson(peer, path, body),
|
|
28
35
|
isActive: () => this.started && !this.stopping,
|
|
29
36
|
handleBackgroundError: error => this.handleBackgroundError(error),
|
|
37
|
+
onPeersUpdated: peers => {
|
|
38
|
+
// Follower received updated peer list from leader via heartbeat
|
|
39
|
+
this.raft.setPeers(peers);
|
|
40
|
+
},
|
|
30
41
|
});
|
|
31
42
|
this.httpServer = new ClusterHttpServer(config, {
|
|
32
43
|
getStatus: () => this.getStatus(),
|
|
@@ -34,6 +45,13 @@ export class ClusterRuntime {
|
|
|
34
45
|
handleHeartbeat: body => this.heartbeat.handleHeartbeat(body),
|
|
35
46
|
getDeltaFromCache: (vector, limit) => this.getDeltaFromCache(vector, limit),
|
|
36
47
|
getVersionVectorCache: () => this.versionVectorCache,
|
|
48
|
+
getReplicationLag: () => this.getReplicationLag(),
|
|
49
|
+
getFencingToken: () => this.raft.getFencingToken(),
|
|
50
|
+
validateFencingToken: token => this.raft.validateFencingToken(token),
|
|
51
|
+
isLeaderLeaseValid: () => this.raft.isLeaderLeaseValid(),
|
|
52
|
+
handleMembershipJoin: body => this.handleMembershipJoin(body),
|
|
53
|
+
handleMembershipLeave: body => this.handleMembershipLeave(body),
|
|
54
|
+
getSnapshot: () => this.cachedSnapshot ?? { version_vector: {}, tables: {} },
|
|
37
55
|
});
|
|
38
56
|
}
|
|
39
57
|
async start() {
|
|
@@ -72,6 +90,26 @@ export class ClusterRuntime {
|
|
|
72
90
|
return true;
|
|
73
91
|
return this.raft.role === 'leader';
|
|
74
92
|
}
|
|
93
|
+
getReplicationLag() {
|
|
94
|
+
return {
|
|
95
|
+
node_id: this.config.node_id,
|
|
96
|
+
total_local_events: this.eventCache.length,
|
|
97
|
+
version_vector: { ...this.versionVectorCache },
|
|
98
|
+
peers: this.raft
|
|
99
|
+
.getPeers()
|
|
100
|
+
.filter(p => p.id !== this.config.node_id)
|
|
101
|
+
.map(p => this.peerLagMap.get(p.id) || {
|
|
102
|
+
peer_id: p.id,
|
|
103
|
+
peer_url: p.url,
|
|
104
|
+
reachable: false,
|
|
105
|
+
events_behind: 0,
|
|
106
|
+
last_sync_at: null,
|
|
107
|
+
last_sync_duration_ms: null,
|
|
108
|
+
last_sync_events_applied: 0,
|
|
109
|
+
}),
|
|
110
|
+
last_sync_at: this.lastSyncAt,
|
|
111
|
+
};
|
|
112
|
+
}
|
|
75
113
|
getStatus() {
|
|
76
114
|
const raftState = this.raft.getRaftStoreState();
|
|
77
115
|
return {
|
|
@@ -83,10 +121,14 @@ export class ClusterRuntime {
|
|
|
83
121
|
is_leader: this.isLeader(),
|
|
84
122
|
leader_id: this.raft.leaderId,
|
|
85
123
|
leader_url: this.raft.getLeaderUrl(),
|
|
124
|
+
fencing_token: this.raft.getFencingToken(),
|
|
125
|
+
leader_lease_valid: this.raft.isLeaderLeaseValid(),
|
|
126
|
+
leader_lease_duration_ms: this.raft.leaderLeaseDurationMs,
|
|
86
127
|
raft_commit_index: raftState?.commit_index || 0,
|
|
87
128
|
raft_last_applied: raftState?.last_applied || 0,
|
|
88
129
|
raft_last_log_index: raftState?.last_log_index || 0,
|
|
89
|
-
peers: this.
|
|
130
|
+
peers: this.raft.getPeers().map(peer => ({ id: peer.id, url: peer.url })),
|
|
131
|
+
is_catching_up: this.raft.isCatchingUp,
|
|
90
132
|
};
|
|
91
133
|
}
|
|
92
134
|
async sync(db) {
|
|
@@ -96,49 +138,339 @@ export class ClusterRuntime {
|
|
|
96
138
|
imported_events_applied: 0,
|
|
97
139
|
merged_duplicate_stories: 0,
|
|
98
140
|
durable_log_entries_appended: 0,
|
|
141
|
+
log_entries_compacted: 0,
|
|
142
|
+
cluster_events_pruned: 0,
|
|
143
|
+
used_snapshot_recovery: false,
|
|
144
|
+
catch_up_applied: 0,
|
|
145
|
+
catch_up_total: 0,
|
|
99
146
|
};
|
|
100
147
|
}
|
|
101
148
|
const hiveDir = this.options.hiveDir || join(process.cwd(), '.hive');
|
|
102
149
|
this.raft.initializeRaftStore(hiveDir);
|
|
103
150
|
ensureClusterTables(db, this.config.node_id);
|
|
151
|
+
// Refresh snapshot cache so the HTTP endpoint always serves current data
|
|
152
|
+
this.cachedSnapshot = this.buildSnapshot(db);
|
|
104
153
|
const localEventsBefore = scanLocalChanges(db, this.config.node_id);
|
|
105
|
-
const imported = await this.pullEventsFromPeers(db);
|
|
154
|
+
const { imported, usedSnapshot, catchUpApplied, catchUpTotal } = await this.pullEventsFromPeers(db);
|
|
106
155
|
const merged = mergeSimilarStories(db, this.config.story_similarity_threshold);
|
|
107
|
-
const localEventsAfter = imported > 0 || merged > 0 ? scanLocalChanges(db, this.config.node_id) : 0;
|
|
156
|
+
const localEventsAfter = imported > 0 || merged > 0 || usedSnapshot ? scanLocalChanges(db, this.config.node_id) : 0;
|
|
108
157
|
this.refreshCache(db);
|
|
109
158
|
const durableLogEntriesAppended = this.raft.appendClusterEventsToDurableLog(getAllClusterEvents(db));
|
|
159
|
+
// Run compaction if thresholds are met and enough time has elapsed
|
|
160
|
+
const { logCompacted, eventsPruned } = this.maybeCompact(db);
|
|
110
161
|
return {
|
|
111
162
|
local_events_emitted: localEventsBefore + localEventsAfter,
|
|
112
163
|
imported_events_applied: imported,
|
|
113
164
|
merged_duplicate_stories: merged,
|
|
114
165
|
durable_log_entries_appended: durableLogEntriesAppended,
|
|
166
|
+
log_entries_compacted: logCompacted,
|
|
167
|
+
cluster_events_pruned: eventsPruned,
|
|
168
|
+
used_snapshot_recovery: usedSnapshot,
|
|
169
|
+
catch_up_applied: catchUpApplied,
|
|
170
|
+
catch_up_total: catchUpTotal,
|
|
115
171
|
};
|
|
116
172
|
}
|
|
173
|
+
handleMembershipJoin(request) {
|
|
174
|
+
const peers = this.raft.getPeers();
|
|
175
|
+
const leaderUrl = this.raft.getLeaderUrl();
|
|
176
|
+
// If not the leader, redirect to leader
|
|
177
|
+
if (this.raft.role !== 'leader') {
|
|
178
|
+
return {
|
|
179
|
+
success: false,
|
|
180
|
+
leader_id: this.raft.leaderId,
|
|
181
|
+
leader_url: leaderUrl,
|
|
182
|
+
peers: peers.map(p => ({ id: p.id, url: p.url })),
|
|
183
|
+
term: this.raft.currentTerm,
|
|
184
|
+
};
|
|
185
|
+
}
|
|
186
|
+
// Check if peer already exists
|
|
187
|
+
const existing = peers.find(p => p.id === request.node_id);
|
|
188
|
+
if (existing) {
|
|
189
|
+
// Update URL if changed
|
|
190
|
+
if (existing.url !== request.url) {
|
|
191
|
+
const updated = peers.map(p => p.id === request.node_id ? { id: p.id, url: request.url } : p);
|
|
192
|
+
this.raft.setPeers(updated);
|
|
193
|
+
this.raft.appendDurableEntry('membership_change', {
|
|
194
|
+
action: 'update',
|
|
195
|
+
node_id: request.node_id,
|
|
196
|
+
url: request.url,
|
|
197
|
+
peer_count: updated.length,
|
|
198
|
+
});
|
|
199
|
+
}
|
|
200
|
+
return {
|
|
201
|
+
success: true,
|
|
202
|
+
leader_id: this.raft.leaderId,
|
|
203
|
+
leader_url: this.config.public_url,
|
|
204
|
+
peers: this.raft.getPeers().map(p => ({ id: p.id, url: p.url })),
|
|
205
|
+
term: this.raft.currentTerm,
|
|
206
|
+
};
|
|
207
|
+
}
|
|
208
|
+
// Add new peer
|
|
209
|
+
const newPeer = { id: request.node_id, url: request.url };
|
|
210
|
+
const updated = [...peers, newPeer];
|
|
211
|
+
this.raft.setPeers(updated);
|
|
212
|
+
this.raft.appendDurableEntry('membership_change', {
|
|
213
|
+
action: 'join',
|
|
214
|
+
node_id: request.node_id,
|
|
215
|
+
url: request.url,
|
|
216
|
+
peer_count: updated.length,
|
|
217
|
+
});
|
|
218
|
+
return {
|
|
219
|
+
success: true,
|
|
220
|
+
leader_id: this.raft.leaderId,
|
|
221
|
+
leader_url: this.config.public_url,
|
|
222
|
+
peers: updated.map(p => ({ id: p.id, url: p.url })),
|
|
223
|
+
term: this.raft.currentTerm,
|
|
224
|
+
};
|
|
225
|
+
}
|
|
226
|
+
handleMembershipLeave(request) {
|
|
227
|
+
const peers = this.raft.getPeers();
|
|
228
|
+
// If not the leader, cannot process leave
|
|
229
|
+
if (this.raft.role !== 'leader') {
|
|
230
|
+
return {
|
|
231
|
+
success: false,
|
|
232
|
+
peers: peers.map(p => ({ id: p.id, url: p.url })),
|
|
233
|
+
};
|
|
234
|
+
}
|
|
235
|
+
// Cannot remove self (leader) — leader must transfer leadership first
|
|
236
|
+
if (request.node_id === this.config.node_id) {
|
|
237
|
+
return {
|
|
238
|
+
success: false,
|
|
239
|
+
peers: peers.map(p => ({ id: p.id, url: p.url })),
|
|
240
|
+
};
|
|
241
|
+
}
|
|
242
|
+
const existing = peers.find(p => p.id === request.node_id);
|
|
243
|
+
if (!existing) {
|
|
244
|
+
// Already gone
|
|
245
|
+
return {
|
|
246
|
+
success: true,
|
|
247
|
+
peers: peers.map(p => ({ id: p.id, url: p.url })),
|
|
248
|
+
};
|
|
249
|
+
}
|
|
250
|
+
const updated = peers.filter(p => p.id !== request.node_id);
|
|
251
|
+
this.raft.setPeers(updated);
|
|
252
|
+
this.raft.appendDurableEntry('membership_change', {
|
|
253
|
+
action: 'leave',
|
|
254
|
+
node_id: request.node_id,
|
|
255
|
+
peer_count: updated.length,
|
|
256
|
+
});
|
|
257
|
+
return {
|
|
258
|
+
success: true,
|
|
259
|
+
peers: updated.map(p => ({ id: p.id, url: p.url })),
|
|
260
|
+
};
|
|
261
|
+
}
|
|
262
|
+
maybeCompact(db) {
|
|
263
|
+
const now = Date.now();
|
|
264
|
+
const interval = this.config.compaction_interval_ms ?? 300000;
|
|
265
|
+
// Respect minimum interval between compaction runs
|
|
266
|
+
if (interval > 0 && now - this.lastCompactionAt < interval) {
|
|
267
|
+
return { logCompacted: 0, eventsPruned: 0 };
|
|
268
|
+
}
|
|
269
|
+
let logCompacted = 0;
|
|
270
|
+
let eventsPruned = 0;
|
|
271
|
+
// Compact raft log if threshold exceeded
|
|
272
|
+
const maxLogEntries = this.config.max_log_entries ?? 10000;
|
|
273
|
+
if (maxLogEntries > 0) {
|
|
274
|
+
const logCount = this.raft.getLogEntryCount();
|
|
275
|
+
if (logCount > maxLogEntries) {
|
|
276
|
+
const versionVector = getVersionVector(db);
|
|
277
|
+
const result = this.raft.createSnapshotAndCompact(versionVector);
|
|
278
|
+
logCompacted = result.entries_removed;
|
|
279
|
+
}
|
|
280
|
+
}
|
|
281
|
+
// Prune cluster_events if threshold exceeded
|
|
282
|
+
const maxEvents = this.config.max_cluster_events ?? 50000;
|
|
283
|
+
if (maxEvents > 0) {
|
|
284
|
+
const eventCount = getClusterEventCount(db);
|
|
285
|
+
if (eventCount > maxEvents) {
|
|
286
|
+
eventsPruned = pruneClusterEvents(db, maxEvents);
|
|
287
|
+
if (eventsPruned > 0) {
|
|
288
|
+
this.refreshCache(db);
|
|
289
|
+
}
|
|
290
|
+
}
|
|
291
|
+
}
|
|
292
|
+
if (logCompacted > 0 || eventsPruned > 0) {
|
|
293
|
+
this.lastCompactionAt = now;
|
|
294
|
+
}
|
|
295
|
+
return { logCompacted, eventsPruned };
|
|
296
|
+
}
|
|
117
297
|
refreshCache(db) {
|
|
118
298
|
this.eventCache = getAllClusterEvents(db).slice(-20000);
|
|
119
299
|
this.versionVectorCache = getVersionVector(db);
|
|
120
300
|
}
|
|
121
301
|
async pullEventsFromPeers(db) {
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
302
|
+
const peers = this.raft.getPeers();
|
|
303
|
+
if (peers.length === 0) {
|
|
304
|
+
return { imported: 0, usedSnapshot: false, catchUpApplied: 0, catchUpTotal: 0 };
|
|
305
|
+
}
|
|
306
|
+
let imported = 0;
|
|
307
|
+
const syncTimestamp = new Date().toISOString();
|
|
308
|
+
this.lastSyncAt = syncTimestamp;
|
|
309
|
+
for (const peer of peers) {
|
|
126
310
|
if (peer.id === this.config.node_id)
|
|
127
311
|
continue;
|
|
128
|
-
const localVector =
|
|
312
|
+
const localVector = getEffectiveVersionVector(db);
|
|
313
|
+
const syncStart = Date.now();
|
|
129
314
|
const response = await this.requestDelta(peer, localVector, 4000);
|
|
130
|
-
if (!response
|
|
315
|
+
if (!response) {
|
|
316
|
+
this.peerLagMap.set(peer.id, {
|
|
317
|
+
peer_id: peer.id,
|
|
318
|
+
peer_url: peer.url,
|
|
319
|
+
reachable: false,
|
|
320
|
+
events_behind: 0,
|
|
321
|
+
last_sync_at: syncTimestamp,
|
|
322
|
+
last_sync_duration_ms: Date.now() - syncStart,
|
|
323
|
+
last_sync_events_applied: 0,
|
|
324
|
+
});
|
|
325
|
+
continue;
|
|
326
|
+
}
|
|
327
|
+
// If the peer advertises a higher fencing token, step down
|
|
328
|
+
if (typeof response.fencing_token === 'number' &&
|
|
329
|
+
response.fencing_token > this.raft.currentTerm) {
|
|
330
|
+
this.raft.stepDown(response.fencing_token, null);
|
|
331
|
+
}
|
|
332
|
+
// Detect if the delta is insufficient (peer's log was truncated past our position)
|
|
333
|
+
if (this.isDeltaInsufficient(localVector, response.version_vector, response.events)) {
|
|
334
|
+
const recovery = await this.recoverFromSnapshot(db, peer);
|
|
335
|
+
if (recovery !== null) {
|
|
336
|
+
this.peerLagMap.set(peer.id, {
|
|
337
|
+
peer_id: peer.id,
|
|
338
|
+
peer_url: peer.url,
|
|
339
|
+
reachable: true,
|
|
340
|
+
events_behind: 0,
|
|
341
|
+
last_sync_at: syncTimestamp,
|
|
342
|
+
last_sync_duration_ms: Date.now() - syncStart,
|
|
343
|
+
last_sync_events_applied: recovery.applied,
|
|
344
|
+
});
|
|
345
|
+
return {
|
|
346
|
+
imported: 0,
|
|
347
|
+
usedSnapshot: true,
|
|
348
|
+
catchUpApplied: recovery.applied,
|
|
349
|
+
catchUpTotal: recovery.total,
|
|
350
|
+
};
|
|
351
|
+
}
|
|
352
|
+
// Snapshot recovery failed — fall through and apply whatever delta we have
|
|
353
|
+
}
|
|
354
|
+
const eventsBehind = response.events.length;
|
|
355
|
+
const peerApplied = eventsBehind > 0 ? applyRemoteEvents(db, this.config.node_id, response.events) : 0;
|
|
356
|
+
imported += peerApplied;
|
|
357
|
+
this.peerLagMap.set(peer.id, {
|
|
358
|
+
peer_id: peer.id,
|
|
359
|
+
peer_url: peer.url,
|
|
360
|
+
reachable: true,
|
|
361
|
+
events_behind: eventsBehind,
|
|
362
|
+
last_sync_at: syncTimestamp,
|
|
363
|
+
last_sync_duration_ms: Date.now() - syncStart,
|
|
364
|
+
last_sync_events_applied: peerApplied,
|
|
365
|
+
});
|
|
366
|
+
}
|
|
367
|
+
// If we had been catching up and now the effective vector matches peers, mark done
|
|
368
|
+
if (this.raft.isCatchingUp) {
|
|
369
|
+
this.raft.isCatchingUp = false;
|
|
370
|
+
}
|
|
371
|
+
return { imported, usedSnapshot: false, catchUpApplied: 0, catchUpTotal: 0 };
|
|
372
|
+
}
|
|
373
|
+
/**
|
|
374
|
+
* Returns true when the delta response is missing events the peer should have.
|
|
375
|
+
* This happens when the peer's event cache has been truncated (log compaction)
|
|
376
|
+
* and can no longer provide all events since our last known version.
|
|
377
|
+
*/
|
|
378
|
+
isDeltaInsufficient(localVector, peerVector, receivedEvents) {
|
|
379
|
+
// Count how many events we actually received per actor
|
|
380
|
+
const received = {};
|
|
381
|
+
for (const event of receivedEvents) {
|
|
382
|
+
received[event.version.actor_id] = (received[event.version.actor_id] ?? 0) + 1;
|
|
383
|
+
}
|
|
384
|
+
for (const [actorId, peerCounter] of Object.entries(peerVector)) {
|
|
385
|
+
const localCounter = localVector[actorId] ?? 0;
|
|
386
|
+
const needed = peerCounter - localCounter;
|
|
387
|
+
if (needed <= 0)
|
|
131
388
|
continue;
|
|
132
|
-
|
|
389
|
+
const receivedCount = received[actorId] ?? 0;
|
|
390
|
+
if (receivedCount < needed) {
|
|
391
|
+
// We're missing events for this actor that the peer should have
|
|
392
|
+
return true;
|
|
393
|
+
}
|
|
133
394
|
}
|
|
134
|
-
return
|
|
395
|
+
return false;
|
|
396
|
+
}
|
|
397
|
+
/**
|
|
398
|
+
* Requests a full snapshot from the given peer and applies it locally.
|
|
399
|
+
* Marks the node as no longer catching up once complete.
|
|
400
|
+
* Returns { applied, total } on success, null on failure.
|
|
401
|
+
*/
|
|
402
|
+
async recoverFromSnapshot(db, peer) {
|
|
403
|
+
this.raft.isCatchingUp = true;
|
|
404
|
+
this.raft.appendDurableEntry('runtime', {
|
|
405
|
+
event: 'snapshot_recovery_start',
|
|
406
|
+
node_id: this.config.node_id,
|
|
407
|
+
peer_id: peer.id,
|
|
408
|
+
});
|
|
409
|
+
const snapshot = await this.requestSnapshot(peer);
|
|
410
|
+
if (!snapshot) {
|
|
411
|
+
return null;
|
|
412
|
+
}
|
|
413
|
+
const { applied, total } = this.applySnapshot(db, snapshot);
|
|
414
|
+
this.raft.isCatchingUp = false;
|
|
415
|
+
this.raft.appendDurableEntry('runtime', {
|
|
416
|
+
event: 'snapshot_recovery_complete',
|
|
417
|
+
node_id: this.config.node_id,
|
|
418
|
+
peer_id: peer.id,
|
|
419
|
+
rows_applied: applied,
|
|
420
|
+
rows_total: total,
|
|
421
|
+
});
|
|
422
|
+
return { applied, total };
|
|
423
|
+
}
|
|
424
|
+
/**
|
|
425
|
+
* Applies a snapshot to the local database, upserting all rows from all tables.
|
|
426
|
+
* Stores the snapshot's version vector so future delta requests start from here.
|
|
427
|
+
*/
|
|
428
|
+
applySnapshot(db, snapshot) {
|
|
429
|
+
let applied = 0;
|
|
430
|
+
let total = 0;
|
|
431
|
+
for (const adapter of REPLICATED_TABLES) {
|
|
432
|
+
const rows = snapshot.tables[adapter.table];
|
|
433
|
+
if (!rows)
|
|
434
|
+
continue;
|
|
435
|
+
total += rows.length;
|
|
436
|
+
for (const row of rows) {
|
|
437
|
+
adapter.upsert(db, row.payload);
|
|
438
|
+
applied++;
|
|
439
|
+
}
|
|
440
|
+
}
|
|
441
|
+
// Record the snapshot version vector so future delta requests
|
|
442
|
+
// only ask for events newer than this snapshot
|
|
443
|
+
setSnapshotVersionVector(db, snapshot.version_vector);
|
|
444
|
+
return { applied, total };
|
|
445
|
+
}
|
|
446
|
+
/**
|
|
447
|
+
* Builds a full snapshot of all replicated tables from the current db state.
|
|
448
|
+
* Called during sync to keep cachedSnapshot fresh for the HTTP endpoint.
|
|
449
|
+
*/
|
|
450
|
+
buildSnapshot(db) {
|
|
451
|
+
const tables = {};
|
|
452
|
+
for (const adapter of REPLICATED_TABLES) {
|
|
453
|
+
const rows = queryAll(db, adapter.selectSql);
|
|
454
|
+
tables[adapter.table] = rows.map(row => ({
|
|
455
|
+
rowId: adapter.rowId(row),
|
|
456
|
+
payload: adapter.payload(row),
|
|
457
|
+
}));
|
|
458
|
+
}
|
|
459
|
+
return {
|
|
460
|
+
version_vector: getVersionVector(db),
|
|
461
|
+
tables,
|
|
462
|
+
};
|
|
135
463
|
}
|
|
136
464
|
async requestDelta(peer, versionVector, limit) {
|
|
137
465
|
return this.postJson(peer, '/cluster/v1/events/delta', {
|
|
138
466
|
version_vector: versionVector,
|
|
139
467
|
limit,
|
|
468
|
+
fencing_token: this.raft.getFencingToken(),
|
|
140
469
|
});
|
|
141
470
|
}
|
|
471
|
+
async requestSnapshot(peer) {
|
|
472
|
+
return this.getJson(peer, '/cluster/v1/snapshot');
|
|
473
|
+
}
|
|
142
474
|
getDeltaFromCache(remoteVersionVector, limit) {
|
|
143
475
|
return this.eventCache
|
|
144
476
|
.filter(event => {
|
|
@@ -155,6 +487,11 @@ export class ClusterRuntime {
|
|
|
155
487
|
body,
|
|
156
488
|
});
|
|
157
489
|
}
|
|
490
|
+
async getJson(peer, path) {
|
|
491
|
+
const normalizedBase = peer.url.endsWith('/') ? peer.url : `${peer.url}/`;
|
|
492
|
+
const url = new URL(path.replace(/^\//, ''), normalizedBase).toString();
|
|
493
|
+
return fetchClusterStatusOrPostJson(url, this.config.request_timeout_ms, this.config.auth_token, { method: 'GET' });
|
|
494
|
+
}
|
|
158
495
|
handleBackgroundError(error) {
|
|
159
496
|
if (!this.started || this.stopping)
|
|
160
497
|
return;
|
|
@@ -171,6 +508,48 @@ export class ClusterRuntime {
|
|
|
171
508
|
throw new Error(`Cluster auth_token is required when listen_host is not loopback (received: ${this.config.listen_host})`);
|
|
172
509
|
}
|
|
173
510
|
}
|
|
511
|
+
export async function fetchReplicationLag(config) {
|
|
512
|
+
if (!config.enabled)
|
|
513
|
+
return null;
|
|
514
|
+
const host = config.listen_host === '0.0.0.0' ? '127.0.0.1' : config.listen_host;
|
|
515
|
+
const url = `http://${host}:${config.listen_port}/cluster/v1/replication-lag`;
|
|
516
|
+
return fetchClusterStatusOrPostJson(url, config.request_timeout_ms, config.auth_token, { method: 'GET' });
|
|
517
|
+
}
|
|
518
|
+
/**
|
|
519
|
+
* Fetches recent cluster events from the local runtime via the delta endpoint.
|
|
520
|
+
* Uses an empty version vector to request recent events up to the given limit.
|
|
521
|
+
*/
|
|
522
|
+
export async function fetchLocalClusterEvents(config, limit = 50) {
|
|
523
|
+
if (!config.enabled)
|
|
524
|
+
return null;
|
|
525
|
+
const host = config.listen_host === '0.0.0.0' ? '127.0.0.1' : config.listen_host;
|
|
526
|
+
const url = `http://${host}:${config.listen_port}/cluster/v1/events/delta`;
|
|
527
|
+
const response = await fetchClusterStatusOrPostJson(url, config.request_timeout_ms, config.auth_token, { method: 'POST', body: { version_vector: {}, limit } });
|
|
528
|
+
return response?.events ?? null;
|
|
529
|
+
}
|
|
530
|
+
/**
|
|
531
|
+
* POSTs to the local cluster runtime at the given path.
|
|
532
|
+
*/
|
|
533
|
+
export async function postToLocalCluster(config, path, body) {
|
|
534
|
+
if (!config.enabled)
|
|
535
|
+
return null;
|
|
536
|
+
const host = config.listen_host === '0.0.0.0' ? '127.0.0.1' : config.listen_host;
|
|
537
|
+
const url = `http://${host}:${config.listen_port}${path}`;
|
|
538
|
+
return fetchClusterStatusOrPostJson(url, config.request_timeout_ms, config.auth_token, {
|
|
539
|
+
method: 'POST',
|
|
540
|
+
body,
|
|
541
|
+
});
|
|
542
|
+
}
|
|
543
|
+
/**
|
|
544
|
+
* POSTs to a peer cluster node at the given URL and path.
|
|
545
|
+
*/
|
|
546
|
+
export async function postToPeerCluster(peerUrl, path, body, options) {
|
|
547
|
+
const url = `${peerUrl.replace(/\/$/, '')}${path}`;
|
|
548
|
+
return fetchClusterStatusOrPostJson(url, options.timeoutMs, options.authToken, {
|
|
549
|
+
method: 'POST',
|
|
550
|
+
body,
|
|
551
|
+
});
|
|
552
|
+
}
|
|
174
553
|
export async function fetchLocalClusterStatus(config) {
|
|
175
554
|
if (!config.enabled) {
|
|
176
555
|
return {
|
|
@@ -182,10 +561,14 @@ export async function fetchLocalClusterStatus(config) {
|
|
|
182
561
|
is_leader: true,
|
|
183
562
|
leader_id: config.node_id,
|
|
184
563
|
leader_url: null,
|
|
564
|
+
fencing_token: 0,
|
|
565
|
+
leader_lease_valid: true,
|
|
566
|
+
leader_lease_duration_ms: config.leader_lease_ms ?? config.heartbeat_interval_ms * 3,
|
|
185
567
|
raft_commit_index: 0,
|
|
186
568
|
raft_last_applied: 0,
|
|
187
569
|
raft_last_log_index: 0,
|
|
188
570
|
peers: config.peers.map(peer => ({ id: peer.id, url: peer.url })),
|
|
571
|
+
is_catching_up: false,
|
|
189
572
|
};
|
|
190
573
|
}
|
|
191
574
|
const host = config.listen_host === '0.0.0.0' ? '127.0.0.1' : config.listen_host;
|
|
@@ -228,10 +611,14 @@ function parseClusterStatus(input) {
|
|
|
228
611
|
is_leader: input.is_leader === true,
|
|
229
612
|
leader_id: typeof input.leader_id === 'string' ? input.leader_id : null,
|
|
230
613
|
leader_url: typeof input.leader_url === 'string' ? input.leader_url : null,
|
|
614
|
+
fencing_token: toInt(input.fencing_token),
|
|
615
|
+
leader_lease_valid: input.leader_lease_valid === true,
|
|
616
|
+
leader_lease_duration_ms: toInt(input.leader_lease_duration_ms),
|
|
231
617
|
raft_commit_index: toInt(input.raft_commit_index),
|
|
232
618
|
raft_last_applied: toInt(input.raft_last_applied),
|
|
233
619
|
raft_last_log_index: toInt(input.raft_last_log_index),
|
|
234
620
|
peers,
|
|
621
|
+
is_catching_up: input.is_catching_up === true,
|
|
235
622
|
};
|
|
236
623
|
}
|
|
237
624
|
async function fetchClusterStatusOrPostJson(url, timeoutMs, authToken, options) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"runtime.js","sourceRoot":"","sources":["../../src/cluster/runtime.ts"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"runtime.js","sourceRoot":"","sources":["../../src/cluster/runtime.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"state-recovery.test.d.ts","sourceRoot":"","sources":["../../src/cluster/state-recovery.test.ts"],"names":[],"mappings":""}
|