@theaiinc/yggdrasil 0.1.0 → 0.2.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/src/index.d.ts +2 -4
- package/dist/src/index.d.ts.map +1 -1
- package/dist/src/index.js +1 -3
- package/dist/src/index.js.map +1 -1
- package/dist/src/orchestration-controller.d.ts +2 -0
- package/dist/src/orchestration-controller.d.ts.map +1 -0
- package/dist/src/orchestration-controller.js +191 -0
- package/dist/src/orchestration-controller.js.map +1 -0
- package/dist/src/services/logger.d.ts +1 -14
- package/dist/src/services/logger.d.ts.map +1 -1
- package/dist/src/services/logger.js +0 -55
- package/dist/src/services/logger.js.map +1 -1
- package/dist/src/types/index.d.ts +0 -129
- package/dist/src/types/index.d.ts.map +1 -1
- package/package.json +6 -24
- package/LICENSE +0 -21
- package/README.md +0 -340
- package/dist/src/services/agent-manager.d.ts +0 -69
- package/dist/src/services/agent-manager.d.ts.map +0 -1
- package/dist/src/services/agent-manager.js +0 -227
- package/dist/src/services/agent-manager.js.map +0 -1
- package/dist/src/services/load-balancer.d.ts +0 -62
- package/dist/src/services/load-balancer.d.ts.map +0 -1
- package/dist/src/services/load-balancer.js +0 -221
- package/dist/src/services/load-balancer.js.map +0 -1
|
@@ -1,62 +0,0 @@
|
|
|
1
|
-
import { AgentInfo, RequestContext } from '@/types';
|
|
2
|
-
/**
|
|
3
|
-
* Load balancer for distributing requests across healthy agents
|
|
4
|
-
* Implements multiple algorithms and session affinity
|
|
5
|
-
*/
|
|
6
|
-
export declare class LoadBalancer {
|
|
7
|
-
private logger;
|
|
8
|
-
private currentIndex;
|
|
9
|
-
private sessionMap;
|
|
10
|
-
private algorithm;
|
|
11
|
-
private sessionAffinity;
|
|
12
|
-
private stickySessionTimeout;
|
|
13
|
-
constructor(algorithm?: 'round-robin' | 'least-connections' | 'ip-hash' | 'weighted', sessionAffinity?: boolean, stickySessionTimeout?: number);
|
|
14
|
-
/**
|
|
15
|
-
* Select an agent for the given request
|
|
16
|
-
*/
|
|
17
|
-
selectAgent(agents: AgentInfo[], context: RequestContext): AgentInfo | null;
|
|
18
|
-
/**
|
|
19
|
-
* Round-robin algorithm
|
|
20
|
-
*/
|
|
21
|
-
private roundRobin;
|
|
22
|
-
/**
|
|
23
|
-
* Least connections algorithm
|
|
24
|
-
*/
|
|
25
|
-
private leastConnections;
|
|
26
|
-
/**
|
|
27
|
-
* IP hash algorithm (uses request ID as hash input)
|
|
28
|
-
*/
|
|
29
|
-
private ipHash;
|
|
30
|
-
/**
|
|
31
|
-
* Weighted algorithm (based on agent health and performance)
|
|
32
|
-
*/
|
|
33
|
-
private weighted;
|
|
34
|
-
/**
|
|
35
|
-
* Simple hash function for IP hash algorithm
|
|
36
|
-
*/
|
|
37
|
-
private hashCode;
|
|
38
|
-
/**
|
|
39
|
-
* Clean up stale session mappings
|
|
40
|
-
*/
|
|
41
|
-
private cleanupStaleSessions;
|
|
42
|
-
/**
|
|
43
|
-
* Remove session mapping
|
|
44
|
-
*/
|
|
45
|
-
removeSession(sessionId: string): void;
|
|
46
|
-
/**
|
|
47
|
-
* Get session statistics
|
|
48
|
-
*/
|
|
49
|
-
getSessionStats(): {
|
|
50
|
-
totalSessions: number;
|
|
51
|
-
sessionMapSize: number;
|
|
52
|
-
};
|
|
53
|
-
/**
|
|
54
|
-
* Update algorithm
|
|
55
|
-
*/
|
|
56
|
-
setAlgorithm(algorithm: 'round-robin' | 'least-connections' | 'ip-hash' | 'weighted'): void;
|
|
57
|
-
/**
|
|
58
|
-
* Update session affinity settings
|
|
59
|
-
*/
|
|
60
|
-
setSessionAffinity(enabled: boolean, timeout?: number): void;
|
|
61
|
-
}
|
|
62
|
-
//# sourceMappingURL=load-balancer.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"load-balancer.d.ts","sourceRoot":"","sources":["../../../src/services/load-balancer.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,cAAc,EAAE,MAAM,SAAS,CAAC;AAGpD;;;GAGG;AACH,qBAAa,YAAY;IACvB,OAAO,CAAC,MAAM,CAAe;IAC7B,OAAO,CAAC,YAAY,CAAK;IACzB,OAAO,CAAC,UAAU,CAA6B;IAC/C,OAAO,CAAC,SAAS,CAIF;IACf,OAAO,CAAC,eAAe,CAAU;IACjC,OAAO,CAAC,oBAAoB,CAAS;gBAGnC,SAAS,GACL,aAAa,GACb,mBAAmB,GACnB,SAAS,GACT,UAA0B,EAC9B,eAAe,GAAE,OAAc,EAC/B,oBAAoB,GAAE,MAAgB;IAOxC;;OAEG;IACI,WAAW,CAChB,MAAM,EAAE,SAAS,EAAE,EACnB,OAAO,EAAE,cAAc,GACtB,SAAS,GAAG,IAAI;IA2EnB;;OAEG;IACH,OAAO,CAAC,UAAU;IASlB;;OAEG;IACH,OAAO,CAAC,gBAAgB;IAQxB;;OAEG;IACH,OAAO,CAAC,MAAM;IASd;;OAEG;IACH,OAAO,CAAC,QAAQ;IA+BhB;;OAEG;IACH,OAAO,CAAC,QAAQ;IAUhB;;OAEG;IACH,OAAO,CAAC,oBAAoB;IA+B5B;;OAEG;IACI,aAAa,CAAC,SAAS,EAAE,MAAM,GAAG,IAAI;IAI7C;;OAEG;IACI,eAAe,IAAI;QAAE,aAAa,EAAE,MAAM,CAAC;QAAC,cAAc,EAAE,MAAM,CAAA;KAAE;IAO3E;;OAEG;IACI,YAAY,CACjB,SAAS,EAAE,aAAa,GAAG,mBAAmB,GAAG,SAAS,GAAG,UAAU,GACtE,IAAI;IAKP;;OAEG;IACI,kBAAkB,CAAC,OAAO,EAAE,OAAO,EAAE,OAAO,CAAC,EAAE,MAAM,GAAG,IAAI;CAUpE"}
|
|
@@ -1,221 +0,0 @@
|
|
|
1
|
-
import { getLogger } from './logger';
|
|
2
|
-
/**
|
|
3
|
-
* Load balancer for distributing requests across healthy agents
|
|
4
|
-
* Implements multiple algorithms and session affinity
|
|
5
|
-
*/
|
|
6
|
-
export class LoadBalancer {
|
|
7
|
-
logger = getLogger();
|
|
8
|
-
currentIndex = 0;
|
|
9
|
-
sessionMap = new Map(); // sessionId -> agentId
|
|
10
|
-
algorithm;
|
|
11
|
-
sessionAffinity;
|
|
12
|
-
stickySessionTimeout;
|
|
13
|
-
constructor(algorithm = 'round-robin', sessionAffinity = true, stickySessionTimeout = 3600000 // 1 hour
|
|
14
|
-
) {
|
|
15
|
-
this.algorithm = algorithm;
|
|
16
|
-
this.sessionAffinity = sessionAffinity;
|
|
17
|
-
this.stickySessionTimeout = stickySessionTimeout;
|
|
18
|
-
}
|
|
19
|
-
/**
|
|
20
|
-
* Select an agent for the given request
|
|
21
|
-
*/
|
|
22
|
-
selectAgent(agents, context) {
|
|
23
|
-
if (agents.length === 0) {
|
|
24
|
-
this.logger.warn('No healthy agents available');
|
|
25
|
-
return null;
|
|
26
|
-
}
|
|
27
|
-
// Filter to only healthy agents
|
|
28
|
-
const healthyAgents = agents.filter(agent => agent.health.status === 'healthy');
|
|
29
|
-
if (healthyAgents.length === 0) {
|
|
30
|
-
this.logger.warn('No healthy agents available');
|
|
31
|
-
return null;
|
|
32
|
-
}
|
|
33
|
-
// Check session affinity first
|
|
34
|
-
if (this.sessionAffinity && context.sessionId) {
|
|
35
|
-
const sessionAgentId = this.sessionMap.get(context.sessionId);
|
|
36
|
-
if (sessionAgentId) {
|
|
37
|
-
const sessionAgent = healthyAgents.find(agent => agent.id === sessionAgentId);
|
|
38
|
-
if (sessionAgent) {
|
|
39
|
-
this.logger.debug('Using session affinity', {
|
|
40
|
-
sessionId: context.sessionId,
|
|
41
|
-
agentId: sessionAgent.id,
|
|
42
|
-
});
|
|
43
|
-
return sessionAgent;
|
|
44
|
-
}
|
|
45
|
-
else {
|
|
46
|
-
// Remove stale session mapping
|
|
47
|
-
this.sessionMap.delete(context.sessionId);
|
|
48
|
-
}
|
|
49
|
-
}
|
|
50
|
-
}
|
|
51
|
-
// Select agent based on algorithm
|
|
52
|
-
let selectedAgent = null;
|
|
53
|
-
try {
|
|
54
|
-
switch (this.algorithm) {
|
|
55
|
-
case 'round-robin':
|
|
56
|
-
selectedAgent = this.roundRobin(healthyAgents);
|
|
57
|
-
break;
|
|
58
|
-
case 'least-connections':
|
|
59
|
-
selectedAgent = this.leastConnections(healthyAgents);
|
|
60
|
-
break;
|
|
61
|
-
case 'ip-hash':
|
|
62
|
-
selectedAgent = this.ipHash(healthyAgents, context);
|
|
63
|
-
break;
|
|
64
|
-
case 'weighted':
|
|
65
|
-
selectedAgent = this.weighted(healthyAgents);
|
|
66
|
-
break;
|
|
67
|
-
default:
|
|
68
|
-
selectedAgent = this.roundRobin(healthyAgents);
|
|
69
|
-
}
|
|
70
|
-
}
|
|
71
|
-
catch (error) {
|
|
72
|
-
this.logger.error('Agent selection failed', {
|
|
73
|
-
error,
|
|
74
|
-
algorithm: this.algorithm,
|
|
75
|
-
});
|
|
76
|
-
return null;
|
|
77
|
-
}
|
|
78
|
-
// Update session mapping if session affinity is enabled
|
|
79
|
-
if (this.sessionAffinity && context.sessionId && selectedAgent) {
|
|
80
|
-
this.sessionMap.set(context.sessionId, selectedAgent.id);
|
|
81
|
-
// Clean up old session mappings periodically
|
|
82
|
-
this.cleanupStaleSessions();
|
|
83
|
-
}
|
|
84
|
-
return selectedAgent;
|
|
85
|
-
}
|
|
86
|
-
/**
|
|
87
|
-
* Round-robin algorithm
|
|
88
|
-
*/
|
|
89
|
-
roundRobin(agents) {
|
|
90
|
-
const agent = agents[this.currentIndex % agents.length];
|
|
91
|
-
if (!agent) {
|
|
92
|
-
throw new Error('No agents available for round-robin selection');
|
|
93
|
-
}
|
|
94
|
-
this.currentIndex = (this.currentIndex + 1) % agents.length;
|
|
95
|
-
return agent;
|
|
96
|
-
}
|
|
97
|
-
/**
|
|
98
|
-
* Least connections algorithm
|
|
99
|
-
*/
|
|
100
|
-
leastConnections(agents) {
|
|
101
|
-
return agents.reduce((min, current) => current.metrics.activeConnections < min.metrics.activeConnections
|
|
102
|
-
? current
|
|
103
|
-
: min);
|
|
104
|
-
}
|
|
105
|
-
/**
|
|
106
|
-
* IP hash algorithm (uses request ID as hash input)
|
|
107
|
-
*/
|
|
108
|
-
ipHash(agents, context) {
|
|
109
|
-
const hash = this.hashCode(context.id);
|
|
110
|
-
const agent = agents[Math.abs(hash) % agents.length];
|
|
111
|
-
if (!agent) {
|
|
112
|
-
throw new Error('No agents available for IP hash selection');
|
|
113
|
-
}
|
|
114
|
-
return agent;
|
|
115
|
-
}
|
|
116
|
-
/**
|
|
117
|
-
* Weighted algorithm (based on agent health and performance)
|
|
118
|
-
*/
|
|
119
|
-
weighted(agents) {
|
|
120
|
-
const weights = agents.map(agent => {
|
|
121
|
-
let weight = 1;
|
|
122
|
-
// Reduce weight for agents with high error rates
|
|
123
|
-
if (agent.metrics.errorRate > 0.1) {
|
|
124
|
-
weight *= 0.5;
|
|
125
|
-
}
|
|
126
|
-
// Reduce weight for agents with high response times
|
|
127
|
-
if (agent.metrics.averageResponseTime > 1000) {
|
|
128
|
-
weight *= 0.7;
|
|
129
|
-
}
|
|
130
|
-
// Increase weight for agents with low CPU usage
|
|
131
|
-
if (agent.metrics.cpuUsage < 0.5) {
|
|
132
|
-
weight *= 1.2;
|
|
133
|
-
}
|
|
134
|
-
return { agent, weight };
|
|
135
|
-
});
|
|
136
|
-
// Sort by weight and return the highest weighted agent
|
|
137
|
-
weights.sort((a, b) => b.weight - a.weight);
|
|
138
|
-
const selectedAgent = weights[0]?.agent;
|
|
139
|
-
if (!selectedAgent) {
|
|
140
|
-
throw new Error('No agents available for weighted selection');
|
|
141
|
-
}
|
|
142
|
-
return selectedAgent;
|
|
143
|
-
}
|
|
144
|
-
/**
|
|
145
|
-
* Simple hash function for IP hash algorithm
|
|
146
|
-
*/
|
|
147
|
-
hashCode(str) {
|
|
148
|
-
let hash = 0;
|
|
149
|
-
for (let i = 0; i < str.length; i++) {
|
|
150
|
-
const char = str.charCodeAt(i);
|
|
151
|
-
hash = (hash << 5) - hash + char;
|
|
152
|
-
hash = hash & hash; // Convert to 32-bit integer
|
|
153
|
-
}
|
|
154
|
-
return hash;
|
|
155
|
-
}
|
|
156
|
-
/**
|
|
157
|
-
* Clean up stale session mappings
|
|
158
|
-
*/
|
|
159
|
-
cleanupStaleSessions() {
|
|
160
|
-
const staleSessions = [];
|
|
161
|
-
// This is a simplified cleanup - in a real implementation,
|
|
162
|
-
// you'd want to track session creation times
|
|
163
|
-
if (this.sessionMap.size > 1000) {
|
|
164
|
-
// If we have too many sessions, clean up some randomly
|
|
165
|
-
const sessions = Array.from(this.sessionMap.keys());
|
|
166
|
-
const toRemove = Math.floor(sessions.length * 0.1); // Remove 10%
|
|
167
|
-
for (let i = 0; i < toRemove; i++) {
|
|
168
|
-
const randomIndex = Math.floor(Math.random() * sessions.length);
|
|
169
|
-
const sessionId = sessions[randomIndex];
|
|
170
|
-
if (sessionId) {
|
|
171
|
-
staleSessions.push(sessionId);
|
|
172
|
-
sessions.splice(randomIndex, 1);
|
|
173
|
-
}
|
|
174
|
-
}
|
|
175
|
-
}
|
|
176
|
-
staleSessions.forEach(sessionId => {
|
|
177
|
-
this.sessionMap.delete(sessionId);
|
|
178
|
-
});
|
|
179
|
-
if (staleSessions.length > 0) {
|
|
180
|
-
this.logger.debug('Cleaned up stale sessions', {
|
|
181
|
-
count: staleSessions.length,
|
|
182
|
-
});
|
|
183
|
-
}
|
|
184
|
-
}
|
|
185
|
-
/**
|
|
186
|
-
* Remove session mapping
|
|
187
|
-
*/
|
|
188
|
-
removeSession(sessionId) {
|
|
189
|
-
this.sessionMap.delete(sessionId);
|
|
190
|
-
}
|
|
191
|
-
/**
|
|
192
|
-
* Get session statistics
|
|
193
|
-
*/
|
|
194
|
-
getSessionStats() {
|
|
195
|
-
return {
|
|
196
|
-
totalSessions: this.sessionMap.size,
|
|
197
|
-
sessionMapSize: this.sessionMap.size,
|
|
198
|
-
};
|
|
199
|
-
}
|
|
200
|
-
/**
|
|
201
|
-
* Update algorithm
|
|
202
|
-
*/
|
|
203
|
-
setAlgorithm(algorithm) {
|
|
204
|
-
this.algorithm = algorithm;
|
|
205
|
-
this.logger.info('Load balancer algorithm updated', { algorithm });
|
|
206
|
-
}
|
|
207
|
-
/**
|
|
208
|
-
* Update session affinity settings
|
|
209
|
-
*/
|
|
210
|
-
setSessionAffinity(enabled, timeout) {
|
|
211
|
-
this.sessionAffinity = enabled;
|
|
212
|
-
if (timeout) {
|
|
213
|
-
this.stickySessionTimeout = timeout;
|
|
214
|
-
}
|
|
215
|
-
this.logger.info('Session affinity settings updated', {
|
|
216
|
-
enabled: this.sessionAffinity,
|
|
217
|
-
timeout: this.stickySessionTimeout,
|
|
218
|
-
});
|
|
219
|
-
}
|
|
220
|
-
}
|
|
221
|
-
//# sourceMappingURL=load-balancer.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"load-balancer.js","sourceRoot":"","sources":["../../../src/services/load-balancer.ts"],"names":[],"mappings":"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"}
|