5.8 KiB
		
	
	
	
	
	
			
		
		
	
	
			5.8 KiB
		
	
	
	
	
	
🚀 稷下学宫负载均衡系统 - 快速上手指南
📋 前置条件
- 
RapidAPI账户: 确保已订阅以下API服务 - Alpha Vantage
- Yahoo Finance 15
- Webull
- Seeking Alpha
 
- 
环境配置: 已配置Doppler环境变量管理 doppler secrets | grep RAPIDAPI_KEY
⚡ 5分钟快速体验
1. 运行完整演示
cd /home/ben/liurenchaxin
doppler run python demo_jixia_load_balancing.py
2. 查看演示结果
# 查看生成的结果文件
ls demo_results_*.json
# 查看AAPL的详细结果
cat demo_results_aapl.json | jq .
🎯 核心功能演示
单个仙人数据获取
from src.jixia.engines.jixia_load_balancer import JixiaLoadBalancer
# 初始化
load_balancer = JixiaLoadBalancer(rapidapi_key)
# 吕洞宾获取苹果股票数据
result = load_balancer.get_data_for_immortal('吕洞宾', 'stock_quote', 'AAPL')
print(f"价格: ${result.data['price']}, 来源: {result.api_used}")
八仙论道完整演示
# 进行八仙论道
results = load_balancer.conduct_immortal_debate('TSLA')
# 查看负载分布
distribution = load_balancer.get_load_distribution()
for api, stats in distribution.items():
    print(f"{api}: {stats['calls']}次调用 ({stats['percentage']:.1f}%)")
📊 预期输出示例
🏛️ 稷下学宫八仙论道开始 - 主题: AAPL
============================================================
🎭 吕洞宾 正在获取 stock_quote 数据...
   ✅ 成功从 alpha_vantage 获取数据 (响应时间: 1.33s)
   💰 吕洞宾: $202.38 (-2.5004%) via alpha_vantage
🎭 何仙姑 正在获取 stock_quote 数据...
   ✅ 成功从 yahoo_finance_15 获取数据 (响应时间: 1.87s)
   💰 何仙姑: $N/A (N/A) via yahoo_finance_15
📊 负载分布统计:
   alpha_vantage: 3 次调用 (37.5%) - 健康
   yahoo_finance_15: 2 次调用 (25.0%) - 健康
   webull: 3 次调用 (37.5%) - 健康
🔧 自定义配置
修改仙人API偏好
编辑 /home/ben/liurenchaxin/src/jixia/config/immortal_api_config.json:
{
  "immortals": {
    "吕洞宾": {
      "preferred_apis": {
        "stock_quote": "webull",  // 改为使用Webull
        "company_overview": "alpha_vantage"
      }
    }
  }
}
调整缓存策略
# 修改缓存TTL
load_balancer.cache_ttl = 600  # 10分钟缓存
# 清空缓存
load_balancer.cache.clear()
🚨 故障排除
常见问题
- 
API密钥错误 ❌ 错误: 请设置RAPIDAPI_KEY环境变量解决: 确保Doppler配置正确 doppler secrets set RAPIDAPI_KEY="your_key_here"
- 
API调用失败 ⚠️ alpha_vantage 不可用,尝试备用API...解决: 系统会自动故障转移,无需干预 
- 
数据格式异常 💰 价格: $N/A解决: 某些API返回格式不同,系统会标准化处理 
调试模式
# 启用详细日志
import logging
logging.basicConfig(level=logging.DEBUG)
# 查看API健康状态
for api, status in load_balancer.health_checker.health_status.items():
    print(f"{api}: {'健康' if status['healthy'] else '异常'}")
📈 性能优化建议
1. 缓存优化
# 针对不同数据类型设置不同缓存时间
cache_strategies = {
    'stock_quote': 60,      # 1分钟
    'company_overview': 3600, # 1小时
    'market_news': 1800     # 30分钟
}
2. 并发控制
# 控制并发请求数量
import time
for immortal in immortals:
    result = load_balancer.get_data_for_immortal(immortal, 'stock_quote', symbol)
    time.sleep(0.2)  # 避免过快请求
3. 批量处理
# 批量获取多个股票数据
symbols = ['AAPL', 'TSLA', 'MSFT', 'GOOGL']
results = {}
for symbol in symbols:
    results[symbol] = load_balancer.conduct_immortal_debate(symbol)
🎯 最佳实践
1. 监控API使用情况
# 定期检查负载分布
distribution = load_balancer.get_load_distribution()
print(f"总调用次数: {sum(stats['calls'] for stats in distribution.values())}")
2. 合理使用缓存
# 对于实时性要求不高的数据,优先使用缓存
result = load_balancer.get_data_for_immortal('韩湘子', 'company_overview', 'AAPL')
if result.cached:
    print("使用缓存数据,节省API调用")
3. 错误处理
result = load_balancer.get_data_for_immortal('吕洞宾', 'stock_quote', 'AAPL')
if not result.success:
    print(f"获取数据失败: {result.error}")
    # 实施降级策略
else:
    # 正常处理数据
    process_stock_data(result.data)
📚 进阶使用
自定义数据处理器
class CustomDataNormalizer(DataNormalizer):
    def normalize_stock_quote(self, raw_data, api_source):
        # 自定义数据标准化逻辑
        normalized = super().normalize_stock_quote(raw_data, api_source)
        # 添加自定义字段
        normalized['custom_score'] = self.calculate_score(normalized)
        return normalized
# 使用自定义处理器
load_balancer.data_normalizer = CustomDataNormalizer()
自定义健康检查
class CustomHealthChecker(APIHealthChecker):
    def _perform_health_check(self, api_name):
        # 自定义健康检查逻辑
        # 例如:检查API响应时间、错误率等
        pass
load_balancer.health_checker = CustomHealthChecker()
🎉 完成!
现在您已经掌握了稷下学宫负载均衡系统的基本使用方法。
下一步
- 📖 阅读完整文档: README_jixia_load_balancing.md
- 🔧 查看配置文件: src/jixia/config/immortal_api_config.json
- 💻 研究核心代码: src/jixia/engines/jixia_load_balancer.py
- 🚀 开始构建您的投资分析系统!
🏛️ 稷下学宫 - 智慧投资,从负载均衡开始