Langchain-Chatchat/libs/chatchat-server/README.md

164 lines
7.5 KiB
Markdown
Raw Normal View History

2024-12-20 16:04:03 +08:00
### 项目简介
![](https://github.com/chatchat-space/Langchain-Chatchat/blob/master/docs/img/logo-long-chatchat-trans-v2.png)
[![pypi badge](https://img.shields.io/pypi/v/langchain-chatchat.svg)](https://shields.io/)
[![Generic badge](https://img.shields.io/badge/python-3.8%7C3.9%7C3.10%7C3.11-blue.svg)](https://pypi.org/project/pypiserver/)
🌍 [READ THIS IN ENGLISH](README_en.md)
📃 **LangChain-Chatchat** (原 Langchain-ChatGLM)
基于 ChatGLM 等大语言模型与 Langchain 等应用框架实现,开源、可离线部署的 RAG 与 Agent 应用项目。
点击[这里](https://github.com/chatchat-space/Langchain-Chatchat)了解项目详情。
### 安装
1. PYPI 安装
```shell
pip install langchain-chatchat
# or if you use xinference to provide model API:
# pip install langchain-chatchat[xinference]
# if you update from an old version, we suggest to run init again to update yaml templates:
# pip install -U langchain-chatchat
# chatchat init
```
详见这里的[安装指引](https://github.com/chatchat-space/Langchain-Chatchat/tree/master?tab=readme-ov-file#%E5%BF%AB%E9%80%9F%E4%B8%8A%E6%89%8B)。
> 注意chatchat请放在独立的虚拟环境中比如condavenvvirtualenv等
>
> 已知问题不能跟xinference一起安装会让一些插件出bug例如文件无法上传
2. 源码安装
除了通过pypi安装外您也可以选择使用[源码启动](https://github.com/chatchat-space/Langchain-Chatchat/blob/master/docs/contributing/README_dev.md)。(Tips:
源码配置可以帮助我们更快的寻找bug或者改进基础设施。我们不建议新手使用这个方式)
3. Docker
```shell
docker pull chatimage/chatchat:0.3.1.2-2024-0720
docker pull ccr.ccs.tencentyun.com/chatchat/chatchat:0.3.1.2-2024-0720 # 国内镜像
```
> [!important]
> 强烈建议: 使用 docker-compose 部署, 具体参考 [README_docker](https://github.com/chatchat-space/Langchain-Chatchat/blob/master/docs/install/README_docker.md)
4. AudoDL
🌐 [AutoDL 镜像](https://www.codewithgpu.com/i/chatchat-space/Langchain-Chatchat/Langchain-Chatchat) 中 `0.3.1`
版本所使用代码已更新至本项目 `v0.3.1` 版本。
### 初始化与配置
项目运行需要特定的数据目录和配置文件,执行下列命令可以生成默认配置(您可以随时修改 yaml 配置文件):
```shell
# set the root path where storing data.
# will use current directory if not set
export CHATCHAT_ROOT=/path/to/chatchat_data
# initialize data and yaml configuration templates
chatchat init
```
`CHATCHAT_ROOT` 或当前目录可以找到 `*_settings.yaml` 文件,修改这些文件选择合适的模型配置,详见[初始化](https://github.com/chatchat-space/Langchain-Chatchat/tree/master?tab=readme-ov-file#3-%E5%88%9D%E5%A7%8B%E5%8C%96%E9%A1%B9%E7%9B%AE%E9%85%8D%E7%BD%AE%E4%B8%8E%E6%95%B0%E6%8D%AE%E7%9B%AE%E5%BD%95)
### 启动服务
确保所有配置正确后(特别是 LLM 和 Embedding Model执行下列命令创建默认知识库、启动服务
```shell
chatchat kb -r
chatchat start -a
```
如无错误将自动弹出浏览器页面。
更多命令可以通过 `chatchat --help` 查看。
### 更新日志:
#### 0.3.1.3 (2024-07-23)
- 修复:
- 修复 nltk_data 未能在项目初始化时复制的问题
- 在项目依赖包中增加 python-docx 以满足知识库初始化时 docx 格式文件处理需求
#### 0.3.1.2 (2024-07-20)
- 新功能:
- Model Platform 支持配置代理 by @liunux4odoo (#4492)
- 给定一个默认可用的 searx 服务器 by @liunux4odoo (#4504)
- 更新 docker 镜像 by @yuehua-s @imClumsyPanda (#4511)
- 新增URL内容阅读器通过jina-ai/reader项目将url内容处理为llm易于理解的文本形式 by @ganwumeng @imClumsyPanda (#4547)
- 优化qwen模型下对tools的json修复成功率 by @ganwumeng (#4554)
- 允许用户在 basic_settings.API_SERVER 中配置 public_host,public_port以便使用云服务器或反向代理时生成正确的公网 API
地址 by @liunux4odoo (#4567)
- 添加模型和服务自动化脚本 by @glide-the (#4573)
- 添加单元测试 by @glide-the (#4573)
- 修复:
- WEBUI 中设置 System message 无效 by @liunux4odoo (#4491)
- 移除无效的 vqa_processor & aqa_processor 工具 by @liunux4odoo (#4498)
- KeyError of 'template' 错误 by @liunux4odoo (#4501)
- 执行 chatchat init 时 nltk_data 目录设置错误 by @liunux4odoo (#4523)
- 执行 chatchat init 时 出现 xinference-client 连接错误 by @imClumsyPanda (#4573)
- xinference 自动检测模型使用缓存,提高 UI 响应速度 by @liunux4odoo (#4510)
- chatchat.log 中重复记录 by @liunux4odoo (#4517)
- 优化错误信息的传递和前端显示 by @liunux4odoo (#4531)
- 修正 openai.chat.completions.create 参数构造方式,提高兼容性 by @liunux4odoo (#4540)
- Milvus retriever NotImplementedError by @kwunhang (#4536)
- Fix bug of ChromaDB Collection as retriever by @kwunhang (#4541)
- langchain 版本升级后DocumentWithVsId 出现 id 重复问题 by @liunux4odoo (#4548)
- 重建知识库时只处理了一个知识库 by @liunux4odoo (#4549)
- chat api error because openapi set max_tokens to 0 by default by @liunux4odoo (#4564)
#### 0.3.1.1 (2024-07-15)
- 修复:
- WEBUI 中设置 system message 无效([#4491](https://github.com/chatchat-space/Langchain-Chatchat/pull/4491))
- 模型平台不支持代理([#4492](https://github.com/chatchat-space/Langchain-Chatchat/pull/4492))
- 移除失效的 vqa_processor & aqa_processor 工具([#4498](https://github.com/chatchat-space/Langchain-Chatchat/pull/4498))
- prompt settings 错误导致 `KeyError: 'template'`([#4501](https://github.com/chatchat-space/Langchain-Chatchat/pull/4501))
- searx 搜索引擎不支持中文([#4504](https://github.com/chatchat-space/Langchain-Chatchat/pull/4504))
- init时默认去连 xinference若默认 xinference 服务不存在会报错([#4508](https://github.com/chatchat-space/Langchain-Chatchat/issues/4508))
- init时调用shutil.copytree当src与dst一样时shutil报错的问题[#4507](https://github.com/chatchat-space/Langchain-Chatchat/pull/4507))
### 项目里程碑
+ `2023年4月`: `Langchain-ChatGLM 0.1.0` 发布,支持基于 ChatGLM-6B 模型的本地知识库问答。
+ `2023年8月`: `Langchain-ChatGLM` 改名为 `Langchain-Chatchat`,发布 `0.2.0` 版本,使用 `fastchat` 作为模型加载方案,支持更多的模型和数据库。
+ `2023年10月`: `Langchain-Chatchat 0.2.5` 发布,推出 Agent 内容,开源项目在`Founder Park & Zhipu AI & Zilliz`
举办的黑客马拉松获得三等奖。
+ `2023年12月`: `Langchain-Chatchat` 开源项目获得超过 **20K** stars.
+ `2024年6月`: `Langchain-Chatchat 0.3.0` 发布,带来全新项目架构。
+ 🔥 让我们一起期待未来 Chatchat 的故事 ···
---
### 协议
本项目代码遵循 [Apache-2.0](LICENSE) 协议。
### 联系我们
#### Telegram
[![Telegram](https://img.shields.io/badge/Telegram-2CA5E0?style=for-the-badge&logo=telegram&logoColor=white "langchain-chatchat")](https://t.me/+RjliQ3jnJ1YyN2E9)
### 引用
如果本项目有帮助到您的研究,请引用我们:
```
@software{langchain_chatchat,
title = {{langchain-chatchat}},
author = {Liu, Qian and Song, Jinke, and Huang, Zhiguo, and Zhang, Yuxuan, and glide-the, and Liu, Qingwei},
year = 2024,
journal = {GitHub repository},
publisher = {GitHub},
howpublished = {\url{https://github.com/chatchat-space/Langchain-Chatchat}}
}
```