@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.
@@ -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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"}