Windows部署deepseek R1训练数据后通过AnythingLLM当服务器创建问答页面
如果要了解Windows部署Ollama 、deepseek R1请看我上一篇内容。
这是接上一篇的。
AnythingLLM是一个开源的全栈AI客户端,支持本地部署和API集成。它可以将任何文档或内容转化为上下文,供各种语言模型(LLM)在对话中使用。以下是关于Windows环境下使用AnythingLLM API的一些重要信息:
一、安装与配置AnythingLLM API
安装与配置AnythingLLM
- 系统要求:支持Windows操作系统,建议至少8GB内存,推荐16GB或更高。
- 下载和安装:访问AnythingLLM官方网站,下载对应的Windows安装包,按照提示完成安装。
- 确保已安装 Python 3.9 及以上版本,并配置好环境变量。
- 安装必要的依赖库,如
requests,可以通过 pip 命令安装:pip install requests。
API调用
- 生成密钥:首先需要点击左下角第四个小扳手图标进入设置生成密钥,用于API的身份验证。
-

- 获取Workspace的slug:列出所有的workspace并找到对应的slug,用于指定API操作的工作空间。
- 调用API:使用Python等编程语言,通过HTTP请求调用AnythingLLM的API。例如,使用
requests.post()方法发送POST请求到指定的API端点,如http://your_ip:3001/api/v1/workspace/{slug}/chat,其中{slug}应替换为实际的工作空间。 - 请求头和参数:在请求头中设置
Authorization为生成的密钥,Content-Type为application/json。请求体中包含message(要询问的问题)和其他可选参数,如mode(chat或query)。
普通示例代码
以下是一个使用Python调用AnythingLLM API的示例代码:
import requestsdef ask_anythingllm(question, slug, api_key):url = f"http://your_ip:3001/api/v1/workspace/{slug}/chat"headers = {"Authorization": f"Bearer {api_key}","Content-Type": "application/json","accept": "application/json"}data = {"message": question,"mode": "chat" # 可选chat / query模式}response = requests.post(url, headers=headers, json=data)if response.status_code == 200:result = response.json()answer = result['textResponse'].split('</think>').strip()sources = result.get('sources', [])return answer, sourceselse:return f"Error: {response.text}", []<q refer="3"></q># 示例调用
api_key = "your_api_key" # 替换成你自己的apikey
slug = "your_workspace_slug" # 替换成你自己的workspace slug
question = "你的问题"
answer, sources = ask_anythingllm(question, slug, api_key)
print("回答:", answer)
print("来源:", [src['title'] for src in sources])
流式处理代码示例
- 指定 AnythingLLM API 的 URL,例如:
url = "http://your_ip:3001/api/v1/workspace/<workspace_name>/stream-chat",其中your_ip替换为部署 AnythingLLM 的服务器 IP,workspace_name替换为实际的工作空间名称。 - 设置请求头,包含授权信息和内容类型:
headers = {"Authorization": f"Bearer {api_key}", "Content-Type": "application/json", "accept": "text/event-stream"}。 - 构建请求体,包含问题和其他参数:
data = {"message": question, "mode": "query", "max_tokens": 1024, "stream": True}。 - 使用
requests.post()方法发送 POST 请求,设置stream=True以启用流式响应:response = requests.post(url, headers=headers, json=data, stream=True)。 - 逐行读取响应内容,进行处理:
for chunk in response.iter_lines(): if chunk: print(chunk.decode("utf-8"))
import requestsdef ask_anythingllm(question, workspace_name, api_key):url = f"http://your_ip:3001/api/v1/workspace/{workspace_name}/stream-chat"headers = {"Authorization": f"Bearer {api_key}","Content-Type": "application/json","accept": "text/event-stream"}data = {"message": question,"mode": "query","max_tokens": 1024,"stream": True}with requests.post(url, headers=headers, json=data, stream=True) as response:if response.status_code == 200:for chunk in response.iter_lines():if chunk:print(chunk.decode("utf-8"))else:print(f"Error: {response.status_code}: {response.text}")# 示例调用
api_key = "YOUR_API_KEY" # 替换成你自己的 API 密钥
workspace_name = "YOUR_WORKSPACE_NAME" # 替换成你的工作空间名称
question = "你的问题"
ask_anythingllm(question, workspace_name, api_key)
注意事项
- 确保 Windows 防火墙已开放 AnythingLLM 服务所使用的端口(默认为 3001),以便外部访问。
- 在实际应用中,建议添加错误处理和异常捕获机制,以应对网络问题或其他潜在错误。
- 流式输出适用于实时交互和长文本生成场景,可以提高用户体验和响应速度。
通过以上步骤,可以在Windows环境下成功调用AnythingLLM的API,实现与本地知识库的交互。
二、写一个问答网页
步骤概述
- 安装必要的库:使用 Flask 来构建 Web 应用,同时使用 requests 库来调用 Windows AnythingLLM API。
- 创建 Flask 应用:搭建一个简单的客服网页,接收用户输入,调用 API 获取回复,并将回复展示给用户。
from flask import Flask, render_template_string, request
import requestsapp = Flask(__name__)# 配置 Windows AnythingLLM API 的地址和参数
API_URL = "http://your-anythingllm-api-url" # 请替换为实际的 API 地址
HEADERS = {"Content-Type": "application/json"
}@app.route('/', methods=['GET', 'POST'])
def index():if request.method == 'POST':user_input = request.form.get('user_input')# 构建请求体data = {"input": user_input}try:# 调用 APIresponse = requests.post(API_URL, headers=HEADERS, json=data)response.raise_for_status()api_response = response.json().get('response', '无有效回复')except requests.RequestException as e:api_response = f"请求出错: {e}"else:api_response = ""return render_template_string('''<!DOCTYPE html><html lang="en"><head><meta charset="UTF-8"><title>客服网页</title></head><body><h1>客服网页</h1><form method="post"><label for="user_input">你的问题:</label><br><textarea id="user_input" name="user_input" rows="4" cols="50"></textarea><br><input type="submit" value="提交"></form>{% if api_response %}<h2>回复:</h2><p>{{ api_response }}</p>{% endif %}</body></html>''', api_response=api_response)if __name__ == '__main__':app.run(host='127.0.0.1', port=5000)
三、配置Cpolar内网穿透让其他人访问
配置Cpolar内网穿透
- 下载并安装Cpolar:从Cpolar官网下载适用于Windows的Cpolar客户端,并进行安装。
- 登录Cpolar Web UI:在浏览器中访问
http://localhost:9200,使用注册的Cpolar账号登录。 - 创建隧道:在Cpolar Web UI中创建一个新的隧道,配置如下:
- 隧道名称:自定义,如
anythingllm-api。 - 协议:选择
HTTP。 - 本地地址:填写
3001(AnythingLLM的API端口)。 - 域名类型:选择
随机域名(免费使用)或升级为固定二级子域名。
- 隧道名称:自定义,如
- 获取公网地址:隧道创建成功后,在“在线隧道列表”中复制生成的公网URL,用于访问客服网页。
测试与访问
- 本地测试:确保问答网页在本地可以通过
http://localhost:3001或其他本地地址正常访问。 - 公网访问:使用Cpolar生成的公网地址,在任何设备的浏览器中访问问答网页,验证是否能正常与AnythingLLM的API交互。
注意事项
- 安全性:确保API密钥的安全,避免泄露。可以考虑使用HTTPS协议和添加身份验证机制来增强安全性。
- 稳定性:长时间运行服务时,确保系统的稳定性,避免服务中断。
- 带宽与性能:根据实际需求,考虑是否需要升级Cpolar套餐以提高带宽和性能。
通过以上步骤,即可在Windows上将AnythingLLM的API结合Cpolar内网穿透,创建一个可供其他人访问的问答网页。
最后一步点赞 关注一下(非常重要)
相关文章:
Windows部署deepseek R1训练数据后通过AnythingLLM当服务器创建问答页面
如果要了解Windows部署Ollama 、deepseek R1请看我上一篇内容。 这是接上一篇的。 AnythingLLM是一个开源的全栈AI客户端,支持本地部署和API集成。它可以将任何文档或内容转化为上下文,供各种语言模型(LLM)在对话中使用。以下是…...
重删算法中的Bloom滤波器详解与C++实现
一、Bloom滤波器基础概念 Bloom滤波器(Bloom Filter)是一种空间高效的概率型数据结构,用于快速判断某个元素是否存在于集合中。其核心特性: 存在不确定性:可能出现假阳性(False Positive)&…...
信奥赛CSP-J复赛集训(模拟算法专题)(27):P5016 [NOIP 2018 普及组] 龙虎斗
信奥赛CSP-J复赛集训(模拟算法专题)(27):P5016 [NOIP 2018 普及组] 龙虎斗 题目背景 NOIP2018 普及组 T2 题目描述 轩轩和凯凯正在玩一款叫《龙虎斗》的游戏,游戏的棋盘是一条线段,线段上有 n n n 个兵营(自左至右编号 1 ∼ n 1 \sim n 1∼n),相邻编号的兵营之间…...
多模态大模型常见问题
1.视觉编码器和 LLM 连接时,使用 BLIP2中 Q-Former那种复杂的 Adaptor 好还是 LLaVA中简单的 MLP 好,说说各自的优缺点? Q-Former(BLIP2): 优点:Q-Former 通过查询机制有效融合了视觉和语言特征…...
SpringBoot项目实战(初级)
目录 一、数据库搭建 二、代码开发 1.pom.xml 2.thymeleaf模块处理的配置类 3.application配置文件 4.配置(在启动类中) 5.编写数据层 ②编写dao层 ③编写service层 接口 实现类 注意 补充(注入的3个注解) 1.AutoWir…...
Linux NFS、自动挂载与系统启动管理指南
1. NFS客户端挂载导出的目录的方式 NFS(网络文件系统) 允许将远程服务器的目录挂载到本地,像访问本地文件一样操作远程文件。挂载方式主要有两种: 手动挂载:使用 mount 命令(临时生效,重启后丢…...
uniapp实现全局拖拽按钮
要先引入 “vue3-draggable-resizable”: “^1.6.5” 1.创建DragComponent组件 <template><!-- 抽屉组件 --><div class"drag-container" id"dragBox" :style"{ zIndex: zIndex }"><Vue3DraggableResizable :initW"…...
SOFABoot-10-聊一聊 sofatboot 的十个问题
前言 大家好,我是老马。 sofastack 其实出来很久了,第一次应该是在 2022 年左右开始关注,但是一直没有深入研究。 最近想学习一下 SOFA 对于生态的设计和思考。 sofaboot 系列 SOFABoot-00-sofaboot 概览 SOFABoot-01-蚂蚁金服开源的 s…...
计算机网络——总结
01. 网络的发展及体系结构 网络演进历程 从1969年ARPANET的4个节点发展到如今覆盖全球的互联网,网络技术经历了电路交换到分组交换、有线连接到无线覆盖的革命性变革。5G时代的到来使得网络传输速度突破10Gbps,物联网设备数量突破百亿级别。 网络体系…...
Umi-OCR- OCR 文字识别工具,支持截图、批量图片排版解析
Umi-OCR 是免费开源的离线 OCR 文字识别软件。无需联网,解压即用,支持截图、批量图片、PDF 扫描件的文字识别,能识别数学公式、二维码,可生成双层可搜索 PDF。内置多语言识别库,界面支持多语言切换,提供命令…...
高速网络包处理,基础网络协议上内核态直接处理数据包,XDP技术的原理
文章目录 预备知识TCP/IP 网络模型(4层、7层)iptables/netfilterlinux网络为什么慢 DPDKXDPBFPeBPFXDPXDP 程序典型执行流通过网络协议栈的入包XDP 组成 使用 GO 编写 XDP 程序明确流程选择eBPF库编写eBPF代码编写Go代码动态更新黑名单 预备知识 TCP/IP…...
C++:背包问题习题
1. 货币系统 1371. 货币系统 - AcWing题库 给定 V 种货币(单位:元),每种货币使用的次数不限。 不同种类的货币,面值可能是相同的。 现在,要你用这 V 种货币凑出 N 元钱,请问共有多少种不同的…...
数据可信安全流通实战,隐语开源社区Meetup武汉站开放报名
隐语开源社区 Meetup 系列再出发!2025 年将以武汉为始发站,聚焦"技术赋能场景驱动",希望将先进技术深度融入数据要素流转的各个环节,推动其在实际应用场景中落地生根,助力释放数据要素的最大潜能!…...
java使用Apache POI 操作word文档
项目背景: 当我们对一些word文档(该文档包含很多的标题比如 1.1 ,1.2 , 1.2.1.1, 1.2.2.3)当我们删除其中一项或者几项时,需要手动的对后续的进行补充。该功能主要是对标题进行自动的补充。 具…...
【 C/C++ 包管理工具】vcpkg安装+使用
【 C/C 包管理工具】vcpkg安装使用 Vcpkg 是由 Microsoft 和 C 社区维护的免费开源 C/C 包管理器,可在 Windows、macOS 和 Linux 上运行。 可以很方便的安装管理 C/C 库。 1. 安装 不要安装到Program Files这种有空格的路径下,否则后面安装库可能出现…...
免费开源的NAS解决方案:TrueNAS
TrueNAS是业内知名的FreeNAS系统的升级版,是一款开源的网络存储系统,具有高性能、稳定性和易用性等优点。 TrueNAS目前有三个版本,分别是TrueNAS CORE、TrueNAS ENTERPRISE、TrueNAS SCALE。其中,TrueNAS CORE基于FreeBSD开发&…...
LeetCode热题100精讲——Top1:两数之和【哈希】
你好,我是安然无虞。 文章目录 题目背景两数之和C解法Python解法 题目背景 如果大家对于 哈希 类型的概念并不熟悉, 可以先看我之前为此专门写的算法详解: 蓝桥杯算法竞赛系列第九章巧解哈希题,用这3种数据类型足矣 两数之和 题目链接:两数…...
github上传操作简单说明
前期准备 0.下载git(如果已经有了就不用了) 1.在GitHub上新建一个存储库 2.先在本地创建一个目录作为本地库目录,在目录里打开git bash进行上传 上传过程 echo "# Garbled_repair" >> README.md 作用:创建一个…...
GitLens with `Commit Graph`
文章目录 GitLens with Commit Graph GitLens with Commit Graph 想要更直观地查看 Git 提交历史?我打包了一个支持 Commit Graph 的 GitLens 版本,让你轻松在 VSCode 中查看分支、合并、变更记录等内容,一目了然! 📌…...
Rocky9.5基于sealos快速部署k8s集群
首先需要下载 Sealos 命令行工具,sealos 是一个简单的 Golang 二进制文件,可以安装在大多数 Linux 操作系统中。 以下是一些基本的安装要求: 每个集群节点应该有不同的主机名。主机名不要带下划线。 所有节点的时间需要同步。 需要在 K8s …...
阿里云服务器环境部署 四 MySQL主从配置
安装MySQL 导入mysql镜像 docker load -i /opt/dockerinstall/mysql/mysql-8.1.0.tar docker run --privilegedtrue --name mysql8 --restartunless-stopped -e MYSQL_ROOT_PASSWORD123456 -p 3306:3306 -v /usr/local/mysql/logs:/var/log/mysql -v /usr/local/mysql/d…...
GPT-5 将免费向所有用户开放?
GPT-5 将免费向所有用户开放? 硅谷知名分析师 Ben Thompson 最近与 OpenAI CEO Sam Altman 进行了一场深度对谈,其中Sam Altman透漏GPT-5将免费向大家发放。 OpenAI 这波操作可不是一时冲动,而是被逼出来的。DeepSeek 这个新秀横空出世&am…...
web客户端存储,IndexDB相关讲解
IndexDB详细讲解 IndexedDB 是浏览器提供的一种底层 API,用于在客户端存储大量结构化数据。相比 Web Storage(localStorage/sessionStorage),它支持更复杂的数据结构、事务处理、索引查询等高级功能。以下是一个系统化的讲解: 一、核心概念 1、数据库(Database) 每…...
excel文件有两列,循环读取文件两列赋值到字典列表。字典的有两个key,分别为question和answer。将最终结果输出到json文件
import pandas as pd import json# 1. 读取 Excel 文件(假设列名为 question 和 answer) try:df pd.read_excel("input.xlsx", usecols["question", "answer"]) # 明确指定列 except Exception as e:print(f"读取文…...
项目日记 -云备份 -服务器配置信息模块
博客主页:【夜泉_ly】 本文专栏:【项目日记-云备份】 欢迎点赞👍收藏⭐关注❤️ 代码已上传 gitee 目录 前言配置信息文件文件配置类getInstance 获得实例readConfigFile 读取配置信息文件 测试 #mermaid-svg-ewlCpjdOf0q0VTLI {font-family:…...
gralloc usage flags
下面这些示例主要说明了 gralloc usage flags 在图像处理和多媒体应用中如何影响性能和正确性。让我们逐个详细分析每个问题的 根因 和 修复方案,并深入解析 gralloc 标志对 缓存管理 和 数据流 的影响。 ✅ Example 1: 长曝光快照耗时异常 📌 问题描述…...
Mysql配套测试之查询篇
🏝️专栏:Mysql_猫咪-9527的博客-CSDN博客 🌅主页:猫咪-9527-CSDN博客 “欲穷千里目,更上一层楼。会当凌绝顶,一览众山小。” 目录 条件查询简单测试: 1.查询英语成绩不及格的同学(<60) 2…...
mysql——第二课
学生表 CREATE TABLE student (id int(11) NOT NULL AUTO_INCREMENT,name varchar(255) COLLATE utf8mb4_bin DEFAULT NULL,sex varchar(255) COLLATE utf8mb4_bin DEFAULT NULL,age int(11) DEFAULT NULL,c_id int(10) DEFAULT NULL,PRIMARY KEY (id),KEY c_id (c_id),CONSTR…...
Python网络编程入门
一.Socket 简称套接字,是进程之间通信的一个工具,好比现实生活中的插座,所有的家用电器要想工作都是基于插座进行,进程之间要想进行网络通信需要Socket,Socket好比数据的搬运工~ 2个进程之间通过Socket进行相互通讯&a…...
arm linux下的读写信号量rw_semphore的实现
本文基于arm linux 5.10来介绍内核中使用的读写信号量rw remphore的实现代码。 内核中信号量结构体struct rw_semaphore的定义在include/linux/rwsem.h 32位architectures下,结构体struct rw_semaphore中的count的使用如下: 先来看信号量的定义和初始化…...
