Skip to content

搜索服务 (Search Service)

此插件为 ChatLuna 提供多源的聚合搜索工具,并且基于 Puppeteer 提供网页浏览能力工具。

配置

  • 前往插件市场,安装 puppeteer 插件。(大部分情况下 Koishi 已经安装了此插件,直接启用就好)
  • 前往插件市场搜索 chatluna-search-service 并安装。

alt text

完成后则可以进行搜索引擎配置。

搜索引擎配置

打开 chatluna-search-service 插件的配置页面。可以看到我们能选择多种搜索引擎进行多源聚合搜索。

alt text

但大部分搜索引擎都需要额外的配置相关参数,才能正常使用。

bing-web、google-web、duckduckgo-lite

只需确认 puppeteer 插件启用,并且你的网络环境可以正常访问 Bing、Google 和 DuckDuckGo 即可。

serper

前往 Serper 注册账号并获取 API Key。 填写相关参数到 Serper 设置 配置项中即可。

tavily

前往 Tavily 注册账号并获取 API Key。 填写相关参数到 Tavily 设置 配置项中即可。

bing-api

前往 Bing 获取 API Key。 填写相关参数到 Bing API 设置 配置项中即可。

searxng

前往 searxng 获取可用的公共实例。 填写相关地址到 searxng 设置 配置项中即可。

wikipedia

你可以寻找支持 mediawiki 的维基网站,填入 API 地址到 Wikipedia 设置 配置项中即可。

我们默认提供了 https://en.wikipedia.org/w/api.phphttps://mzh.moegirl.org.cn/api.php 两个维基网站。

使用

配置完成后直接启用插件即可。此时已经可以正常使用 browsing 聊天模式和相关工具了。

配置项

此处列举了 chatluna-search-service 插件的配置项。

搜索服务配置

searchEngine

  • 类型: string[]
  • 默认值: []

启用的搜索引擎列表。可选值包括: bing-webgoogle-webduckduckgo-liteserpertavilybing-apisearxngwikipedia

此配置项支持多选,意味着你可以同时启用多个搜索引擎进行聚合搜索。

topK

  • 类型: number
  • 默认值: 5
  • 范围: 2-20

参考结果数量。此值决定每次搜索返回的结果数量。 此值不要设置过大或者过小,都会影响到模型输出的质量。 我们推荐配置在 3-6 之间。

enhancedSummary

  • 类型: boolean
  • 默认值: false

是否启用增强摘要功能。启用后会对搜索结果的网页进行访问,以求获取更详细的内容。

puppeteerTimeout

  • 类型: number
  • 默认值: 60000

Puppeteer 操作超时时间(毫秒)。

puppeteerIdleTimeout

  • 类型: number
  • 默认值: 300000

Puppeteer 空闲超时时间(毫秒)。

summaryModel

  • 类型: string
  • 默认值: gpt-3.5-turbo

处理搜索结果的模型。在启用了增强摘要功能后,会使用此模型总结和分析搜索获取的内容。

summaryType

  • 类型:speed | balanced | quality
  • 默认值:balanced

搜索结果摘要的生成策略,提供几种模式:

  • speed: 优先考虑生成速度,直接返回搜索结果。
  • balanced: 阅读网页,切块返回,提供一定的质量。
  • quality: 使用 LLM 阅读和总结网页,高质量的结果。

multiSourceMode

  • 类型: average | total
  • 默认值: total

多源搜索结果的聚合策略,提供两种模式:

  • average: 对每个搜索取前 total / K 个结果,聚合后对每个结果进行相似度检测,返回最高的 K 个结果。
  • total: 对每个搜索源取前 K 个结果,聚合后对每个结果进行相似度检测,返回最高的 K 个结果。

searchThreshold

  • 类型: number
  • 默认值: 0.25

搜索结果的相似度阈值。使用向量相似度检测,过滤掉相似度低于此阈值的结果。

Serper 设置

serperApiKey

  • 类型: string
  • 默认值: ``

Serper API 密钥。

serperCountry

  • 类型: string
  • 默认值: cn

Serper 搜索地区。

serperLocation

  • 类型: string
  • 默认值: zh-cn

Serper 搜索语言。

serperSearchResults

  • 类型: number
  • 默认值: 10

Serper 搜索结果数量。

Bing API 设置

bingSearchApiKey

  • 类型: string
  • 默认值: ``

Bing API 密钥。

bingSearchLocation

  • 类型: string
  • 默认值: zh-CN

Bing API 搜索地区。

azureLocation

  • 类型: string
  • 默认值: global

Azure API 服务地区。

Tavily 设置

tavilyApiKey

  • 类型: string
  • 默认值: ``

Tavily API 密钥。

Wikipedia 设置

wikipediaBaseURL

  • 类型: string[]
  • 默认值: ["https://en.wikipedia.org/w/api.php", "https://mzh.moegirl.org.cn/api.php"]

Wikipedia API 基础 URL。可以添加多个维基网站的 API 地址。

maxWikipediaDocContentLength

  • 类型: number
  • 默认值: 5000

Wikipedia 文档内容的最大长度。超出此长度的内容会被截断。

SearxNG 设置

searxngBaseURL

  • 类型: string
  • 默认值: https://paulgo.io

SearxNG API 基础 URL。可以填写任意可用的 SearxNG 实例地址。

进阶设置

[! WARNING] 提示 如果你对 Prompt 工程不够熟悉,不要随意修改以下配置。否则会直接影响模型生成的质量。

searchPrompt

  • 类型: string
  • 默认值: ....

搜索任务的 Prompt。用于模型理解搜索任务,并基于搜索结果生成符合人类偏好的回答。

newQuestionPrompt

  • 类型: string
  • 默认值: ....

新问题 Prompt。用于模型理解用户的输入,并基于当前上下文生成新的回答。

页面历史

在 CC-BY-SA-4.0 许可下发布