AgentDB Advanced Features by ruvnet/ruflo
npx skills add https://github.com/ruvnet/ruflo --skill 'AgentDB Advanced Features'涵盖 AgentDB 在分布式系统、多数据库协调、自定义距离度量、混合搜索(向量 + 元数据)、QUIC 同步和生产部署模式方面的高级功能。支持构建具有亚毫秒级跨节点通信和高级搜索能力的复杂 AI 系统。
性能:<1ms QUIC 同步,带过滤器的混合搜索,自定义距离度量。
QUIC(快速 UDP 互联网连接)支持跨网络边界的 AgentDB 实例之间实现亚毫秒延迟的同步,具备自动重试、多路复用和加密功能。
优势:
import { createAgentDBAdapter } from 'agentic-flow$reasoningbank';
// 使用 QUIC 同步初始化
const adapter = await createAgentDBAdapter({
dbPath: '.agentdb$distributed.db',
enableQUICSync: true,
syncPort: 4433,
syncPeers: [
'192.168.1.10:4433',
'192.168.1.11:4433',
'192.168.1.12:4433',
],
});
// 模式会自动在所有对等节点间同步
await adapter.insertPattern({
// ... 模式数据
});
// 约 1ms 内在所有对等节点上可用
广告位招租
在这里展示您的产品或服务
触达数万 AI 开发者,精准高效
const adapter = await createAgentDBAdapter({
enableQUICSync: true,
syncPort: 4433, // QUIC 服务器端口
syncPeers: ['host1:4433'], // 对等节点地址
syncInterval: 1000, // 同步间隔 (ms)
syncBatchSize: 100, // 每批模式数量
maxRetries: 3, // 失败同步重试次数
compression: true, // 启用压缩
});
# 节点 1 (192.168.1.10)
AGENTDB_QUIC_SYNC=true \
AGENTDB_QUIC_PORT=4433 \
AGENTDB_QUIC_PEERS=192.168.1.11:4433,192.168.1.12:4433 \
node server.js
# 节点 2 (192.168.1.11)
AGENTDB_QUIC_SYNC=true \
AGENTDB_QUIC_PORT=4433 \
AGENTDB_QUIC_PEERS=192.168.1.10:4433,192.168.1.12:4433 \
node server.js
# 节点 3 (192.168.1.12)
AGENTDB_QUIC_SYNC=true \
AGENTDB_QUIC_PORT=4433 \
AGENTDB_QUIC_PEERS=192.168.1.10:4433,192.168.1.11:4433 \
node server.js
最适合归一化向量,语义相似度:
# CLI
npx agentdb@latest query .$vectors.db "[0.1,0.2,...]" -m cosine
# API
const result = await adapter.retrieveWithReasoning(queryEmbedding, {
metric: 'cosine',
k: 10,
});
使用场景:
公式:cos(θ) = (A · B) / (||A|| × ||B||) 范围:[-1, 1] (1 = 相同, -1 = 相反)
最适合空间数据,几何相似度:
# CLI
npx agentdb@latest query .$vectors.db "[0.1,0.2,...]" -m euclidean
# API
const result = await adapter.retrieveWithReasoning(queryEmbedding, {
metric: 'euclidean',
k: 10,
});
使用场景:
公式:d = √(Σ(ai - bi)²) 范围:[0, ∞] (0 = 相同, ∞ = 非常不同)
最适合预归一化向量,计算快速:
# CLI
npx agentdb@latest query .$vectors.db "[0.1,0.2,...]" -m dot
# API
const result = await adapter.retrieveWithReasoning(queryEmbedding, {
metric: 'dot',
k: 10,
});
使用场景:
公式:dot = Σ(ai × bi) 范围:[-∞, ∞] (越高越相似)
// 实现自定义距离函数
function customDistance(vec1: number[], vec2: number[]): number {
// 加权欧几里得距离
const weights = [1.0, 2.0, 1.5, ...];
let sum = 0;
for (let i = 0; i < vec1.length; i++) {
sum += weights[i] * Math.pow(vec1[i] - vec2[i], 2);
}
return Math.sqrt(sum);
}
// 在搜索中使用 (需要自定义实现)
结合向量相似度和元数据过滤:
// 存储带元数据的文档
await adapter.insertPattern({
id: '',
type: 'document',
domain: 'research-papers',
pattern_data: JSON.stringify({
embedding: documentEmbedding,
text: documentText,
metadata: {
author: 'Jane Smith',
year: 2025,
category: 'machine-learning',
citations: 150,
}
}),
confidence: 1.0,
usage_count: 0,
success_count: 0,
created_at: Date.now(),
last_used: Date.now(),
});
// 混合搜索:向量相似度 + 元数据过滤器
const result = await adapter.retrieveWithReasoning(queryEmbedding, {
domain: 'research-papers',
k: 20,
filters: {
year: { $gte: 2023 }, // 2023 年或之后发表
category: 'machine-learning', // 仅限机器学习论文
citations: { $gte: 50 }, // 高引用
},
});
// 复杂元数据查询
const result = await adapter.retrieveWithReasoning(queryEmbedding, {
domain: 'products',
k: 50,
filters: {
price: { $gte: 10, $lte: 100 }, // 价格范围
category: { $in: ['electronics', 'gadgets'] }, // 多个类别
rating: { $gte: 4.0 }, // 高评分
inStock: true, // 有库存
tags: { $contains: 'wireless' }, // 包含标签
},
});
结合向量和元数据分数:
const result = await adapter.retrieveWithReasoning(queryEmbedding, {
domain: 'content',
k: 20,
hybridWeights: {
vectorSimilarity: 0.7, // 70% 权重在语义相似度上
metadataScore: 0.3, // 30% 权重在元数据匹配上
},
filters: {
category: 'technology',
recency: { $gte: Date.now() - 30 * 24 * 3600000 }, // 最近 30 天
},
});
// 为不同领域使用独立的数据库
const knowledgeDB = await createAgentDBAdapter({
dbPath: '.agentdb$knowledge.db',
});
const conversationDB = await createAgentDBAdapter({
dbPath: '.agentdb$conversations.db',
});
const codeDB = await createAgentDBAdapter({
dbPath: '.agentdb$code.db',
});
// 为每个任务使用相应的数据库
await knowledgeDB.insertPattern({ /* 知识 */ });
await conversationDB.insertPattern({ /* 对话 */ });
await codeDB.insertPattern({ /* 代码 */ });
// 按领域分片以实现水平扩展
const shards = {
'domain-a': await createAgentDBAdapter({ dbPath: '.agentdb$shard-a.db' }),
'domain-b': await createAgentDBAdapter({ dbPath: '.agentdb$shard-b.db' }),
'domain-c': await createAgentDBAdapter({ dbPath: '.agentdb$shard-c.db' }),
};
// 将查询路由到适当的分片
function getDBForDomain(domain: string) {
const shardKey = domain.split('-')[0]; // 提取分片键
return shards[shardKey] || shards['domain-a'];
}
// 插入到正确的分片
const db = getDBForDomain('domain-a-task');
await db.insertPattern({ /* ... */ });
检索多样化的结果以避免冗余:
// 不使用 MMR:相似的结果可能冗余
const standardResults = await adapter.retrieveWithReasoning(queryEmbedding, {
k: 10,
useMMR: false,
});
// 使用 MMR:多样化、非冗余的结果
const diverseResults = await adapter.retrieveWithReasoning(queryEmbedding, {
k: 10,
useMMR: true,
mmrLambda: 0.5, // 平衡相关性 (0) 与多样性 (1)
});
MMR 参数:
mmrLambda = 0: 最大相关性 (可能冗余)mmrLambda = 0.5: 平衡 (默认)mmrLambda = 1: 最大多样性 (相关性可能较低)使用场景:
从多个记忆生成丰富的上下文:
const result = await adapter.retrieveWithReasoning(queryEmbedding, {
domain: 'problem-solving',
k: 10,
synthesizeContext: true, // 启用上下文合成
});
// ContextSynthesizer 创建连贯的叙述
console.log('合成上下文:', result.context);
// "基于 10 个类似的问题解决尝试,最有效的方法包括:1) 分析根本原因,2) 头脑风暴解决方案,3) 评估权衡,4) 增量实施。成功率:85%"
console.log('模式:', result.patterns);
// 跨记忆提取的常见模式
// 用于共享适配器的单例模式
class AgentDBPool {
private static instance: AgentDBAdapter;
static async getInstance() {
if (!this.instance) {
this.instance = await createAgentDBAdapter({
dbPath: '.agentdb$production.db',
quantizationType: 'scalar',
cacheSize: 2000,
});
}
return this.instance;
}
}
// 在应用中使用
const db = await AgentDBPool.getInstance();
const results = await db.retrieveWithReasoning(queryEmbedding, { k: 10 });
async function safeRetrieve(queryEmbedding: number[], options: any) {
try {
const result = await adapter.retrieveWithReasoning(queryEmbedding, options);
return result;
} catch (error) {
if (error.code === 'DIMENSION_MISMATCH') {
console.error('查询嵌入维度不匹配');
// 处理维度错误
} else if (error.code === 'DATABASE_LOCKED') {
// 使用指数退避重试
await new Promise(resolve => setTimeout(resolve, 100));
return safeRetrieve(queryEmbedding, options);
}
throw error;
}
}
// 性能监控
const startTime = Date.now();
const result = await adapter.retrieveWithReasoning(queryEmbedding, { k: 10 });
const latency = Date.now() - startTime;
if (latency > 100) {
console.warn('检测到慢查询:', latency, 'ms');
}
// 记录统计信息
const stats = await adapter.getStats();
console.log('数据库统计:', {
totalPatterns: stats.totalPatterns,
dbSize: stats.dbSize,
cacheHitRate: stats.cacheHitRate,
avgSearchLatency: stats.avgSearchLatency,
});
# 带压缩导出
npx agentdb@latest export .$vectors.db .$backup.json.gz --compress
# 从备份导入
npx agentdb@latest import .$backup.json.gz --decompress
# 合并数据库
npx agentdb@latest merge .$db1.sqlite .$db2.sqlite .$merged.sqlite
# 清理数据库 (回收空间)
sqlite3 .agentdb$vectors.db "VACUUM;"
# 分析查询优化
sqlite3 .agentdb$vectors.db "ANALYZE;"
# 重建索引
npx agentdb@latest reindex .$vectors.db
# AgentDB 配置
AGENTDB_PATH=.agentdb$reasoningbank.db
AGENTDB_ENABLED=true
# 性能调优
AGENTDB_QUANTIZATION=binary # binary|scalar|product|none
AGENTDB_CACHE_SIZE=2000
AGENTDB_HNSW_M=16
AGENTDB_HNSW_EF=100
# 学习插件
AGENTDB_LEARNING=true
# 推理代理
AGENTDB_REASONING=true
# QUIC 同步
AGENTDB_QUIC_SYNC=true
AGENTDB_QUIC_PORT=4433
AGENTDB_QUIC_PEERS=host1:4433,host2:4433
# 检查防火墙是否允许 UDP 端口 4433
sudo ufw allow 4433$udp
# 验证对等节点可达
ping host1
# 检查 QUIC 日志
DEBUG=agentdb:quic node server.js
// 放宽过滤器
const result = await adapter.retrieveWithReasoning(queryEmbedding, {
k: 100, // 增加 k
filters: {
// 移除或放宽过滤器
},
});
// 禁用自动优化
const result = await adapter.retrieveWithReasoning(queryEmbedding, {
optimizeMemory: false, // 禁用自动整合
k: 10,
});
类别:高级 / 分布式系统 难度:高级 预计时间:45-60 分钟
每周安装次数
–
代码仓库
GitHub 星标数
25.1K
首次出现
–
安全审计
Covers advanced AgentDB capabilities for distributed systems, multi-database coordination, custom distance metrics, hybrid search (vector + metadata), QUIC synchronization, and production deployment patterns. Enables building sophisticated AI systems with sub-millisecond cross-node communication and advanced search capabilities.
Performance : <1ms QUIC sync, hybrid search with filters, custom distance metrics.
QUIC (Quick UDP Internet Connections) enables sub-millisecond latency synchronization between AgentDB instances across network boundaries with automatic retry, multiplexing, and encryption.
Benefits :
import { createAgentDBAdapter } from 'agentic-flow$reasoningbank';
// Initialize with QUIC synchronization
const adapter = await createAgentDBAdapter({
dbPath: '.agentdb$distributed.db',
enableQUICSync: true,
syncPort: 4433,
syncPeers: [
'192.168.1.10:4433',
'192.168.1.11:4433',
'192.168.1.12:4433',
],
});
// Patterns automatically sync across all peers
await adapter.insertPattern({
// ... pattern data
});
// Available on all peers within ~1ms
const adapter = await createAgentDBAdapter({
enableQUICSync: true,
syncPort: 4433, // QUIC server port
syncPeers: ['host1:4433'], // Peer addresses
syncInterval: 1000, // Sync interval (ms)
syncBatchSize: 100, // Patterns per batch
maxRetries: 3, // Retry failed syncs
compression: true, // Enable compression
});
# Node 1 (192.168.1.10)
AGENTDB_QUIC_SYNC=true \
AGENTDB_QUIC_PORT=4433 \
AGENTDB_QUIC_PEERS=192.168.1.11:4433,192.168.1.12:4433 \
node server.js
# Node 2 (192.168.1.11)
AGENTDB_QUIC_SYNC=true \
AGENTDB_QUIC_PORT=4433 \
AGENTDB_QUIC_PEERS=192.168.1.10:4433,192.168.1.12:4433 \
node server.js
# Node 3 (192.168.1.12)
AGENTDB_QUIC_SYNC=true \
AGENTDB_QUIC_PORT=4433 \
AGENTDB_QUIC_PEERS=192.168.1.10:4433,192.168.1.11:4433 \
node server.js
Best for normalized vectors, semantic similarity:
# CLI
npx agentdb@latest query .$vectors.db "[0.1,0.2,...]" -m cosine
# API
const result = await adapter.retrieveWithReasoning(queryEmbedding, {
metric: 'cosine',
k: 10,
});
Use Cases :
Formula : cos(θ) = (A · B) / (||A|| × ||B||) Range : [-1, 1] (1 = identical, -1 = opposite)
Best for spatial data, geometric similarity:
# CLI
npx agentdb@latest query .$vectors.db "[0.1,0.2,...]" -m euclidean
# API
const result = await adapter.retrieveWithReasoning(queryEmbedding, {
metric: 'euclidean',
k: 10,
});
Use Cases :
Formula : d = √(Σ(ai - bi)²) Range : [0, ∞] (0 = identical, ∞ = very different)
Best for pre-normalized vectors, fast computation:
# CLI
npx agentdb@latest query .$vectors.db "[0.1,0.2,...]" -m dot
# API
const result = await adapter.retrieveWithReasoning(queryEmbedding, {
metric: 'dot',
k: 10,
});
Use Cases :
Formula : dot = Σ(ai × bi) Range : [-∞, ∞] (higher = more similar)
// Implement custom distance function
function customDistance(vec1: number[], vec2: number[]): number {
// Weighted Euclidean distance
const weights = [1.0, 2.0, 1.5, ...];
let sum = 0;
for (let i = 0; i < vec1.length; i++) {
sum += weights[i] * Math.pow(vec1[i] - vec2[i], 2);
}
return Math.sqrt(sum);
}
// Use in search (requires custom implementation)
Combine vector similarity with metadata filtering:
// Store documents with metadata
await adapter.insertPattern({
id: '',
type: 'document',
domain: 'research-papers',
pattern_data: JSON.stringify({
embedding: documentEmbedding,
text: documentText,
metadata: {
author: 'Jane Smith',
year: 2025,
category: 'machine-learning',
citations: 150,
}
}),
confidence: 1.0,
usage_count: 0,
success_count: 0,
created_at: Date.now(),
last_used: Date.now(),
});
// Hybrid search: vector similarity + metadata filters
const result = await adapter.retrieveWithReasoning(queryEmbedding, {
domain: 'research-papers',
k: 20,
filters: {
year: { $gte: 2023 }, // Published 2023 or later
category: 'machine-learning', // ML papers only
citations: { $gte: 50 }, // Highly cited
},
});
// Complex metadata queries
const result = await adapter.retrieveWithReasoning(queryEmbedding, {
domain: 'products',
k: 50,
filters: {
price: { $gte: 10, $lte: 100 }, // Price range
category: { $in: ['electronics', 'gadgets'] }, // Multiple categories
rating: { $gte: 4.0 }, // High rated
inStock: true, // Available
tags: { $contains: 'wireless' }, // Has tag
},
});
Combine vector and metadata scores:
const result = await adapter.retrieveWithReasoning(queryEmbedding, {
domain: 'content',
k: 20,
hybridWeights: {
vectorSimilarity: 0.7, // 70% weight on semantic similarity
metadataScore: 0.3, // 30% weight on metadata match
},
filters: {
category: 'technology',
recency: { $gte: Date.now() - 30 * 24 * 3600000 }, // Last 30 days
},
});
// Separate databases for different domains
const knowledgeDB = await createAgentDBAdapter({
dbPath: '.agentdb$knowledge.db',
});
const conversationDB = await createAgentDBAdapter({
dbPath: '.agentdb$conversations.db',
});
const codeDB = await createAgentDBAdapter({
dbPath: '.agentdb$code.db',
});
// Use appropriate database for each task
await knowledgeDB.insertPattern({ /* knowledge */ });
await conversationDB.insertPattern({ /* conversation */ });
await codeDB.insertPattern({ /* code */ });
// Shard by domain for horizontal scaling
const shards = {
'domain-a': await createAgentDBAdapter({ dbPath: '.agentdb$shard-a.db' }),
'domain-b': await createAgentDBAdapter({ dbPath: '.agentdb$shard-b.db' }),
'domain-c': await createAgentDBAdapter({ dbPath: '.agentdb$shard-c.db' }),
};
// Route queries to appropriate shard
function getDBForDomain(domain: string) {
const shardKey = domain.split('-')[0]; // Extract shard key
return shards[shardKey] || shards['domain-a'];
}
// Insert to correct shard
const db = getDBForDomain('domain-a-task');
await db.insertPattern({ /* ... */ });
Retrieve diverse results to avoid redundancy:
// Without MMR: Similar results may be redundant
const standardResults = await adapter.retrieveWithReasoning(queryEmbedding, {
k: 10,
useMMR: false,
});
// With MMR: Diverse, non-redundant results
const diverseResults = await adapter.retrieveWithReasoning(queryEmbedding, {
k: 10,
useMMR: true,
mmrLambda: 0.5, // Balance relevance (0) vs diversity (1)
});
MMR Parameters :
mmrLambda = 0: Maximum relevance (may be redundant)mmrLambda = 0.5: Balanced (default)mmrLambda = 1: Maximum diversity (may be less relevant)Use Cases :
Generate rich context from multiple memories:
const result = await adapter.retrieveWithReasoning(queryEmbedding, {
domain: 'problem-solving',
k: 10,
synthesizeContext: true, // Enable context synthesis
});
// ContextSynthesizer creates coherent narrative
console.log('Synthesized Context:', result.context);
// "Based on 10 similar problem-solving attempts, the most effective
// approach involves: 1) analyzing root cause, 2) brainstorming solutions,
// 3) evaluating trade-offs, 4) implementing incrementally. Success rate: 85%"
console.log('Patterns:', result.patterns);
// Extracted common patterns across memories
// Singleton pattern for shared adapter
class AgentDBPool {
private static instance: AgentDBAdapter;
static async getInstance() {
if (!this.instance) {
this.instance = await createAgentDBAdapter({
dbPath: '.agentdb$production.db',
quantizationType: 'scalar',
cacheSize: 2000,
});
}
return this.instance;
}
}
// Use in application
const db = await AgentDBPool.getInstance();
const results = await db.retrieveWithReasoning(queryEmbedding, { k: 10 });
async function safeRetrieve(queryEmbedding: number[], options: any) {
try {
const result = await adapter.retrieveWithReasoning(queryEmbedding, options);
return result;
} catch (error) {
if (error.code === 'DIMENSION_MISMATCH') {
console.error('Query embedding dimension mismatch');
// Handle dimension error
} else if (error.code === 'DATABASE_LOCKED') {
// Retry with exponential backoff
await new Promise(resolve => setTimeout(resolve, 100));
return safeRetrieve(queryEmbedding, options);
}
throw error;
}
}
// Performance monitoring
const startTime = Date.now();
const result = await adapter.retrieveWithReasoning(queryEmbedding, { k: 10 });
const latency = Date.now() - startTime;
if (latency > 100) {
console.warn('Slow query detected:', latency, 'ms');
}
// Log statistics
const stats = await adapter.getStats();
console.log('Database Stats:', {
totalPatterns: stats.totalPatterns,
dbSize: stats.dbSize,
cacheHitRate: stats.cacheHitRate,
avgSearchLatency: stats.avgSearchLatency,
});
# Export with compression
npx agentdb@latest export .$vectors.db .$backup.json.gz --compress
# Import from backup
npx agentdb@latest import .$backup.json.gz --decompress
# Merge databases
npx agentdb@latest merge .$db1.sqlite .$db2.sqlite .$merged.sqlite
# Vacuum database (reclaim space)
sqlite3 .agentdb$vectors.db "VACUUM;"
# Analyze for query optimization
sqlite3 .agentdb$vectors.db "ANALYZE;"
# Rebuild indices
npx agentdb@latest reindex .$vectors.db
# AgentDB configuration
AGENTDB_PATH=.agentdb$reasoningbank.db
AGENTDB_ENABLED=true
# Performance tuning
AGENTDB_QUANTIZATION=binary # binary|scalar|product|none
AGENTDB_CACHE_SIZE=2000
AGENTDB_HNSW_M=16
AGENTDB_HNSW_EF=100
# Learning plugins
AGENTDB_LEARNING=true
# Reasoning agents
AGENTDB_REASONING=true
# QUIC synchronization
AGENTDB_QUIC_SYNC=true
AGENTDB_QUIC_PORT=4433
AGENTDB_QUIC_PEERS=host1:4433,host2:4433
# Check firewall allows UDP port 4433
sudo ufw allow 4433$udp
# Verify peers are reachable
ping host1
# Check QUIC logs
DEBUG=agentdb:quic node server.js
// Relax filters
const result = await adapter.retrieveWithReasoning(queryEmbedding, {
k: 100, // Increase k
filters: {
// Remove or relax filters
},
});
// Disable automatic optimization
const result = await adapter.retrieveWithReasoning(queryEmbedding, {
optimizeMemory: false, // Disable auto-consolidation
k: 10,
});
Category : Advanced / Distributed Systems Difficulty : Advanced Estimated Time : 45-60 minutes
Weekly Installs
–
Repository
GitHub Stars
25.1K
First Seen
–
Security Audits
超能力技能使用指南:AI助手技能调用优先级与工作流程详解
45,100 周安装