Skip to content

Latest commit

 

History

History
426 lines (328 loc) · 24.6 KB

README_zh.md

File metadata and controls

426 lines (328 loc) · 24.6 KB
Logo

Question and Answer based on Anything

English | 简体中文

         

              

目 录

🚀 重要更新

重要的事情说三遍!

商务问题联系方式:

010-82558901

什么是QAnything?

QAnything (Question and Answer based on Anything) 是致力于支持任意格式文件或数据库的本地知识库问答系统,可断网安装使用。

您的任何格式的本地文件都可以往里扔,即可获得准确、快速、靠谱的问答体验。

目前已支持格式: PDF(pdf)Word(docx)PPT(pptx)XLS(xlsx)Markdown(md)电子邮件(eml)TXT(txt)图片(jpg,jpeg,png)CSV(csv)网页链接(html),更多格式,敬请期待...

特点

  • 数据安全,支持全程拔网线安装使用。
  • 支持跨语种问答,中英文问答随意切换,无所谓文件是什么语种。
  • 支持海量数据问答,两阶段向量排序,解决了大规模数据检索退化的问题,数据越多,效果越好。
  • 高性能生产级系统,可直接部署企业应用。
  • 易用性,无需繁琐的配置,一键安装部署,拿来就用。
  • 支持选择多知识库问答。

架构

qanything_system

为什么是两阶段检索?

知识库数据量大的场景下两阶段优势非常明显,如果只用一阶段embedding检索,随着数据量增大会出现检索退化的问题,如下图中绿线所示,二阶段rerank重排后能实现准确率稳定增长,即数据越多,效果越好

two stage retrievaal

QAnything使用的检索组件BCEmbedding有非常强悍的双语和跨语种能力,能消除语义检索里面的中英语言之间的差异,从而实现:

一阶段检索(embedding)

模型名称 Retrieval STS PairClassification Classification Reranking Clustering 平均
bge-base-en-v1.5 37.14 55.06 75.45 59.73 43.05 37.74 47.20
bge-base-zh-v1.5 47.60 63.72 77.40 63.38 54.85 32.56 53.60
bge-large-en-v1.5 37.15 54.09 75.00 59.24 42.68 37.32 46.82
bge-large-zh-v1.5 47.54 64.73 79.14 64.19 55.88 33.26 54.21
jina-embeddings-v2-base-en 31.58 54.28 74.84 58.42 41.16 34.67 44.29
m3e-base 46.29 63.93 71.84 64.08 52.38 37.84 53.54
m3e-large 34.85 59.74 67.69 60.07 48.99 31.62 46.78
bce-embedding-base_v1 57.60 65.73 74.96 69.00 57.29 38.95 59.43

二阶段检索(rerank)

模型名称 Reranking 平均
bge-reranker-base 57.78 57.78
bge-reranker-large 59.69 59.69
bce-reranker-base_v1 60.06 60.06

基于LlamaIndex的RAG评测(embedding and rerank)

NOTE:

  • 在WithoutReranker列中,我们的bce-embedding-base_v1模型优于所有其他embedding模型。
  • 在固定embedding模型的情况下,我们的bce-reranker-base_v1模型达到了最佳表现。
  • bce-embedding-base_v1和bce-reranker-base_v1的组合是SOTA。
  • 如果想单独使用embedding和rerank请参阅:BCEmbedding

LLM

开源版本QAnything的大模型基于通义千问,并在大量专业问答数据集上进行微调;在千问的基础上大大加强了问答的能力。 如果需要商用请遵循千问的license,具体请参阅:通义千问

🚀 最近更新

  • 2024-08-22: 支持快速开始、前端配置参数、在线预览和编辑chunk块,优化项目架构和启动方式。 - 详见👉 v2.0.0
  • 2024-05-20: 支持与OpenAI API兼容的其他LLM服务,并提供优化后的PDF解析器。 - 详见👉 v1.4.1
  • 2024-04-26: 支持联网检索、FAQ、自定义BOT、文件溯源等。 - 详见👉 v1.4.0
  • 2024-04-03: 支持在纯Python环境中安装;支持混合检索。 - 详见👉 v1.3.0
  • 2024-01-29: 支持自定义大模型,包括OpenAI API和其他开源大模型,GPU需求最低降至GTX 1050Ti,极大提升部署,调试等方面的用户体验 - 详见👉 v1.2.0
  • 2024-01-23: 默认开启rerank,修复在windows上启动时存在的各类问题 - 详见👉 v1.1.1
  • 2024-01-18: 支持一键启动,支持windows部署,提升pdf,xlsx,html解析效果 - 详见👉 v1.1.0

开始之前

在GitHub上加星,即可立即收到新版本的通知! star_us

开始

安装方式

此次更新带来了使用门槛,资源占用,检索效果,问答效果,解析效果,前端效果,服务架构,使用方式等多方面的改进。同时合并了旧有的docker版和python版两个版本,改为全新的统一版本,采用docker compose单行命令一键启动。

最新特性表

特性 python (v1.4.1) docker (v1.4.1) 全新QAnything v2.0 说明
详细安装文档
API支持
生产环境(小型生产环境)
断网安装(私有化部署)
支持多并发
支持多卡推理 v2.0版本不再提供默认本地LLM,一律通过openai接口接入,用户可自行通过ollama等工具部署本地LLM
支持Mac(M系列芯片)
支持Linux python版本Linux下默认使用onnxruntime-gpu for cuda12,glibc<2.28时自动切换为onnxruntime
支持windows (无需WSL) v1.4.1版本的python和docker均要求WSL环境,v2.0可直接在非WSL环境下启动
支持纯CPU环境 v2.0版本Mac,Linux,Win统一不再使用GPU,完全迁移至CPU
支持混合检索(BM25+embedding)
支持联网检索(需外网VPN)
支持FAQ问答
支持自定义机器人(可绑定知识库,可分享)
支持文件溯源(数据来源可直接点击打开)
支持问答日志检索(暂只支持通过API调用)
支持解析语音文件(依赖faster_whisper,解析速度慢)
支持OpenCloudOS
支持与OpenAI接口兼容的其他开源大模型服务(包括ollama) v1.4.1版本需手动修改api_key,base_url,model等参数,v2.0版本均改为前端设置自动保存
pdf(包含表格)解析效果+++ v1.4.1版本需手动设置,v2.0无需手动设置,pdf解析效果和性能均有提升
用户自定义embed,rerank配置(实验性:提升速度) v1.4.1需手动开启,v2.0默认使用最佳配置
其他文件类型解析效果+++ v2.0版本提升url,md,xlsx,docx等解析效果
支持独立服务调用 v2.0版本独立依赖服务,包括embed,rerank,ocr,pdf解析服务等,可独立调用(http)
支持快速开始模式 快速开始:无需创建知识库,支持文件即传即问,支持无文件问答
支持仅检索模式 仅返回检索结果,不调用大模型进行问答
支持解析结果chunks内容可视化,手动编辑 v2.0版本支持手动编辑chunks内容,实时生效
pdf解析支持图片,支持回答带图

新增细节优化:

  • 支持前端配置API_BASE,API_KEY,文本分片大小,输出token数量,上下文消息数量等参数

  • 优化Bot角色设定的指令遵循效果,每个Bot可单独配置模型参数

  • 支持创建多个对话窗口,同时保存多份历史问答记录

  • 支持问答内容保存成图片

  • 优化上传文件逻辑,解析文件与问答请求独立,上传文件不再影响问答

  • 优化镜像大小,旧版本镜像压缩后大小为18.94GB->新版镜像压缩后大小为4.88GB,降为原有的1/4,提供完整Dockerfile

  • 检索优化,chunks新增片段融合与排序,聚合单文档或双文档

  • 检索阶段和问答阶段均嵌入metadata信息,提升检索和问答效果

    各阶段数据展示:

  • 知识库所有文件上传进度展示

  • 知识库单个文件上传进度展示,上传各阶段耗时

  • 问答信息统计,包含问答各阶段耗时,tokens消耗,模型信息等

  • 用户信息统计,包含上传文件总数量,总耗时,问答历史记录等

    问题修复

  • xlsx表格支持多sheet解析

  • 优化PDF表格漏识别问题

  • 修复DOCX文件解析出错问题

  • 优化FAQ匹配逻辑

  • 支持非utf-8编码的txt文件 |

docker环境安装

必要条件

System Required item Minimum Requirement Note
RAM Memory >= 20GB (use OpenAI API)
Docker version >= 20.10.5 Docker install
Linux/Mac docker compose version >= 2.23.3 docker compose install
Windows Docker Desktop >= 4.26.1(131620) Docker Desktop for Windows
git-lfs git-lfs install

step1: 下载本项目

git clone https://github.com/netease-youdao/QAnything.git

step2: 进入项目根目录执行启动脚本

cd QAnything
# 在 Linux 上启动
docker compose -f docker-compose-linux.yaml up
# 在 Mac 上启动
docker compose -f docker-compose-mac.yaml up
# 在 Windows 上启动
docker compose -f docker-compose-win.yaml up

(注意)如果启动失败,可以尝试将 docker compose改为 docker-compose

step3: 开始体验

前端页面

运行成功后,即可在浏览器输入以下地址进行体验。

  • 前端地址: http://your_host:8777/qanything/

API

如果想要访问API接口,请参考下面的地址:

  • API address: http://your_host:8777/api/
  • For detailed API documentation, please refer to QAnything API 文档

DEBUG

如果想要查看相关日志,请查看QAnything/logs/debug_logs目录下的日志文件。

  • debug.log
    • 用户请求处理日志
  • main_server.log
    • 后端服务运行日志
  • rerank_server.log
    • rerank服务运行日志
  • ocr_server.log
    • OCR服务运行日志
  • embedding_server.log
    • 前端服务运行日志
  • insert_files_server.log
    • 文件上传服务运行日志
  • pdf_parser_server.log
    • pdf解析服务运行日志

关闭服务

bash close.sh

离线使用

如果您想要离线使用QAnything,需要在断网机器提前部署本地的ollama模型,可以使用以下命令启动服务。

windows离线使用

# 先在联网机器上下载docker镜像
docker pull quay.io/coreos/etcd:v3.5.5
docker pull minio/minio:RELEASE.2023-03-20T20-16-18Z
docker pull milvusdb/milvus:v2.4.8
docker pull mysql:8.4
docker pull xixihahaliu01/qanything-win:v1.5.1  # 从 [https://github.com/netease-youdao/QAnything/blob/master/docker-compose-windows.yaml#L103] 中获取最新镜像版本号。

# 打包镜像
docker save quay.io/coreos/etcd:v3.5.5 minio/minio:RELEASE.2023-03-20T20-16-18Z milvusdb/milvus:v2.4.8 mysql:8.4 xixihahaliu01/qanything-win:v1.5.1 -o qanything_offline.tar

# 下载QAnything代码
wget https://github.com/netease-youdao/QAnything/archive/refs/heads/master.zip

# 把镜像qanything_offline.tar和代码QAnything-master.zip拷贝到断网机器上
cp QAnything-master.zip qanything_offline.tar /path/to/your/offline/machine

# 在断网机器上加载镜像
docker load -i qanything_offline.tar

# 解压代码,运行
unzip QAnything-master.zip
cd QAnything-master
bash run.sh

Linux离线使用

# 先在联网机器上下载docker镜像
docker pull quay.io/coreos/etcd:v3.5.5
docker pull minio/minio:RELEASE.2023-03-20T20-16-18Z
docker pull milvusdb/milvus:v2.4.8
docker pull mysql:8.4
docker pull xixihahaliu01/qanything-linux:v1.5.1  # 从 [https://github.com/netease-youdao/qanything/blob/master/docker-compose-linux.yaml#L104] 中获取最新镜像版本号。

# 打包镜像
docker save quay.io/coreos/etcd:v3.5.5 minio/minio:RELEASE.2023-03-20T20-16-18Z milvusdb/milvus:v2.4.8 mysql:8.4 xixihahaliu01/qanything-linux:v1.5.1 -o qanything_offline.tar

# 下载QAnything代码
wget https://github.com/netease-youdao/QAnything/archive/refs/heads/master.zip

# 把镜像qanything_offline.tar和代码QAnything-master.zip拷贝到断网机器上
cp QAnything-master.zip qanything_offline.tar /path/to/your/offline/machine

# 在断网机器上加载镜像
docker load -i qanything_offline.tar

# 解压代码,运行
unzip QAnything-master.zip
cd QAnything-master
bash run.sh

常见问题

常见问题

使用

跨语种:多篇英文论文问答

multi_paper_qa.mp4

信息抽取

information_extraction.mp4

文件大杂烩

various_files_qa.mp4

网页问答

web_qa.mp4

接入API

如果需要接入API,请参阅QAnything API 文档

贡献代码

我们感谢您对贡献到我们项目的兴趣。无论您是修复错误、改进现有功能还是添加全新内容,我们都欢迎您的贡献!

感谢以下所有贡献者

🛣️ 路线图 & 反馈

🔎 想了解QAnything的未来规划和进展,请看这里: QAnything Roadmap

🤬 想要给QAnything提交反馈,请看这里(可以给每个功能需求投票哦): QAnything Feedbak

交流 & 支持

Discord

欢迎加入QAnything Discord 社区!

微信

欢迎关注微信公众号,获取最新QAnything信息

欢迎扫码进入QAnything交流群

邮箱

如果你需要私信我们团队,请通过下面的邮箱联系我们:

[email protected]

GitHub issues & discussions

有任何公开的问题,欢迎提交issues,或者在discussions区讨论

Logo

Star History

Star History Chart

协议

QAnything 依照 Apache 2.0 协议开源。

Acknowledgements