 85bf1341f3
			
		
	
	85bf1341f3
	
	
	
		
			
			Frontend Enhancements: - Complete React TypeScript frontend with modern UI components - Distributed workflows management interface with real-time updates - Socket.IO integration for live agent status monitoring - Agent management dashboard with cluster visualization - Project management interface with metrics and task tracking - Responsive design with proper error handling and loading states Backend Infrastructure: - Distributed coordinator for multi-agent workflow orchestration - Cluster management API with comprehensive agent operations - Enhanced database models for agents and projects - Project service for filesystem-based project discovery - Performance monitoring and metrics collection - Comprehensive API documentation and error handling Documentation: - Complete distributed development guide (README_DISTRIBUTED.md) - Comprehensive development report with architecture insights - System configuration templates and deployment guides The platform now provides a complete web interface for managing the distributed AI cluster with real-time monitoring, workflow orchestration, and agent coordination capabilities. 🤖 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com>
		
			
				
	
	
		
			67 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			67 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| 'use strict'
 | |
| 
 | |
| const max = 1000000
 | |
| const fastqueue = require('./')(worker, 1)
 | |
| const { promisify } = require('util')
 | |
| const immediate = promisify(setImmediate)
 | |
| const qPromise = require('./').promise(immediate, 1)
 | |
| const async = require('async')
 | |
| const neo = require('neo-async')
 | |
| const asyncqueue = async.queue(worker, 1)
 | |
| const neoqueue = neo.queue(worker, 1)
 | |
| 
 | |
| function bench (func, done) {
 | |
|   const key = max + '*' + func.name
 | |
|   let count = -1
 | |
| 
 | |
|   console.time(key)
 | |
|   end()
 | |
| 
 | |
|   function end () {
 | |
|     if (++count < max) {
 | |
|       func(end)
 | |
|     } else {
 | |
|       console.timeEnd(key)
 | |
|       if (done) {
 | |
|         done()
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| function benchFastQ (done) {
 | |
|   fastqueue.push(42, done)
 | |
| }
 | |
| 
 | |
| function benchAsyncQueue (done) {
 | |
|   asyncqueue.push(42, done)
 | |
| }
 | |
| 
 | |
| function benchNeoQueue (done) {
 | |
|   neoqueue.push(42, done)
 | |
| }
 | |
| 
 | |
| function worker (arg, cb) {
 | |
|   setImmediate(cb)
 | |
| }
 | |
| 
 | |
| function benchSetImmediate (cb) {
 | |
|   worker(42, cb)
 | |
| }
 | |
| 
 | |
| function benchFastQPromise (done) {
 | |
|   qPromise.push(42).then(function () { done() }, done)
 | |
| }
 | |
| 
 | |
| function runBench (done) {
 | |
|   async.eachSeries([
 | |
|     benchSetImmediate,
 | |
|     benchFastQ,
 | |
|     benchNeoQueue,
 | |
|     benchAsyncQueue,
 | |
|     benchFastQPromise
 | |
|   ], bench, done)
 | |
| }
 | |
| 
 | |
| runBench(runBench)
 |