首页
/ VibeMeter项目深度解析:Claude使用追踪功能的技术实现

VibeMeter项目深度解析:Claude使用追踪功能的技术实现

2025-06-19 20:27:26作者:咎岭娴Homer

项目背景与核心目标

VibeMeter是一款macOS应用程序,旨在帮助用户追踪各类AI服务的用量情况。本次技术升级的重点是增加对Anthropic公司Claude服务的用量追踪功能。与传统的API调用方式不同,这一功能将通过解析Claude客户端生成的本地日志文件来实现用量统计。

技术架构设计

1. 整体架构

Claude用量追踪功能采用模块化设计,主要分为四个核心模块:

  1. 日志解析模块:负责读取和解析Claude生成的本地日志文件
  2. 令牌计算模块:准确计算输入/输出令牌数量
  3. 用户界面模块:展示用量数据和配置选项
  4. 数据持久化模块:安全存储用户授权和配置信息

2. 关键技术选型

  • 日志解析:直接读取~/.claude/projects/目录下的JSONL格式日志文件
  • 令牌计算:集成Swift版tiktoken库,支持o200k_base编码
  • 安全访问:使用macOS沙盒机制和书签数据实现持久化文件访问权限
  • 无登录认证:通过用户手动选择订阅类型简化认证流程

核心功能实现细节

1. 令牌计算实现

令牌计算是准确估算成本的关键。我们采用以下技术方案:

// 令牌计算核心代码示例
private lazy var tiktoken: Tiktoken? = {
    try? Tiktoken(encoding: .o200k_base)
}()

实现要点:

  1. 集成Swift版tiktoken
  2. 添加o200k_base编码支持
  3. 确保词汇表文件正确打包到应用中

2. 日志解析与安全访问

日志解析面临的主要挑战是安全访问用户目录。我们采用macOS的安全范围书签机制:

func requestLogAccess() async -> Bool {
    let openPanel = NSOpenPanel()
    openPanel.message = "请选择您的主目录以授权访问~/.claude文件夹"
    // 配置面板参数...
    
    let response = await openPanel.begin()
    guard response == .OK, let url = openPanel.url else { return false }
    
    do {
        let bookmark = try url.bookmarkData(options: .withSecurityScope, 
                                          includingResourceValuesForKeys: nil, 
                                          relativeTo: nil)
        saveBookmark(data: bookmark)
        return true
    } catch {
        logger.error("创建书签失败: \(error.localizedDescription)")
        return false
    }
}

关键实现细节:

  1. 使用NSOpenPanel获取用户授权
  2. 生成安全范围书签数据
  3. 持久化存储书签以便后续访问
  4. 正确处理书签过期情况

3. 用量数据模型

我们设计了专门的数据结构来存储和表示Claude用量信息:

struct ClaudeLogEntry: Decodable, Identifiable {
    var id = UUID()
    let timestamp: Date
    let model: String?
    let inputTokens: Int
    let outputTokens: Int
    // 解码实现...
}

struct FiveHourWindow {
    let used: Double
    let total: Double
    let resetDate: Date
    
    var remaining: Double { total - used }
    var percentageUsed: Double { total > 0 ? (used / total) : 0 }
}

模型特点:

  1. 支持精确的时间戳解析
  2. 区分输入/输出令牌
  3. 专门处理Claude Pro的5小时窗口限制

用户界面设计

1. 菜单栏显示选项

用户可以选择两种显示模式:

  • 总花费模式:显示当月累计花费
  • 配额模式:显示5小时窗口剩余配额
public enum GaugeRepresentation: String, CaseIterable {
    case totalSpending
    case claudeQuota
    
    public var displayName: String {
        switch self {
        case .totalSpending: "月度总花费"
        case .claudeQuota: "5小时配额"
        }
    }
}

2. 详细用量视图

提供按日分组的用量明细:

  • 每日令牌使用量
  • 成本估算
  • 模型类型信息

性能与安全考量

  1. 性能优化

    • 异步日志解析避免阻塞主线程
    • 增量式日志读取减少内存占用
    • 合理缓存计算结果
  2. 安全保障

    • 严格的沙盒权限控制
    • 敏感操作日志记录
    • 书签数据加密存储

开发路线图

项目采用分阶段实施策略:

  1. 基础阶段:完成核心日志解析和令牌计算功能
  2. 集成阶段:将Claude提供程序集成到现有架构
  3. 界面阶段:开发用户配置界面
  4. 优化阶段:完善菜单栏和弹出窗口UI

技术难点与解决方案

  1. 日期解析问题

    • 实现健壮的ISO8601日期解析器
    • 支持带分数秒的时间戳格式
  2. 文件访问权限

    • 使用安全范围书签实现持久化访问
    • 正确处理权限失效情况
  3. 成本计算准确性

    • 集成官方定价模型
    • 支持不同订阅类型的计算规则

总结

VibeMeter的Claude用量追踪功能展示了如何通过创新的本地日志解析方式实现AI服务用量监控。该方案不仅提供了准确的用量数据,还通过精心设计的用户界面和灵活的配置选项,为用户带来了便捷的使用体验。技术实现上充分考虑了macOS平台的安全特性和性能要求,是本地化AI用量监控的一个优秀实践案例。

登录后查看全文
热门项目推荐