如何在本地部署小智服务器:从源码到全模块运行的详细步骤

小智聊天机器人本地后台服务器源码全模块部署

作者:林甲酸 -不是小女子也不是女汉子 是大女子
更新日期:2025年4月29日

我觉得新的控制台好看耶

🎯 前言:为什么要写这篇教程?

上周按照虾哥小智服务器的教程去部署本地后台,我用的是本地源码运行全模块的方法去部署,虽然照着文字教程去部署了,但是教程一看要安装好多东西啊,我是一个硬件的,对于服务器这块也不熟悉,一路坎坎坷坷,还好借助各类gpt解决了问题。感谢AI工具🙏。如果你也跟我一样看着教程有些下不去手,或许你可以参考我这篇文章开始动手,帮您少走一步弯路。:
在这里插入图片描述

本文将用最直白的语言+图解,带你完成全模块部署!
注:部署过程也不是一次就能搞定的,出现问题可以备注交流,文章是经过验证后才写的,如果错误请指正,欢迎交流!


采用本地源码运行全模块的好处是,你可以体验最全的小智大模型各类工具。
声明,本文参考了:
小智源码文档
本地源码运行全模块步骤
小智硬件源码
下面跟着虾哥本地源码运行全模块的流程来吧!

📦 环境总览

组件版本用途
Docker最新版容器化部署数据库
MySQL8.0+数据存储
Redis7.0+缓存服务
JDK21后端运行环境
Python3.10AI模型推理

🔧 一、安装MySQL数据库

1. 先安装Docker

通过docker安转MySQL。这里因为我是没有MySQL,所以我采取了使用Docker安装。我用的Docker是在官方下载的,我并没有按照他上面给的方式去安装,感觉看的不清晰。
(1)安装Docker我是win11系统,我选择了第3个。
在这里插入图片描述
(2)安装的时候记得要关闭所有杀毒软件!关闭所有防火墙!安装的时候使用管理员运行.exe文件,安装的时候按照默认选择。
在这里插入图片描述

(2)安装好后关闭,然后重新管理员运行打开软件。进入界面时Accept一下条款,然后Skip跳过介绍。

在这里插入图片描述
(3)Docker设置。这一步是在 Docker Desktop 里开启 WSL 2 集成,目的是让 Docker 可以直接在你的 WSL 2(例如 Ubuntu)环境中运行容器。点击设置->Resources->WSL integration,然后打开Ubuntu的按钮,为了让你的 Ubuntu WSL 环境可以直接用 Docker。
在这里插入图片描述

这里我当时安装的时候没有出现Ubuntu的按钮,是因为当时我的系统尚未安装任何WSL 2发行版。如果你没有遇到这个问题可以跳过这里。解决方法:
① 安装WSL 2发行版

wsl –install

②将发行版设置为WSL 2模式

wsl --set-version Ubuntu 2

③验证是否成功

wsl --list –verbose

确认输出中包含Ubuntu且版本为WSL 2。然后在关闭、管理员重启Docker,就可以看到这里有这个Ubuntu选项了。
(4)接下来。在Docker Desktop 中设置 磁盘镜像存储位置,Docker Desktop 会把所有的数据(包括镜像、容器、卷)存在 C 盘,如果不改路径,时间长了 C 盘可能爆满。我选择了D盘。然后点击Apply&restart。
在这里插入图片描述等待安装好后,管理员打开Docker,这样就安装好这个大部头。

2. 通过docker安转MySQL

安装好 Docker 后,确保Docker打开的状态。你可以通过 命令行终端PowerShell,通过docker安装mysql。
在这里插入图片描述
这个时候你可以看到在Docker中看到当前系统正在运行一个MySQL容器
在这里插入图片描述

🔧 二、安装redis

如果还没有Redis,你可以通过docker安装redis
在这里插入图片描述
回车之后,可以看到redis启动运行
在这里插入图片描述

🔧 三、运行manager-api程序(后端服务)

1. 安装JDK21

① JDK下载网址:Java 。我是window系統行4位。解压后,可安装到D盘。D:\JDK21_0_6
在这里插入图片描述
② 设置JDK的path环境变量。首先是Path环境变量设置。在“系统变量”区域找到并选中 Path,然后点击“编辑”。 在编辑窗口中,点击“新建”,添加以下JDK的安装路径
在这里插入图片描述
③ 设置JDK的JAVA_HOME 环境变量。在“系统变量”部分点击“新建”, 变量名:JAVA_HOME,变量值:JDK 安装路径。
在这里插入图片描述
④ 可以打开PowerShell,验证 JDK 是否安装成功

java -version

如果返回类似下面的结果,说明 JDK 已正确安装

java version "21" 2025-03-21
Java(TM) SE Runtime Environment (build 21+36-2239)
Java HotSpot(TM) 64-Bit Server VM (build 21+36-2239, mixed mode)

2.安装Maven

① Maven 压缩包(下载 Maven 的二进制 zip 文件)。我安装到D:\JDK21_0_6
在这里插入图片描述
②解压 Maven 到 D 盘,例如:D:\Apache\Maven。
在这里插入图片描述
③设置环境变量
• MAVEN_HOME:指向你解压 Maven 的目录(例如:D:\Apache\Maven)。
• Path:将 Maven 的 bin 目录添加到 Path 环境变量中(例如:D:\Apache\Maven\bin)。

3.安装Java环境相关插件

打开 VSCode,安装 Java 插件(例如:Java Extension Pack)以支持 Java 开发
在这里插入图片描述

4.使用Vscode编程工具加载manager-api模块

首先你需要去下载源码
虾哥源码地址 解压后按照虾哥的教程你需要“把它重命名成xiaozhi-esp32-server,我把工程放在了E盘,然后使用VScode打开路径“E:\xiaozhi-esp32-server\main\manager-api”。
①按照虾哥提供的配置,将数据库连接信息填入

src/main/resources/application-dev.yml中:
spring:datasource:username: root
password: 123456

② 在src/main/resources/application-dev.yml中配置Redis连接信息

spring:data:redis:host: localhostport: 6379password:database: 0

在这里插入图片描述

5.运行manager-api程序

一定要确保你的Docker是打开的,这俩是在运行的情况下,再去运行程序。
在这里插入图片描述
当你看到输出日志时,说明你的manager-api启动成功了。
在这里插入图片描述

🔧四、运行manager-web程序(前端控制台)

1. 安装nodejs

(下面的步骤都是按照虾哥的教程来的)
nodejs的安装地址:Node.js — 在任何地方运行 JavaScript

2. 使用Vscode编程工具加载manager-web模块

①终端命令进入manager-web目录下。

npm install

② 启动

npm run serve

在这里插入图片描述
③ 到这一步,运行成功后,打开智控台,链接:http://127.0.0.1:8001,注册第一个用户。第一个用户即是超级管理员,以后的用户都是普通用户。然后在里面配置你的LLM密钥。这一步可以去申请阿里或者智谱的密钥,网上很多,我就不描述了。
在这里插入图片描述
重要:注册成功后,使用超级管理员账号,登录智控台,在顶部菜单找到模型配置,然后在左侧栏点击大语言模型,找到第一条数据智谱AI,点击修改按钮, 弹出修改框后,将你注册到的智谱AI的密钥填写到API密钥中。然后点击保存。然后窗口别关闭了。
注意:采用豆包语音识别请看,没有可跳过这里。你如果使用豆包然后tts报错的话,你应该是voice_type参数出错了。别问我为啥知道…
如果你开通了豆包的语音识别,然后有这些参数
在这里插入图片描述
你可以按照我这个参数去修改豆包的语音合成。
在这里插入图片描述
然后要记得在外面这里音色管理修改参数编码,根据你开通填的音色去修改
在这里插入图片描述

🔧五、安装Python环境

我按照虾哥的教程使用 Conda 创建 Python 环境,这一步是为本地化运行的语音交互、设备通信、AI模型推理等关键功能提供隔离、稳定的Python运行时环境。因此需要先去安装Anaconda。

1. 安装清华镜像源的Anaconda

尽量安装Anaconda3-5.3.0后面的版本,python版本3.6。安装我是安装在D盘的
在这里插入图片描述

2. 通过conda_prompt运行指令

(1) 使用管理员身份运行
在这里插入图片描述
(2)执行命令

conda remove -n xiaozhi-esp32-server --all -y
conda create -n xiaozhi-esp32-server python=3.10 -y
conda activate xiaozhi-esp32-server# 添加清华源通道
conda config --add channels https://mirrors.tuna.tsinghua.edu.cn/anaconda/pkgs/main
conda config --add channels https://mirrors.tuna.tsinghua.edu.cn/anaconda/pkgs/free
conda config --add channels https://mirrors.tuna.tsinghua.edu.cn/anaconda/cloud/conda-forgeconda install libopus -y
conda install ffmpeg -y

安装libopus可能会出现如下报错:
在这里插入图片描述
你可以尝试:指定conda-forge安装
libopus主要在conda-forge仓库中,可以指定从conda-forge安装:

conda install -c conda-forge libopus -y

上面的命令都要一步一步执行下来。出现问题,及时问AI。
在这里插入图片描述

🔧六、运行源码依赖

1. 安装依赖

# 继续使用conda环境
conda activate xiaozhi-esp32-server
# 进入到你的项目根目录,再进入main/xiaozhi-server
cd main/xiaozhi-server
pip config set global.index-url https://mirrors.aliyun.com/pypi/simple/
pip install -r requirements.txt

在这里插入图片描述

🔧七、 下载语音识别模型文件

还是按照虾哥的教程去下载语音识别模块,然后下载后把model.pt文件放在models/SenseVoiceSmall目录下线路 百度网盘下载SenseVoiceSmall 提取码:qvna

🔧八、 配置项目文件

1. 复制server.secret参数

使用 超级管理员账号 登录系统管理后台(智控台),在顶部菜单找到参数管理(参数编码为server.secret),找到列表中第一条数据,参数编码是server.secret,它是随机生成的,每次重新部署都会随机生成,复制它到参数值。
在这里插入图片描述

2. 配置.config.yaml文件

打开整一个源码文件,进入xiaozhi-server目录,检查是否存在data文件夹,如果没有data目录,请手动创建。如果 data 目录下没有 .config.yaml 文件,执行以下操作:
将 xiaozhi-server 目录下的 config_from_api.yaml 复制到 data 目录。重命名复制的文件为 .config.yaml
在这里插入图片描述
将复制的server.secret值粘贴到secret字段中。
在这里插入图片描述

🔧九、 运行xiaozhi-esp32-server项目

1.运行本地服务端

在刚刚安装依赖的环境下继续执行

# 确保在xiaozhi-server目录下执行
conda activate xiaozhi-esp32-server
python app.py

在这里插入图片描述
如果出现上面的结果,表示你的server端已经部署好了。接下来就是跟小智硬件的结合。注意看返回的ws://xxx.xx.xx.xx:8000/xiaozhi/v1/,其中xxx.xx.xx.xx就是你本地的地址,后面都会用到。

2.硬件接口更新

接下来你可以去在智控台更新硬件接口。
①使用超级管理员账号,登录智控台,在顶部菜单找到参数管理,找到参数编码是server.websocket,输入你的Websocket接口。
②使用超级管理员账号,登录智控台,在顶部菜单找到参数管理,找到数编码是server.ota,输入你的OTA接口。
不知道为啥我没找到,所以我通过手动新增了这两个参数
在这里插入图片描述

🔧十、 小智硬件烧录

打开小智的硬件源码程序。

  1. OTA接口更新
http://你电脑局域网的ip:8002/xiaozhi/ota/
  1. Websocket接口更新
ws://你电脑局域网的ip:8000/xiaozhi/v1/

这里我是写在Kconfig.projbuild文件里面,后面配置的时候会根据这个文件去更新。记得保存
在这里插入图片描述
你可以点击下方的设置那里,查看右边配置有没有更新到,没有问题可以下载到小智硬件了。
在这里插入图片描述
硬件烧录成功后,根据屏幕播报的设备码填写到控制台。点击智能体管理,还没新建智能体的话,就新建一个,然后填写设备管理,绑定播报的6位验证码。
在这里插入图片描述
在这里插入图片描述
然后点击硬件重启设备。接下来就是见证奇迹的时候。
在这里插入图片描述

总结:

通过上述步骤,你已经成功在本地部署了小智服务器。无论是后端服务的管理、前端控制台的操作,还是语音交互与硬件控制的集成,都可以在本地环境中完成。这种部署方式给开发者提供了极大的灵活性,同时也帮助你更深入地理解整个系统的工作流程。希望本文能帮助你少走弯路,顺利搭建起属于自己的智能硬件系统。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/78679.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

github开源项目添加开源协议,使用很简单

直接在 GitHub 网页上创建 进入你的 GitHub 仓库 打开你的项目仓库页面(如 https://github.com/用户名/仓库名)。 点击 "Add file" → "Create new file" 在仓库主页,点击右上角的 "Add file" 按钮&#xff…

8.idea创建maven项目(使用Log4j日志记录框架+Log4j 介绍)

8.idea创建maven项目(使用Log4j日志记录框架Log4j 介绍) 在 IntelliJ IDEA 的 Maven 项目中引入了 Log4j,并配置了日志同时输出到控制台和文件。 Log4j 提供了灵活的日志配置选项,可以根据项目需求调整日志级别、输出目标和格式。 1. 创建 Maven 项目 …

【和春笋一起学C++】函数——C++的编程模块

目录 1. 原型句法 2. 函数分类 3. 函数参数之按值传递 4. 数组作为函数参数 在C中,要使用函数,必须要有这三个方面: 函数原型,函数原型描述了函数到编译器的接口,函数原型一般放在include文件中。函数原型告诉编译…

深挖Java基础之:认识Java(创立空间/先导:Java认识)

今天我要介绍的是在Java中对Java的一些基本语法的认识与他们的运用,以及拟举例子说明和运用场景,优势和劣势, 注:本篇文章是对Java的一些基本的,简单的代码块的一些内容,后续会讲解在Java中的变量类型&…

Python+Selenium+Pytest+Allure PO模式UI自动化框架

一、框架结构 allure-report:测试报告base:定位元素封装data:数据log:日志文件page:页面封装文件夹report:缓存报告testcases:测试用例层utils:工具类run.py:执行文件 二…

博物馆除湿控湿保卫战:M-5J1R 电解除湿科技如何重塑文物守护的未来

在卢浮宫幽深的长廊里,达芬奇的《蒙娜丽莎》正经历着一场看不见的战争——不是来自时间的侵蚀,而是空气中无形的水分子。每一件文物都在与湿度进行着无声的抗争,这场抗争关乎人类文明的延续。湿度,这个看不见的文物杀手&#xff0…

【嘉立创EDA】如何找到曲线和直线的交点,或找到弧线和直线的交点

文章路标👉 :one: 文章解决问题:two: 主题内容:three: 参考方法be end..1️⃣ 文章解决问题 操作环境:嘉立创EDA专业版 V2.2.38 本文使用嘉立创EDA,描述如何快速找到曲线和直线交点的方法,这里的曲线包括了弧线等。本文将此过程记录,以供有需要的读者参考。 2️⃣ 主题…

大语言模型能否替代心理治疗师的深度拓展研究:fou

大语言模型能否替代心理治疗师的深度拓展研究 在科技初创企业和研究领域,大型语言模型(LLMs)用于替代心理健康服务提供者的应用备受关注。但研究人员通过对主要医疗机构治疗指南的梳理回顾,并对当前 LLMs(如 gpt-4o)进行实验评估后发现,LLMs 存在对心理疾病患者表达污名…

【linux】Chrony服务器

简介 1.1 时间的重要性 由于 IT 系统中,准确的计时非常重要,有很多种原因需要准确计时: 在网络传输中,数据包括和日志需要准确的时间戳 各种应用程序中,如订单信息,交易信息等 都需要准确的时间戳 1.2 时区…

mysql查看哪些表的自增id已超过某个值

场景 想看哪些表数据比较大,如果用count 比较慢,同时表设计如果是自增,有没有办法一次查出自增id已超过某值的所有表呢。 方法 SELECT AUTO_INCREMENT,TABLE_NAME FROM INFORMATION_SCHEMA.TABLES WHERE TABLE_SCHEMA 库名 AND AUTO_INCRE…

SiamMask原理详解:从SiamFC到SiamRPN++,再到多任务分支设计

SiamMask原理详解:从SiamFC到SiamRPN,再到多任务分支设计 一、引言二、SiamFC:目标跟踪的奠基者1. SiamFC的结构2. SiamFC的局限性 三、SiamRPN:引入Anchor机制的改进1. SiamRPN的创新2. SiamRPN的进一步优化 四、SiamMask&#x…

SpringBoot终极形态:AI生成带OAuth2鉴权的微服务模块(节省20人日)

在数字化转型的浪潮中,开发效率和质量是企业竞争力的关键要素。飞算 JavaAI 作为一款创新的 AI 工具,能在 Spring Boot 开发中,自动生成完整微服务模块,极大提升开发效率。下面,我们就详细介绍如何借助飞算 JavaAI,实现 Spring Boot 微服务模块的自动化生成。 飞算 JavaAI 简介…

Spring缓存注解深度实战:3大核心注解解锁高并发系统性能优化‌

引言:缓存——高并发系统的“性能加速器”‌ 在互联网应用中,数据库查询往往是性能瓶颈的核心。当每秒数千次的请求直接冲击数据库时,系统响应速度会急剧下降,甚至引发宕机风险。‌缓存技术‌应运而生,成为解决这一痛…

CSS元素动画篇:基于当前位置的变换动画(二)

基于当前位置的变换动画(二) 前言旋转效果类元素动画摇摆动画效果效果预览代码实现 摇晃动画效果效果预览代码实现 螺旋旋转效果预览代码实现 结语 前言 CSS元素动画一般分为两种:一种是元素基于当前位置的变换动画,通过不明显的…

Qt/C++开发监控GB28181系统/设备注册/设备注销/密码认证/心跳保活/校时

一、前言 根据gb28181协议文档,第一步就是需要实现设备的注册,和onvif不同,gb是反过来的,设备端主动连接服务端,而onvif是服务端主动发出搜索,设备被动应答,包括后续的交互几乎都是被动应答&am…

MATLAB 中的图形绘制

一、线图 plot 函数用来创建x和y值的简单线图。 x 0 : 0.05 : 30; %从0到30,每隔0.05取一次值 y sin(x); plot(x,y,LineWidth,2) %若(x,y,LineWidth,2)可变粗 xlabel("横轴标题") ylab…

go语言八股文(五)

1.go的局部变量是分配在栈上还是在堆上 在Go语言中,局部变量的内存分配(栈或堆)由编译器基于逃逸分析(escape analysis)来决定。以下是总结和具体示例: 栈上分配 当局部变量的生命周期严格限定在函数作用…

Gradients of Matrix-Matrix Multiplication in Deep Learning

Gradients of Matrix-Matrix Multiplication in Deep Learning 1. Matrix multiplication2. Derivation of the gradients2.1. Dimensions of the gradients2.2. The chain rule2.3. Derivation of the gradient ∂ L ∂ A \frac{ {\partial L} }{ {\partial \boldsymbol {\bo…

Spring Boot 框架简介

✨ Spring Boot 框架简介 1️⃣ 🚀 快速构建 Spring Boot 能够快速构建可直接运行的、企业级 Spring 应用。 2️⃣ ⚙️ “约定优于配置” 该框架采用"约定优于配置"理念,默认集成 Spring 平台与主流第三方库,开发者仅需简单配置…

【Robocorp实战指南】Python驱动的开源RPA框架

目录 前言技术背景与价值当前技术痛点解决方案概述目标读者说明 一、技术原理剖析核心概念图解核心作用讲解关键技术模块说明技术选型对比 二、实战演示环境配置要求核心代码实现案例1:网页数据抓取案例2:Excel报表生成 运行结果验证 三、性能对比测试方…