MIT License
29
最近更新:12个月前

好的,请提供需要翻译的英文技术文档内容,我将严格按照规则返回中文翻译。

tavily-search MCP 服务器

一个 MCP 服务器项目

tavily-search MCP server

组件

该服务器使用 Tavily API 根据指定查询执行搜索。

  • 搜索结果以文本格式返回。
  • 搜索结果包含 AI 响应、URI 和搜索结果的标题。

工具

该服务器实现了以下工具:

  • search:根据指定查询执行搜索
    • 必选参数:"query"
    • 可选参数:"search_depth"(basic 或 advanced)

通过 Smithery 安装

要通过 Smithery 自动为 Claude Desktop 安装 Tavily Search:

bash 复制代码
npx -y @smithery/cli install tavily-search --client claude

安装

  1. 下载代码库。
bash 复制代码
git clone https://github.com/Tomatio13/mcp-server-tavily.git
  1. 打开 Claude Desktop 配置文件。
复制代码
在 MacOS 上:`~/Library/Application\ Support/Claude/claude_desktop_config.json`
在 Windows 上:`C:\Users\[username]\AppData\Roaming\Claude\claude_desktop_config.json`
  1. 按如下方式编辑配置文件:
yaml 复制代码
"mcpServers": {
  "tavily-search": {
    "command": "uv",
    "args": [
      "--directory",
      "C:\\your_path\\mcp-server-tavily",
      "run",
      "tavily-search"
    ],
    "env": {
      "TAVILY_API_KEY": "YOUR_TAVILY_API_KEY",
      "PYTHONIOENCODING": "utf-8"
    }
  }
}
  1. 重启 Claude Desktop。

使用

在 Claude Desktop 中,当您询问"请搜索某些内容"时,您将收到搜索结果。

搜索示例:

复制代码
请详细搜索今天镰仓的活动

响应示例:

复制代码
根据搜索结果,12月1日今天开始有以下活动:
"镰仓宣传照片大赛2025"
期间:2024年12月1日 - 2025年1月31日
面向热爱镰仓人士的照片比赛
今天起开始接受申请
另外,相关即将举办的活动:
12月7日将在西武Press Inn镰仓大船站东出口休息室举办12位镰仓艺术家的展览。

日志存储位置

日志存储在以下位置:

Windows 系统:

复制代码
C:\Users\[username]\AppData\Roaming\Claude\logs\mcp-server-tavily-search

使用 Cursor 执行

  1. 创建一个 shell 脚本(如 script.sh),内容如下:
bash 复制代码
#!/bin/bash
TARGET_DIR=/path/to/mcp-server-tavily
cd "${TARGET_DIR}"
export TAVILY_API_KEY="your-api-key"
export PYTHONIOENCODING=utf-8
uv --directory $PWD run tavily-search
  1. 按如下方式配置 Cursor 的 MCP Server 设置:
复制代码
名称:tavily-search
类型:command
命令:/path/to/your/script.sh
  1. 保存设置。

  2. 设置保存后,您可以要求 Cursor 的 Composer-Agent "搜索某些内容",它将返回搜索结果。

使用 Docker Compose 在本地环境运行

目的

对于无法使用 Claude Desktop 的 Windows/MacOS 以外的操作系统,
本节介绍如何使用 Docker compose 在本地环境中设置和运行 MCP 服务器和客户端。

步骤

  1. 安装 Docker。
  2. 下载代码库。
bash 复制代码
git clone https://github.com/Tomatio13/mcp-server-tavily.git
  1. 运行 Docker compose。
bash 复制代码
docker compose up -d
  1. 执行客户端。
bash 复制代码
docker exec mcp_server uv --directory /usr/src/app/mcp-server-tavily/src run client.py
  1. 执行结果
  2. 如下所示搜索可用工具后,将向 Tavily 发出查询并返回响应:
bash 复制代码
2024-12-01 11:21:56,930 - tavily-search-server - INFO - 启动 Tavily 搜索服务器
2024-12-01 11:21:56,932 - tavily-search-server - INFO - 服务器已初始化,开始主循环
2024-12-01 11:21:56,936 - mcp.server - INFO - 处理 ListToolsRequest 类型的请求
2024-12-01 11:21:56,936 - tavily-search-server - INFO - 列出可用工具
可用工具: nextCursor=None tools=[Tool(name='search', description='使用 Tavily API 搜索网络', inputSchema={'type': 'object', 'properties': {'query': {'type': 'string', 'description': '搜索查询'}, 'search_depth': {'type': 'string', 'description': '搜索深度(basic 或 advanced)', 'enum': ['basic', 'advanced']}}, 'required': ['query']})]
2024-12-01 11:21:56,937 - mcp.server - INFO - 处理 CallToolRequest 类型的请求
2024-12-01 11:21:56,937 - tavily-search-server - INFO - TOOL_CALL_DEBUG: 工具调用 - 名称: search, 参数: {'query': '请告诉我今天东京塔的活动'}
2024-12-01 11:21:56,937 - tavily-search-server - INFO - 执行搜索,查询: '请告诉我今天东京塔的活动'
2024-12-01 11:22:00,243 - httpx - INFO - HTTP 请求: POST https://api.tavily.com/search "HTTP/1.1 200 OK"
2024-12-01 11:22:00,243 - tavily-search-server - INFO - 搜索成功 - 生成答案
2024-12-01 11:22:00,243 - tavily-search-server - INFO - 搜索成功 - 结果可用
工具执行结果: content=[TextContent(type='text', text='AI 回答:\n今天东京塔的活动如下:\n1. Candlelight: Ed Sheeran 和 Coldplay 的热门歌曲串烧 - 12月01日\n2. teamLab Planets TOKYO - 12月01日至1月21日\n\n可能还有其他活动,请在官方网站等渠道确认最新信息。\n\n\n\n搜索结果:\n\n1. 东京塔 (东京): 当前活动与门票 | Fever\nURL: https://feverup.com/ja/tokyo/venue/tokyo-tower\n摘要: 未找到摘要\n\n\n2. 东京塔(东京都)设施内举办的活动一览|Walkerplus\nURL: https://www.walkerplus.com/spot/ar0313s03867/e_list.html\n摘要: 未找到摘要\n\n\n3. 东京塔 - Tokyo Tower\nURL: https://www.tokyotower.co.jp/event/\n摘要: 未找到摘要\n')] isError=False