最新资讯

  • (2025)F450+树莓派5(Ubuntu24.04)+Dronekit+Aruco二维码降落 实验指南

(2025)F450+树莓派5(Ubuntu24.04)+Dronekit+Aruco二维码降落 实验指南

2025-05-09 20:00:58 7 阅读

1、本项目基本遵循苍穹四轴DIY给出的教程,但是由于各个库的版本更新,在环境配置过程中遇到了很多问题,原有教程难以解决,所以整理出一份资料。

2、由于环境配置过于复杂且繁琐,我只在Dronekit环境搭建还有SITL仿真环境搭建这两步进行了全过程的记录,只要对ubuntu系统足够熟悉,配置起来很快。不熟悉ubuntu也没关系,ubuntu使用上的关键部分我都贴出了相应教程。

3、dwc老师原本建议用ROS控制无人机,但是我为了光速毕业主打一个方便快捷且省事,最后还是采用了Dronekit的方案。

4、树莓派上的ubuntu系统用户名我设置为HDUASL,密码hduasl(小写)。

5、在这个项目之前我从未接触过无人机,仅为自身经验总结,如有错误,欢迎指正。(邮箱:Vc_Ri@outlook.com)

代码:

https://github.com/VcRi/F450-Dronekit-Aruco.git

演示视频:

(F450+Dronekit)SITL + MavProxy 仿真演示

F450+树莓派Ubuntu24.04+Dronekit 悬停、移动测试

综述:

1、无人机组装

2、无人机调试(需要下载地面站软件MissionPlanner)

3、树莓派5搭载Ubuntu24.04系统,使用GPIO对机械爪的PWM舵机进行控制以实现开合;使用Dronekit库对无人机进行飞行控制

4、仿真使用SITL+MAVProxy(仿真环境在笔记本虚拟机里的Ubuntu18.04系统上)

5、两个Ubuntu系统下载的都是带图形界面的版本,平时使用让树莓派接上显示器及键盘鼠标,用vscode写代码。户外飞行时用笔记本SSH远程连接树莓派(两台都连接手机热点,或者连接同一wifi,总之在同一网络下),通过命令行的方式运行代码。也可以通过VNC连接让笔记本获取到树莓派的桌面。

硬件准备:

1、F450无人机 (2000r左右,我使用的这台是pixhawk2.4.8飞控 + AT9s Pro遥控器)

苍穹四轴DIY 处购买,出厂已经调试好。我们有三台无人机是在这家购买的,提供订单链接可以被拉到售后群

2、树莓派5 (4G) (500r左右)

  • 树莓派5是23年新发售的,教程不多。我买它是因为买的时候什么也不知道,随便选了个最新的,不过使用上大差不差。
  • 买的是带csi摄像头版本的。raspberry pi os自带了对这个csi摄像头支持的库,但是ubuntu系统下我始终没搞定这个库,且这个摄像头似乎不具备完成这个项目的能力
  • 还额外购买了32G的SD存储卡装在树莓派上
  • 这一套使用下来偶有死机或者卡顿现象,不知道是内存小了还是树莓派本身性能的问题。

3、机械爪 (100r左右)

我购买的是下图这一款:

安装在无人机上的方式也很潦草,直接用轧带绑在无人机下面的。
机械爪资料-百度网盘分享 店家提供的机械爪资料我没细看,实际上就三根线,接到树莓派上就完事了,如何接线及使用详见文章后面。

4、摄像头 (400r左右)

  • 选择全局快门(而非卷帘快门),我描述了一下我要在离地两三米高度对地面上A4大小左右二维码进行识别的需求后,店家推荐我使用50-60度的摄像头:

  • 该摄像头是USB口,在win上和ubuntu上即插即用,无需安装驱动。Ubuntu命令行里输入以下两个命令可以调用该摄像头看看效果:

  • #ffmpeg是一个多媒体处理库,也是sudo apt install ffmpeg一行命令就能下载好
              
    #录制一段10s的视频
    ffmpeg -f v4l2 -input_format mjpeg -framerate 30 -video_size 1920x1200 -i /dev/video0 -t 10 -c:v copy output.mp4
              
    #拍摄一张照片
    ffmpeg -f v4l2 -input_format mjpeg -video_size 1920x1200 -i /dev/video0 -frames:v 1 -q:v 2 image.jpg
    
  • 但是这款摄像头的拍摄素质有点感人,我只能说完成该二维码识别任务还是可以成功的

  • 店家提供的调试软件:摄像头资料-百度网盘分享


F450很耐造,器材坏了都可以买,单价1000以内的发票学校可以直接报销,总之买之前跟dwc老师讲一声。

无人机桨叶等都是耗材(我的遥控技术实在太烂了),桨叶上有标型号,买的时候注意正桨反桨,可以各买一两副备用。

M8n GPS模块的支架容易摔断,如果断的地方靠底部,把螺丝拧开,支架重新插进去再拧上螺丝还可以继续用,只是会短一截。淘宝上也有单支架可以买,型号基本上是通用的。

苍穹四轴DIY教程整理:

点击可直接跳转:

图文并茂详细教程之–用pixhawk飞控组装一台F450四轴无人机(上)

图文并茂详细教程之-- 用pixhawk飞控组装一台F450无人机(中)

图文并茂详细教程之-- 用pixhawk飞控组装一台F450无人机(下)

Pixhawk无人机扩展教程(1)—树莓派与pixhawk连接

Pixhawk无人机扩展教程(2)—树莓派安装ubuntu-mate系统及必要设置

Pixhawk无人机扩展教程(3)—树莓派安装Dronekit及读取飞控数据

Pixhawk无人机扩展教程(4)—使用Dronekit编写一个控制程序

Pixhawk无人机扩展教程(5)—SITL仿真模拟飞行:开发环境搭建

Pixhawk无人机扩展教程(6)—启动SITL+MAVProxy

Pixhawk无人机扩展教程(7)—SITL+MP/QGC运行

Pixhawk无人机扩展教程(8)—使用键盘控制无人机飞行

Pixhawk无人机扩展教程(9)—树莓派安装opencv

本文是对这份教程的补充和扩展,飞行控制部分也主要参考教程里的代码,只是额外加上了机械爪控制和二维码检测部分。

其中扩展教程(7)和扩展教程(9)我完全没有用到。

温馨提示:

和安全性有关的问题,一定注意注意再注意,不要对自己太自信。

这一小段的内容即使暂时不理解也没有关系,放在前面是因为它非常重要。

祝愿大家都不要炸机。


1、每次安装好桨叶后,都仔细核对一遍桨叶安装是否正确

初次接触无人机的我:不是,这么简单谁能装反

某次起飞侧翻了三次才发现是桨叶装错后的我:我是**

2、锂电池是一个比较危险的东西。电池不要过充及过放,充电时保证有人在场。我的是3s锂电池,即有三片电芯,只要其中有一片坏了就不要再用了,电压会有问题;电池鼓包也不要再用了。每次飞行完毕后,无人机的动力锂电池和遥控器里的电池都及时取下,放进电池防爆袋里,废电池更是需要妥善处理

有次遥控器里的电池忘记取下,隔了一晚上发现电池鼓包,没法用了。

3、针对本项目,需要熟悉定高模式、悬停模式和降落模式,三种模式都要手飞过,并且学会判断GPS信号。

上锁、解锁、BB响使用演示:

YH远航科技-F450无人机PIXHAWK飞控起飞教程(定点+自稳操作)

这个视频里的遥控器设置和我们的不一样。关注使用过程就行。


苍穹四轴DIY提供的飞行教程:

定高模式(F450福斯遥控版)

悬停模式(F450机型乐迪遥控版)

降落模式(F450机型乐迪遥控版)

定高模式: 定高模式不需要GPS。飞上去后,高度虽然能固定,但是水平方向上会有较大偏移,要不断调整位置

悬停模式: 悬停模式需要GPS,飞上去后会定点悬停住。如果GPS信号不足,遥控器是解锁不了的。

降落模式: 降落模式下,无人机会自动降落。

在代码里面使用的都是GUIDED模式,降落时才会切换RTL返航或者LAND降落模式实现降落。

RTL模式下,会先回到航点上空固定高度(在missionplanner里可以查到RTL_ALT这个参数),然后再执行降落。这是教程里的代码提供的降落模式。

Land模式下,会让无人机直接降落。这是在我的项目采用的降落模式。


对于GUIDED模式,想让它飞上去定的住不漂移,也是需要足够的GPS信号的。

我的个人使用经验是,即使GPS信号不充足,在GUIDED模式下也会解锁。

那次的使用体验很恐怖, 我没有检查GPS灯,也没有在悬停模式下试验能否用遥控器解锁,结果无人机起飞后直接大漂移,最后撞到东西摔了。

在那次之后,我还遇到过代码运行中、等待无人机起飞时,LED灯忽然从绿变黄绿的情况。如果没及时暂停代码,恐怕就要梅开二度了。

当然如果你的场地足够空旷,就不用像我这么小心翼翼。我设置的飞行高度一般两三米,飞行时间也很短暂。


检查GPS信号我认为有两种方式:

1、直接连MissionPlanner,可以查到GPS信号是否充足。(实际上直接在遥控器里也能查到GPS搜星数量)

2、通过飞控上的LED灯判断GPS信号

我的数传用不了,每次地面站连飞控都要接线,很麻烦,所以我都用第二种方法,扫一眼就知道能不能起飞了。


如何识别LED灯?

LED灯在飞控上,这里仅说明明如何辨别pix的灯

我这里找到的是pix4的官方教程,与我使用的pixhawk2.4.8还是有点区别的

参考官方教程:LED灯含义 · PX4 User Guide

解锁: 在手飞情况下,遥控器“油门最低 + 方向舵右”这一步就是解锁操作,解锁完后,电机会转动,此时推油门无人机才会起飞。呈现在代码里,就是vehicle.armed = True这一句。(注意,拨动安全开关那一步只是解锁的前置条件,但还不是解锁)

GPS锁定: 这里锁定的意思是GPS模块会输出有效的全球定位数据,所以GPS锁定才是我们需要的。


综上,

蓝色,意味着GPS未锁定,即GPS信号不足。解锁操作会使灯从蓝色闪烁状态变成蓝色常亮状态。

绿色,意味着GPS锁定,即GPS信号充足。解锁操作会使灯从绿色闪烁状态变成绿色常亮状态。

但是!实际上我最常遇到的是另外一种快速闪烁的黄绿色灯(毕竟这只是Pixhawk4的教程)

这个灯的意思我猜测是介于蓝色和绿色之间,代表有GPS信号,但是仍然不足,譬如悬停模式下是无法解锁的

等待一段时间后,当GPS信号充足时,黄绿色灯才会转变成为绿色。M8N GPS性能不是很好,无人机附近不要有遮挡物,包括人也离得远一点。


黄绿色灯:

绿色灯:

代码控制飞行时,请保证LED灯一定是绿色的。


4、据无人机售后描述,用代码控制飞行时,使用遥控器切换飞行模式可以剥夺控制权。例如飞行中使用悬停模式,遥控器来回拨动一下模式开关就可以得到控制权了。但是在切换时油门需要保持中位,低位会掉下来。


5、如果真的炸机,可以看这篇教程查一下飞行日志检查原因:APM/Pixhawk飞行日志分析入门(苍穹四轴)

一、组装


组装见教程:图文并茂详细教程之–用pixhawk飞控组装一台F450四轴无人机(上)


这一步我没有经验可以分享,我拿到的无人机是已经组装好的,但是想熟悉一下所有结构的话可以参考这个视频:

F450装机教程PIX2.4.8版本

二、调试

图文并茂详细教程之-- 用pixhawk飞控组装一台F450无人机(中)

图文并茂详细教程之-- 用pixhawk飞控组装一台F450无人机(下)

调试过程完全遵循教程。 即使是已经安装使用过的无人机,在长期不用后一些仪器也需要校准。

一些注意事项如下:

1、推荐一个视频PIXHAWK2.4.8飞控调试教程,非常直观地展示了调试的步骤和一些细节。视频仅供参考,调试过程中所有的设置仍然以卖家的教程为准。

2、调试使用的软件是Mission Planner地面站,官网下载即可,教程里用的是版本1.3.62(archive文件夹里有历史版本)。注意下载.msi版本,前者安装完后能帮你装上驱动,后续用数据线连接时电脑可以成功识别到飞控

3、飞控和笔记本之间连接使用的是micro线,如果插上线后识别不到正确的端口,很有可能是线的问题。短的micro线极有可能只提供充电功能,无法进行数据传输;三合一充电线也不够稳定。这两种线我都试过,用不了。

4、第一次安装的无人机跟着教程一步步设置即可。已经安装使用过的无人机,跳过更新固件这一步(除非有特殊需求)

5、指南针校准这一步,只要三百六十度无死角来回晃让进度条走满就可以,不需要有严格的旋转方向

三、电池使用

如果实验室的电池或者充电器换新设备了,使用方式可能会略有不同。仅以我拿到手的为例:

共有两块锂电池,小的是控电,装在遥控器里;大的是动力锂电池,给无人机供电


电池接口:

左边白色的是平衡头,右边黄色的是XT60头

不同充电器需要用到的接口可能不同,使用B3平衡充的话,将平衡头接到充电器上进行充电即可。放一个电池充电的教程:[航模入门]B3、B6充电器使用方法 航模锂电池充电教程(锂电池易燃,不耐摔,使用务必注意安全,充电时需有人在场)


遥控器电池安装方式:

打开遥控器后侧电池槽

将遥控器电池供电头(红色那个头,有红黑两条电线分别对应正极和负极)插在遥控器的电池槽最左侧的二口排插上,保证正极(红色电线)朝上。


四、起飞

在温馨提示部分,已经列出了手飞可以参考的教程。顺便再把温馨提示看一遍。

五、树莓派与Pixhawk连接

见教程:Pixhawk无人机扩展教程(1)—树莓派与pixhawk连接

六、树莓派镜像烧录器烧录Ubuntu24.04系统

对应教程:Pixhawk无人机扩展教程(2)—树莓派安装ubuntu-mate系统及必要设置

在系统选择上,我并没有遵循扩展教程(2)的配置。树莓派5是2023年发售的,买的时候没考虑太多,买完后发现关于树莓派5的使用教程比较少。而且用树莓派镜像烧录器烧录系统的时候,发现能选择的ubuntu系统都比较新(没有教程里的那么古老)。中途系统还被我搞坏了一两次,总之最后配置好环境的Ubuntu系统是24.04 LTS (是一个相当新的Ubuntu版本)

因此,针对这一步骤,我简单描述下我是如何进行配置的:

1、使用树莓派镜像烧录器烧录24.04 LTS系统。
参考教程: 【树莓派5】树莓派5安装Ubuntu 23.10桌面系统


2、安装vim编辑器。
忘了24.04有没有自带vim了,虽然平时用vscode写代码,看文件也是直接用图形界面操作多,但是vim偶尔还是会用到的。

 sudo apt-get install vim

vim编辑器的基础用法是需要额外学一下的。


3、对Ubuntu进行换源。
ubuntu下载好时,官方源使用的是国外服务器,下载速度感人,要换成我们国内的源。常见的有清华源、阿里源、淘宝源等等,都可以使用(简单来说换源就是更改Ubuntu系统里某个文件里的某几行)。

换源教程:Ubuntu24.04换源方法(新版源更换方式,包含Arm64) 注意,树莓派是arm架构,要看最后的Arm64-ubuntu配置,即换源时要额外加上ports。


4、我没有用远程桌面的方案。我室内写代码时树莓派外接显示器鼠标键盘,户外测试时直接使用ssh连接树莓派。

  • 扩展教程(2)提到要在笔记本上提前下载好ubuntu系统,让两个ubuntu系统互连。我觉得没有必要。笔记本之后确实需要下载ubuntu系统(下载在虚拟机里),但这个系统我只用来配置仿真环境。现在用ssh连接只是保证在没有显示器和鼠标键盘的户外时,仍然可以运行树莓派里的代码,所以在win上使用MobaXterm这个软件远程ssh连接到树莓派就可以了。
  • 在笔记本windows系统上下载好MobaXterm(亲测很好用,推荐),树莓派上开启ssh远程服务,需要保证笔记本和树莓派在同一网络下(同一手机热点也可以),之后就可以连接到树莓派用命令行的方式对树莓派进行控制了。

对ubuntu24.04使用的提示:

ubuntu24.04下载好是自带python3的,下面两个命令可以查看python版本

python2 --version
python3 --version

本项目的代码都是在python3环境下运行的,在命令行里运行python代码使用的命令也是 python3 test.py(不加3会默认使用Python2环境)

苍穹四轴DIY里给出的教程应该是在python2环境下,Dronekit库也是Python2版本的。因此用教程里的方法去配置Dronekit完全不成功。这点在讲到Dronekit配置时再展开。

在环境配置阶段,除了Dronekit库下载和SITL仿真环境搭建这两步我卡了很久之外,其他所有的下载靠下面的命令基本就可以完成:

sudo apt install xxxx(你需要的包的名称)

sudo pip3 install xxxx(你需要的包的名称) #pip默认为Python 2使用,而pip3则专门为Python 3使用

总之环境配置就是看提示信息,提示缺什么就下载什么,大部分问题一两个命令就可以解决。下载不成就问GPT。

有时候回车了一个命令后会提示权限不足,这种情况一般是命令开头忘记加sudo了。sudo是临时提升权限的方式,不想频繁输入sudo也可以查下永久提升权限的方式。

在ubuntu命令行下输入密码,密码是被隐藏掉的,没有*号占位,光标也不会后移。放心大胆的输完然后敲回车,输错了会提示你重来的。

在室内使用时,树莓派是接树莓派官方电源使用的(比较稳定,卡顿较少)

在户外测试时,树莓派和无人机都使用电池供电,无人机上有一根Type-C接口的线就是给树莓派供电用的

七、机械爪安装

机械爪上的舵机是PWM舵机,总共有三根线,一根接5V电源,一根接地(Ground),还有一根是信号线,不同功能的线可以根据颜色区分。

查阅树莓派引脚图可发现,树莓派上总共40个引脚,每个引脚功能不同。

其中我接的是4号(5V电源)、6号(接地)和32号引脚(PWM信号),在图中已圈出。

引脚参考文章:树莓派5-GPIO和40针引脚_树莓派5引脚定义-CSDN博客

里面有提到“GPIO12、GPIO13、GPIO18、GPIO19 上提供硬件 PWM。”

总之我选择了GPIO12(即32号引脚),测试下来可以正常使用。

RPI.GPIO这个库是要下载的,网上查一下ubuntu安装树莓派GPIO库的命令是什么,不赘述。

机械爪测试代码:control.py

import RPi.GPIO as GPIO
import time

# 设置GPIO模式为BCM
GPIO.setmode(GPIO.BCM)
# 定义GPIO引脚
PWM_PIN = 12  # GPIO12(对应32号引脚)
# 设置GPIO引脚为输出模式
GPIO.setup(PWM_PIN, GPIO.OUT)
# 创建PWM实例,频率设置为50Hz(适用于大多数舵机)
pwm = GPIO.PWM(PWM_PIN, 50)
# 启动PWM,初始占空比为0(电机停止)
pwm.start(0)

# 定义函数:打开爪子
def open_claw():
    print("打开爪子")
    pwm.ChangeDutyCycle(8)  # 8%占空比(假设对应爪子打开)
    time.sleep(1)  # 等待1秒,确保动作完成

# 定义函数:闭合爪子
def close_claw():
    print("闭合爪子")
    pwm.ChangeDutyCycle(5)  # 5%占空比(假设对应爪子闭合)
    time.sleep(1)  # 等待1秒,确保动作完成
    
try:
    while True:
        open_claw()  # 打开爪子
        time.sleep(5)  # 等待5秒

        close_claw()  # 闭合爪子
        time.sleep(5)  # 等待5秒

except KeyboardInterrupt:
    # 捕获Ctrl+C,停止程序
    print("程序停止")

finally:
    # 停止PWM并清理GPIO设置
    pwm.stop()
    GPIO.cleanup()
    print("GPIO已清理")

八、树莓派安装Dronekit(修改Dronekit源码)

参考教程:Pixhawk无人机扩展教程(3)—树莓派安装Dronekit及读取飞控数据

之前提到过,我们的树莓派上安装的是Ubuntu24.04,自带python2和python3。

从教程里的Dronekit使用流程里看下来,它使用的应该是python2环境

python2实在太古老,我之后还要控制机械爪,还要使用OpenCV,所以Dronekit也必须在python3环境下使用

按照教程里的方式去下载Dronekit时,遇到了相当多的问题,查阅资料,甚至发现Dronekit 不支持Python3.0。不过都是比较古老的教程,2025年Dronekit还是支持python3的。

在树莓派里我也是误打误撞才装下来Dronekit,不可能为了复刻而重装一遍系统,所以决定在我的笔记本虚拟机里装一个Ubuntu24.04 LTS,复刻一下Dronekit安装流程(但树莓派是arm架构毕竟和笔记本还是有区别,不清楚会不会有影响)

1、查看python版本

python3 --version

输出Python 3.12.3,说明ubuntu24.04确实自带python3


2、下载pip3,下载完后查看

sudo apt install python3 python3-pip python3-dev
pip3 --version #查看pip3版本

3、下载dronekit

sudo pip3 install dronekit

报错:

言下之意就是和环境有冲突,但如果硬要下载,可以在后面加上–break-system-packages

sudo pip3 install dronekit --break-system-packages

下载成功,下一步测试一下这个库能不能在python代码里正常使用

我已经提前下载安装好vscode,ubuntu自带的火狐浏览器默认搜索引擎是谷歌,没开vpn是用不了的,初次使用记得去设置里改一下。如果不想额外下载代码编辑器,直接在命令行里用命令创建python文件然后写代码进去也行。就是真的难用。

from dronekit import connect, VehicleMode, LocationGlobalRelative #代码里放这一句就够了。

运行一下测试代码,发现出现了报错。看起来Dronekit确实下载并且引入成功了,问题出在Dronekit内部。

大致原因是,python3的高版本中,MutableMapping已经被弃用。解决方法要么给python版本降级,要么修改Dronekit源代码。



我们使用修改源代码的方式

其实并不复杂,仔细观察报错可以发现,问题出在文件的第2689行,改掉这一行里的一点内容就可以。
我们使用vim编辑器打开这个文件:

#注意,要给sudo权限,不然改不了这个文件
sudo vim /usr/local/lib/python3.12/dist-packages/dronekit/__init__.py

打开之后会发现vim编辑器没显示行号的,先按esc键,然后输入冒号,再输入set number,回车后会显示行号。

:set number

既然讲到这就多写一句,vim编辑器有保存退出和不保存退出,不小心改掉了不该改的记得不保存退出:

:wq #保存退出
:wq #强制保存退出
:q #不保存退出
:wq! #强制不保存退出

我们直接跳转2689行。同样是先按esc,再输入:

:2689 

键盘上敲一个a,进入插入模式

把2689行的 class Parameters(collections.MutableMapping, HasObservers):这一句替换成:

from collections.abc import MutableMapping
class Parameters(MutableMapping, HasObservers): 

然后:wq保存退出。

此时再运行测试代码,成功


接下来就是按照教程的步骤赋予端口权限。

需要提到的是,教程里面永久改写USB口读写权限我一直没有成功,因此每次都用下面这个命令临时赋予权限:

sudo chmod 666 /dev/ttyUSB0

如果环境配置都成功了话,给无人机供上电,在树莓派上运行connect.py代码看下是否能正常输出信息。

connect.py代码:

from dronekit import connect

# Connect to the Vehicle (in this case a UDP endpoint)
#vehicle = connect('/dev/ttyUSB0', wait_ready=True, baud=921600)
vehicle = connect('/dev/ttyUSB0', wait_ready=True, baud=57600) #降低波特率后成功

# vehicle is an instance of the Vehicle class
print("Autopilot Firmware version: %s" % vehicle.version)
print("Autopilot capabilities (supports ftp): %s" % vehicle.capabilities.ftp)
print("Global Location: %s" % vehicle.location.global_frame)
print("Global Location (relative altitude): %s" % vehicle.location.global_relative_frame)
print("Local Location: %s" % vehicle.location.local_frame)
print("Attitude: %s" % vehicle.attitude)
print("Velocity: %s" % vehicle.velocity)
print("GPS: %s" % vehicle.gps_0)
print("Groundspeed: %s" % vehicle.groundspeed)
print("Airspeed: %s" % vehicle.airspeed)
print("Gimbal status: %s" % vehicle.gimbal)
print("Battery: %s" % vehicle.battery)
print("EKF OK?: %s" % vehicle.ekf_ok)
print("Last Heartbeat: %s" % vehicle.last_heartbeat)
print("Rangefinder: %s" % vehicle.rangefinder)
print("Rangefinder distance: %s" % vehicle.rangefinder.distance)
print("Rangefinder voltage: %s" % vehicle.rangefinder.voltage)
print("Heading: %s" % vehicle.heading)
print("Is Armable?: %s" % vehicle.is_armable)
print("System status: %s" % vehicle.system_status.state)
print("Mode: %s" % vehicle.mode.name) 
print("Armed: %s" % vehicle.armed)  

对于波特率这一点我很迷惑。常见的波特率有1200、2400、4800、9600、19200、38400、57600和115200,我改了几次最后发现我的无人机波特率设置为57600时可以正常连接。至于为什么改成57600就可以不清楚。

注意,无人机记得接上电源。未接电源,仅连接地面站的情况下运行代码,我这里出现no heartbeat的报错

WARNING:dronekit:Link timeout, no heartbeat in last 5 seconds
ERROR:dronekit.mavlink:Exception in MAVLink input loop

九、使用Dronekit编写代码

参考教程:Pixhawk无人机扩展教程(4)—使用Dronekit编写一个控制程序

到这一步就可以编写自己需要的功能控制无人机移动了。

再放一下我的代码的实地测试视频:F450+树莓派Ubuntu24.04+Dronekit 悬停、移动测试

代码不能直接上无人机运行! 只要是控制飞行的代码都要提前做好仿真,下一部分才会讲解到仿真如何做。

hover.py:

#!/usr/bin/env python
# -*- coding: utf-8 -*-
from __future__ import print_function
import time
from dronekit import connect, VehicleMode, LocationGlobalRelative
import RPi.GPIO as GPIO

# 设置GPIO模式为BCM
GPIO.setmode(GPIO.BCM)
# 定义GPIO引脚
PWM_PIN = 12  # GPIO12(32号引脚)
# 设置GPIO引脚为输出模式
GPIO.setup(PWM_PIN, GPIO.OUT)
# 创建PWM实例,频率设置为50Hz(适用于大多数舵机)
pwm = GPIO.PWM(PWM_PIN, 50)
# 启动PWM,初始占空比为0(电机停止)
pwm.start(0)
# 定义函数:打开爪子
def open_claw():
    print("爪子已打开")
    pwm.ChangeDutyCycle(8)  # 8%占空比(打开)
    time.sleep(1)  # 等待1秒s

# 定义函数:闭合爪子
def close_claw():
    print("爪子已闭合")
    pwm.ChangeDutyCycle(5)  # 5%占空比(闭合)
    time.sleep(1)  # 等待1s

# 在起飞之前,打开爪子5秒,然后合上,等待3秒
print("起飞前操作:抓取物品")
open_claw()  # 打开爪子
print("爪子已打开,请在5s内放上物品")
time.sleep(5)  # 等待5秒
close_claw()  # 闭合爪子
print("闭合后等待3秒")
time.sleep(3)  # 等待3s


# 当前连接的 Pixhawk 飞控的端口
connection_string = '/dev/ttyUSB0'  # 现在使用的是 USB 转 TTL 接口,连接 Pixhawk 飞控
print('连接到设备: %s' % connection_string)
vehicle = connect('/dev/ttyUSB0', wait_ready=True, baud=57600) #降低波特率后成功

# 定义 arm_and_takeoff 函数,使无人机解锁并起飞到目标高度
# 参数 aTargetAltitude 即为目标高度,单位为米
def arm_and_takeoff(aTargetAltitude):
    # 起飞前检查
    print("进行起飞前检查")
    # vehicle.is_armable 会检查飞控是否启动完成
    while not vehicle.is_armable:
        print(" 等待设备初始化...")
        time.sleep(1)

    # 解锁无人机(电机将开始旋转)
    print("解锁电机")
    # 将无人机的飞行模式切换成 "GUIDED"(一般在 GUIDED 模式下控制无人机)
    vehicle.mode = VehicleMode("GUIDED")
    # 通过设置 vehicle.armed 状态变量为 True,解锁无人机
    vehicle.armed = True

    # 在无人机起飞之前,确认电机已经解锁
    while not vehicle.armed:
        print(" 等待解锁...")
        time.sleep(1)

    # 发送起飞指令
    print("起飞!")
    # simple_takeoff 将发送指令,使无人机起飞并上升到目标高度
    vehicle.simple_takeoff(aTargetAltitude)

    # 在无人机上升到目标高度之前,阻塞程序
    while True:
        print(" 当前高度: ", vehicle.location.global_relative_frame.alt)
        # 当高度上升到目标高度的 0.95 倍时,即认为达到了目标高度,退出循环
        if vehicle.location.global_relative_frame.alt >= aTargetAltitude * 0.95:
            print("达到目标高度")
            break
        time.sleep(1)

# 调用上面声明的 arm_and_takeoff 函数,目标高度 3 米
arm_and_takeoff(2)

# 悬停 5 秒,并不断输出“正在悬停”和一些信息
# 这里是为了在悬停的时候输出信息才这么写。如果不需要输出信息,直接time.sleep(5)就可以
print("开始悬停")
start_time = time.time()
while time.time() - start_time < 5: 
    # 打印高度和完整GPS信息
    print(" 正在悬停,当前高度: ", vehicle.location.global_relative_frame.alt)
    print("当前模式:",vehicle.mode.name)
    print("当前GPS:", vehicle.location.global_frame)
    time.sleep(1)

# 发送 "降落" 指令
print("降落")
#这里根据需要选择降落的方式
# RTL模式,无人机会自动返回home点的正上方(RTL高度可以在地面站里更改),之后自动降落。但我不需要无人机返回航点,所以改用Land模式降落。
# vehicle.mode = VehicleMode("RTL")
vehicle.mode = VehicleMode("LAND")  # 直接降落

# 在降落过程中,不断输出当前高度
print("开始降落")
while vehicle.armed:  # 当无人机未降落完成时(电机仍在旋转)
    print(" 正在降落,当前高度: ", vehicle.location.global_relative_frame.alt)
    print("当前模式:",vehicle.mode.name)
    print("当前GPS:", vehicle.location.global_frame)
    time.sleep(1)

# 降落完成后,退出之前,打开爪子
print("降落完成,打开爪子")
open_claw()  # 打开爪子
time.sleep(1)  # 等待1秒,确保动作完成

# 退出之前,清除 vehicle 对象
print("关闭设备连接")
vehicle.close()

# 停止PWM并清理GPIO设置
pwm.stop()
GPIO.cleanup()
print("GPIO已清理")

代码中凡是涉及到GPIO、PWM、Claw相关的代码,都是与机械爪有关的,可以直接删掉。不影响无人机控制部分的使用。

move.py

#!/usr/bin/env python
# -*- coding: utf-8 -*-
from __future__ import print_function
import time
from dronekit import connect, VehicleMode, LocationGlobalRelative
import RPi.GPIO as GPIO
from pymavlink import mavutil 

# 设置GPIO模式为BCM
GPIO.setmode(GPIO.BCM)
# 定义GPIO引脚
PWM_PIN = 12  # GPIO12(32号引脚)
# 设置GPIO引脚为输出模式
GPIO.setup(PWM_PIN, GPIO.OUT)
# 创建PWM实例,频率设置为50Hz(适用于大多数舵机)
pwm = GPIO.PWM(PWM_PIN, 50)
# 启动PWM,初始占空比为0(电机停止)
pwm.start(0)

# 定义函数:打开爪子
def open_claw():
    print("爪子已打开,请在5s内放上物品")
    pwm.ChangeDutyCycle(8)  # 8%占空比(打开)
    time.sleep(1)  # 等待1秒,确保动作完成

# 定义函数:闭合爪子
def close_claw():
    print("爪子已闭合")
    pwm.ChangeDutyCycle(5)  # 5%占空比(闭合)
    time.sleep(1)  # 等待1秒,确保动作完成

# 在起飞之前,打开爪子5秒,然后合上爪子,等待3秒
print("起飞前操作:抓取物品")
open_claw()  # 打开爪子
time.sleep(5)  # 等待5秒
close_claw()  # 闭合爪子
print("等待3秒,开始连接设备")
time.sleep(3)  # 等待3秒


# 当前连接的 Pixhawk 飞控的端口
connection_string = '/dev/ttyUSB0'  # 现在使用的是 USB 转 TTL 接口,连接 Pixhawk 飞控
print('连接到设备: %s' % connection_string)
vehicle = connect('/dev/ttyUSB0', wait_ready=True, baud=57600) #降低波特率后成功


# 定义 arm_and_takeoff 函数,使无人机解锁并起飞到目标高度
# 参数 aTargetAltitude 即为目标高度,单位为米
def arm_and_takeoff(aTargetAltitude):
    # 起飞前检查
    print("进行起飞前检查")
    # vehicle.is_armable 会检查飞控是否启动完成
    while not vehicle.is_armable:
        print(" 等待设备初始化...")
        time.sleep(1)

    # 解锁无人机(电机将开始旋转)
    print("解锁电机")
    # 将无人机的飞行模式切换成 "GUIDED"(一般在 GUIDED 模式下控制无人机)
    vehicle.mode = VehicleMode("GUIDED")
    # 通过设置 vehicle.armed 状态变量为 True,解锁无人机
    vehicle.armed = True

    # 在无人机起飞之前,确认电机已经解锁
    while not vehicle.armed:
        print(" 等待解锁...")
        time.sleep(1)

    # 发送起飞指令
    print("起飞!")
    # simple_takeoff 将发送指令,使无人机起飞并上升到目标高度
    vehicle.simple_takeoff(aTargetAltitude)

    # 在无人机上升到目标高度之前,阻塞程序
    while True:
        print(" 当前高度: ", vehicle.location.global_relative_frame.alt)
        # 当高度上升到目标高度的 0.95 倍时,即认为达到了目标高度,退出循环
        if vehicle.location.global_relative_frame.alt >= aTargetAltitude * 0.95:
            print("达到目标高度")
            break
        time.sleep(1)

# 调用上面声明的 arm_and_takeoff 函数,目标高度 3 米
arm_and_takeoff(2)

# 悬停 5 秒,并不断输出“正在悬停”和一些信息
# 这里是为了在悬停的时候输出信息才这么写。如果不需要输出信息,直接time.sleep(5)就可以
print("开始悬停")
start_time = time.time()
while time.time() - start_time < 5: 
    # 打印高度和完整GPS信息
    print(" 正在悬停,当前高度: ", vehicle.location.global_relative_frame.alt)
    print("当前模式:",vehicle.mode.name)
    time.sleep(1)

print("向左缓慢飞行")
left_speed = 0.5  # 设置向左飞行速度为0.5m/s
flight_time = 2    # 飞行时间4秒(0.5m/s × 4s = 2米)

# 获取起始位置
start_position = vehicle.location.global_relative_frame

# 发送向左速度指令
msg = vehicle.message_factory.set_position_target_local_ned_encode(
    0,       # 时间戳
    0, 0,    # 目标系统ID和目标组件ID
    mavutil.mavlink.MAV_FRAME_BODY_NED,  # 坐标系
    0b0000111111000111, # 控制速度的位掩码
    0, 0, 0, # 位置参数(忽略)
    0, -left_speed, 0, # 速度参数(X,Y,Z)- Y为负表示向左
    0, 0, 0, # 加速度参数(忽略)
    0, 0)    # 偏航参数(忽略)

# 发送指令并保持飞行状态
start_time = time.time()
while time.time() - start_time < flight_time:
    vehicle.send_mavlink(msg)
    vehicle.flush()
    print(" 正在向左飞行,当前高度: ", vehicle.location.global_relative_frame.alt)
    print("当前GPS:", vehicle.location.global_frame)
    time.sleep(0.1)

# 停止移动(发送零速度指令)
msg = vehicle.message_factory.set_position_target_local_ned_encode(
    0, 0, 0,
    mavutil.mavlink.MAV_FRAME_BODY_NED,
    0b0000111111000111,
    0, 0, 0,
    0, 0, 0,
    0, 0, 0,
    0, 0)
vehicle.send_mavlink(msg)
vehicle.flush()
print("向左飞行完成,准备降落")


# 发送 "降落" 指令
print("降落")
#这里根据需要选择降落的方式
# RTL模式,无人机会自动返回home点的正上方(RTL高度可以在地面站里更改),之后自动降落。但我不需要无人机返回航点,所以改用Land模式降落。
# vehicle.mode = VehicleMode("RTL")
vehicle.mode = VehicleMode("LAND")  # 直接降落

# 在降落过程中,不断输出当前高度
print("开始降落")
while vehicle.armed:  # 当无人机未降落完成时(电机仍在旋转)
    print(" 正在降落,当前高度: ", vehicle.location.global_relative_frame.alt)
    print("当前模式:",vehicle.mode.name)
    time.sleep(1)

# 降落完成后,退出之前,打开爪子
print("降落完成,打开爪子")
open_claw()  # 打开爪子
time.sleep(1)  # 等待1秒,确保动作完成

# 先停止PWM
pwm.stop()
# 然后清理GPIO设置
GPIO.cleanup()
print("GPIO已清理")

# 最后退出之前,清除 vehicle 对象
print("关闭设备连接")
vehicle.close()

十、SITL仿真

仿真环境的搭建还是耗了我不少时间的,所以扩展教程(5)和(6)两篇教程里配置环境的步骤我会重新在文章里写一遍

之前已经说过了,仿真环境是需要搭建在另一台电脑上的Ubuntu系统上。

教程里用的是16.04系统。

我最后在笔记本Vmware虚拟机里配置了18.04系统(18.04本身就够古老了)

双系统是在一台计算机上装两个操作系统,每次开机时选择一个操作系统,两个系统是平级的。

虚拟机是在一个操作系统上通过虚拟机软件(如Vmware)模拟出1台或N台计算机,每台计算机上都可以装一个系统。

Vmware虚拟机安装ubuntu系统的帖子网上的教程很多,流程并不复杂,没有什么困难点。

唯一要注意的是,安装好系统后,如果虚拟机和主机之前无法复制粘贴,可以参考这篇:

Vmware虚拟机和主机之间复制、粘贴内容、拖拽文件的详细方法_主机如何复制粘贴到vmware虚拟机上-CSDN博客

我一般都是用这篇最后的三条命令解决这个问题:

sudo apt-get autoremove open-vm-tools
sudo apt-get install open-vm-tools
sudo apt-get install open-vm-tools-desktop

以下没有特别说明,默认是在笔记本端的ubuntu系统进行操作。

搭建Ardupilot开发环境

Pixhawk无人机扩展教程(5)—SITL仿真模拟飞行:开发环境搭建

更新系统,安装git:

sudo apt-get update

sudo apt-get install git

sudo apt-get install gitk git-gui

印象中这三个命令都是可以顺利运行的。不顺利的话自己找下原因

git clone这一步:

git clone https://github.com/ArduPilot/ardupilot #github服务器在国外,不会魔法的还是老实使用下面的镜像站吧

git clone https://kkgithub.com/ArduPilot/ardupilot #使用这个命令

这里的github.com换成镜像站kkgithub.com。镜像站的下载会很慢,请耐心等待一下,有能力也可以选择科学上网。

进入ardupilot文件夹:

cd ardupilot

之后,按照教程原本是要用git submodule update --init --recursive这个命令的

git clone那一步只是下载了仓库,还需要通过submodule 把module里的一些模块给下载下来。

但是我下载的时候总是下载不全,有时候提示下载完了,但是点进modules文件夹里,发现里面好多文件夹是空的。

查阅了很多资料,试了很多方法,最后成功的方法依然是换源。

以下是换源步骤:

首先在ardupilot文件夹下,用ls -a 查看所有文件,其中有一个.gitmodules文件

我们用vim编辑器打开这个文件:

vim .gitmodules

把文件里面所有的github.com换成kkgithub.com,然后保存退出。

输入:

git submodule sync

因为少输了这一句我卡了两天…

此时,镜像站已经更换完成。我们可以回到正常方式下载模块了:

git submodule update --init --recursive

完毕后点进modules文件夹,里面文件夹一个一个查看,发现全部下载成功。

接下来就按照教程,依次输入这几句就可以:

chmod +x Tools/environment_install/install-prereqs-ubuntu.sh
    
Tools/environment_install/install-prereqs-ubuntu.sh -y
    
. ~/.profile

到此环境配置成功了。

对于教程里接下来提到的例子,说实话我没明白它的作用,但还是把命令放上来:

cd ardupilot

./waf configure--board Pixhawk1

./waf copter

印象中我一开始以为我的飞控是pixhwak4,所以对pixhwak4也编译过一次,反而没有针对pixhawk2.4.8进行编译。但是可以正常使用。

启动仿真环境

Pixhawk无人机扩展教程(6)—启动SITL+MAVProxy

首先进入ArduCopter目录:

cd ardupilot/ArduCopter

接下来,教程里直接在ArduCopter目录下输入sim_vehicle.py -w(第一次仿真的时候一般先输入这个命令,初始化一些设置)

但是实际上这个文件挪到别的文件夹去了,所以在ArduCopter目录下应当输入的是:

../Tools/autotest/sim_vehicle.py -w

正式仿真的时候,运行的是下面的命令:

../Tools/autotest/sim_vehicle.py --console --map

正常情况下会弹出一个terminal,一个console,和一个map

console和map没有弹出来?正常。

在一堆输出里面我找到了一些信息:

Failed to load module: No module named 'console'. Use 'set moddebug 3' in the MAVProxy console to enable traceback
Failed to load module: No module named 'map'. Use 'set moddebug 3' in the MAVProxy console to enable traceback

言下之意就是这两个模块加载不出来。

教程里面给出的解决方法是这个:

sudo -H pip2 install --upgrade MAVProxy pymavlink future lxml

但是运行后,问题并没有解决

看下面这个帖子最终解决了

Pixhawk无人机-ArduPilot 软件SITL仿真模拟飞行(SITL+MAVProxy)_sitl仿真找不到’mavproxy.exe-CSDN博客

我是先试了解决方法二,没用,卡了好几天,回过头来又找到这个帖子,试了下解决方法一,最后成功了。

除了上述console和map模块的两个failed信息之外,我记得当时上面一行还有一行warning,言下之意是要卸载一个什么manager。当时网上搜了一下,反正最后sudo uninstall掉了。


### 连接树莓派运行仿真

再放一次自己录的演示视频:(F450+Dronekit)SITL + MavProxy 仿真演示

这里主要做两件事:

1、在笔记本端,启动仿真后,把树莓派的IP接口加进去

教程里的做法是使用output add命令增加树莓派IP接口。提醒一下,添加接口是每一次重启系统后都要重新做的。

但是有时候仿真启动后,需要等半天才能输入output add命令,不想等的话可以使用这个命令,将启动仿真+添加接口一次性完成:

# 记得把命令里的ip改成自己的树莓派的ip
# 冒号是英文冒号,不要打成中文冒号
../Tools/autotest/sim_vehicle.py -v ArduCopter --console --map --out=udp:192.168.2.239:14550

2、在树莓派端,运行仿真代码

其中仿真代码与实际代码相比,仅仅只是三行有改变而已。

左为hover.py代码示例,右边为配套的hover_sitl.py代码示例

connection_string = '192.168.2.239:14550'  # 这里的ip地址记得改为你的树莓派的地址
print('连接到设备: %s' % connection_string)
vehicle = connect(connection_string, wait_ready=True)

树莓派运行仿真代码后,在笔记本端的仿真界面里就会出现相应的变化了。

十一、(openCV)Aruco二维码降落

Aruco二维码实现无人机降落是一个比较成熟的方案了,需要下载opencv库

扩展教程(9)里提供了下载openCV的方法,但它选择的是从源码编译安装,非常繁琐。

我没记错的话,我直接使用万能的sudo apt install就下载成功了,同时openCV下载好后自带Aruco模块,无需再额外下载Aruco。

下载好后到python代码里用一行import cv2测试一下,没报错就说明安装成功。


我最后的实现方案非常傻瓜,就是让无人机在空中根据二维码调整自身位置,对准后直接降落。实际测试能不能落到二维码上比较看运气。

Aruco二维码生成网站:Online ArUco markers generator

我用的是它默认的配置,可以根据需要自行更改:

字典选择4*4,ID选择0,size选择100


相机检测二维码camera_test.py:
import cv2
import numpy as np
import time

# 摄像头参数
CAMERA_DEVICE = "/dev/video0"
FRAME_WIDTH = 1920
FRAME_HEIGHT = 1200
FPS = 30

# ArUco参数
DICTIONARY = cv2.aruco.DICT_4X4_50
MARKER_ID = 0

# 初始化摄像头
cap = cv2.VideoCapture(CAMERA_DEVICE)
if not cap.isOpened():
    print(f"无法打开摄像头 {CAMERA_DEVICE}!")
    exit()

cap.set(cv2.CAP_PROP_FRAME_WIDTH, FRAME_WIDTH)
cap.set(cv2.CAP_PROP_FRAME_HEIGHT, FRAME_HEIGHT)
cap.set(cv2.CAP_PROP_FPS, FPS)

# ArUco初始化
aruco_dict = cv2.aruco.Dictionary_get(DICTIONARY)
parameters = cv2.aruco.DetectorParameters_create()

def get_frame_center(frame):
    h, w = frame.shape[:2]
    return (w // 2, h // 2)

# 主程序
try:
    last_detection_time = 0
    detection_interval = 2.5  # 检测间隔(秒)
    
    while True:
        ret, frame = cap.read()
        if not ret:
            print("摄像头读取失败!")
            break

        # 显示画面
        cv2.imshow("Camera View - 按ESC退出", frame)
        
        # 按固定间隔检测
        current_time = time.time()
        if current_time - last_detection_time >= detection_interval:
            last_detection_time = current_time
            
            # 检测ArUco标记
            corners, ids, _ = cv2.aruco.detectMarkers(frame, aruco_dict, parameters=parameters)
            
            if ids is not None and MARKER_ID in ids:
                idx = np.where(ids == MARKER_ID)[0][0]
                frame_center = get_frame_center(frame)
                marker_center = np.mean(corners[idx][0], axis=0).astype(int)
                
                offset_x = marker_center[0] - frame_center[0]
                offset_y = marker_center[1] - frame_center[1]

                # 输出调整指令
                if abs(offset_x) > 100:
                    print(f"[{time.strftime('%H:%M:%S')}] 向右移动" if offset_x > 0 else f"[{time.strftime('%H:%M:%S')}] 向左移动")
                if abs(offset_y) > 100:
                    print(f"[{time.strftime('%H:%M:%S')}] 向上移动" if offset_y < 0 else f"[{time.strftime('%H:%M:%S')}] 向下移动")
                if abs(offset_x) <= 100 and abs(offset_y) <= 100:
                    print(f"[{time.strftime('%H:%M:%S')}] 已居中,准备降落")
            else:
                print(f"[{time.strftime('%H:%M:%S')}] 未检测到标记")

        # 按ESC退出
        if cv2.waitKey(1) == 27:
            break

finally:
    # 确保资源被正确释放
    cap.release()
    cv2.destroyAllWindows()
    print("程序结束")

本文地址:https://www.vps345.com/9491.html

搜索文章

Tags

PV计算 带宽计算 流量带宽 服务器带宽 上行带宽 上行速率 什么是上行带宽? CC攻击 攻击怎么办 流量攻击 DDOS攻击 服务器被攻击怎么办 源IP docker 容器 运维 java-rabbitmq java 服务器安全 网络安全策略 防御服务器攻击 安全威胁和解决方案 程序员博客保护 数据保护 安全最佳实践 服务器 linux 游戏 云计算 网络工程师 网络管理 软考 2024 2024年上半年 下午真题 答案 Deepseek Deepseek-R1 大模型 私有化部署 推理模型 deepseek DeepSeek-R1 API接口 物联网 ubuntu DNS 英语 人工智能 redis Ollama Qwen2.5-coder 离线部署 c语言 RTSP xop RTP RTSPServer 推流 视频 YOLO conda pytorch vscode python yolov5 php 开发语言 macos windows 神经网络 深度学习 计算机视觉 卷积神经网络 ddos android 网络安全 web安全 CH340 单片机 嵌入式硬件 串口驱动 CH341 uart 485 django centos gcc centos 7 网络 tcp/ip 网络协议 ip协议 阿里云 llama 算法 opencv 自然语言处理 语言模型 ssh 网络结构图 部署 MCP 计算机外设 bug ai nlp javascript 前端 chrome edge Ubuntu 开发环境 进程 操作系统 进程控制 模型联网 API CherryStudio 经验分享 笔记 vue.js spring boot nginx https harmonyos 华为 数据库系统 pycharm ide 负载均衡 tomcat jvm 虚拟机 游戏引擎 学习 学习方法 mysql adb arm开发 架构 dify 数据库 oracle 关系型 安全 分布式 kubernetes prometheus grafana 云原生 mcu gnu virtualenv asm 策略模式 c++ node.js 高级IO epoll 知识库 本地化部署 后端 机器学习 ui fastapi mcp mcp-proxy mcp-inspector fastapi-mcp agent sse eureka debian PVE live555 rtsp rtp typescript 鸿蒙 word图片自动上传 word一键转存 复制word图片 复制word图文 复制word公式 粘贴word图文 粘贴word公式 USB转串口 fstab 自动化 ubuntu 18.04 安装教程 jellyfin nas ip apache 并查集 leetcode udp 本地环回 bind jenkins gitee 智能路由器 外网访问 内网穿透 端口映射 计算机网络 像素流送api 像素流送UE4 像素流送卡顿 像素流送并发支持 科技 个人开发 AI编程 xcode qt arm 持续部署 Doris搭建 docker搭建Doris Doris搭建过程 linux搭建Doris Doris搭建详细步骤 Doris部署 Linux PID Ubuntu20.04 GLIBC 2.35 集成学习 集成测试 LDAP Ubuntu DeepSeek DeepSeek Ubuntu DeepSeek 本地部署 DeepSeek 知识库 DeepSeek 私有化知识库 本地部署 DeepSeek DeepSeek 私有化部署 kylin spring ollama llm AI Dify C 环境变量 进程地址空间 opengl 多线程 运维开发 C# MQTTS 双向认证 emqx github pygame 大数据 spark hive vnc transformer uni-app Linux 维护模式 kafka 华为云 UEFI Legacy MBR GPT U盘安装操作系统 媒体 快捷键 旋转屏幕 自动操作 QT 5.12.12 QT开发环境 Ubuntu18.04 websocket 监控k8s集群 集群内prometheus pillow 进程优先级 调度队列 进程切换 ffmpeg 音视频 视频编解码 pip ssh漏洞 ssh9.9p2 CVE-2025-23419 数据分析 TCP WebServer yum docker-compose docker compose grub 版本升级 扩容 matplotlib fonts-noto-cjk perf AIGC 人工智能生成内容 cpu 内存 实时 使用 spring cloud AI大模型 大模型技术 本地部署大模型 dubbo 面试 json outlook 错误代码2603 无网络连接 2603 聚类 openvpn server openvpn配置教程 centos安装openvpn compose devops elasticsearch 安卓模拟器 mac windows 服务器安装 c# 课程设计 springsecurity6 oauth2 授权服务器 前后端分离 虚拟现实 JAVA Java EtherNet/IP串口网关 EIP转RS485 EIP转Modbus EtherNet/IP网关协议 EIP转RS485网关 EIP串口服务器 HarmonyOS Next ubuntu20.04 Linux 开机黑屏 maven svn 宝塔面板访问不了 宝塔面板网站访问不了 宝塔面板怎么配置网站能访问 宝塔面板配置ip访问 宝塔面板配置域名访问教程 宝塔面板配置教程 VMware ue4 着色器 ue5 虚幻 虚拟显示器 远程控制 目标跟踪 目标检测 OpenVINO 推理应用 cron crontab日志 数据结构 链表 思科 react.js 前端面试题 zotero WebDAV 同步失败 代理模式 git IM即时通讯 QQ 微信 企业微信 剪切板对通 HTML FORMAT 嵌入式 linux驱动开发 硬件架构 系统架构 eclipse 热榜 指令 产品经理 agi microsoft vim 进程信号 远程连接 rdp 实验 信息与通信 Kali Linux 黑客 渗透测试 信息收集 离线部署dify numpy open webui flutter Google pay Apple pay unix 华为od ragflow filezilla 无法连接服务器 连接被服务器拒绝 vsftpd 331/530 性能优化 k8s sql intellij idea visual studio code 编辑器 远程工作 GPU环境配置 Ubuntu22 CUDA PyTorch Anaconda安装 Cursor 创意 社区 bash ruoyi VMware创建虚拟机 gpu算力 webdav shell rpc vr notepad DevEco Studio ip命令 新增网卡 新增IP 启动网卡 DeepSeek 驱动开发 串口服务器 大模型入门 大模型教程 tcp hadoop 机器人 WSL2 Ubuntu22.04 虚拟化 开发人员主页 golang redhat stm32 sublime text 上传视频文件到服务器 uniApp本地上传视频并预览 uniapp移动端h5网页 uniapp微信小程序上传视频 uniapp app端视频上传 uniapp uview组件库 1024程序员节 VMware安装Ubuntu Ubuntu安装k8s ESP32 camera Arduino 电子信息 axure 富文本编辑器 WebUI DeepSeek V3 EtherCAT转Modbus ECT转Modbus协议 EtherCAT转485网关 ECT转Modbus串口网关 EtherCAT转485协议 ECT转Modbus网关 cursor rabbitmq chatgpt oneapi efficientVIT YOLOv8替换主干网络 TOLOv8 http Linux无人智慧超市 LInux多线程服务器 QT项目 LInux项目 单片机项目 pdf iot Agent LLM CrewAI deepseek-r1 大模型本地部署 ros 话题通信 服务通信 华为认证 交换机 开源 ssl 程序人生 网络药理学 生信 生物信息学 gromacs 分子动力学模拟 MD 动力学模拟 Hyper-V WinRM TrustedHosts 小程序 微信小程序域名配置 微信小程序服务器域名 微信小程序合法域名 小程序配置业务域名 微信小程序需要域名吗 微信小程序添加域名 rtsp服务器 rtsp server android rtsp服务 安卓rtsp服务器 移动端rtsp服务 大牛直播SDK ecmascript nextjs react reactjs flask oracle fusion oracle中间件 database vmware 卡死 vue3 HTML audio 控件组件 vue3 audio音乐播放器 Audio标签自定义样式默认 vue3播放音频文件音效音乐 自定义audio播放器样式 播放暂停调整声音大小下载文件 rancher remote-ssh 虚拟局域网 burp suite 抓包 压测 ECS 升级 CVE-2024-7347 漏洞 缓存 iftop 网络流量监控 powerpoint maxkb ARG Dell R750XS list odoo 服务器动作 Server action fork wait waitpid exit nftables 防火墙 温湿度数据上传到服务器 Arduino HTTP oceanbase 传统数据库升级 银行 Flask FastAPI Waitress Gunicorn uWSGI Uvicorn 多线程服务器 Linux网络编程 postman 测试工具 aws MacOS录屏软件 python2 ubuntu24.04 java-ee rust 私有化 本地部署 实时音视频 实时互动 Trae IDE AI 原生集成开发环境 Trae AI 电脑 硬件工程 嵌入式实习 深度求索 私域 linux内核 html Cline wsl 浪潮信息 AI服务器 主从复制 etcd 数据安全 RBAC CPU 主板 电源 网卡 命令 IIS .net core Hosting Bundle .NET Framework vs2022 报错 SRS 流媒体 直播 intellij-idea lvm 磁盘挂载 磁盘分区 dell服务器 gateway Clion Nova ResharperC++引擎 Centos7 远程开发 GaN HEMT 氮化镓 单粒子烧毁 辐射损伤 辐照效应 .netcore openEuler 灵办AI 区块链 软件需求 vite 云电竞 云电脑 todesk protobuf 序列化和反序列化 安装 elk AI-native Docker Desktop Alexnet TrueLicense C语言 rust腐蚀 milvus 前端框架 游戏程序 ios centos-root /dev/mapper yum clean all df -h / du -sh jupyter 读写锁 多层架构 解耦 vSphere vCenter 软件定义数据中心 sddc 腾讯云 3d 数学建模 计算生物学 生物信息 基因组 互信 微信分享 Image wxopensdk 大语言模型 LLMs audio vue音乐播放器 vue播放音频文件 Audio音频播放器自定义样式 播放暂停进度条音量调节快进快退 自定义audio覆盖默认样式 国产数据库 瀚高数据库 数据迁移 下载安装 jmeter 软件测试 stm32项目 ocr 软件工程 软件构建 VMware安装mocOS macOS系统安装 onlyoffice gitlab unity MacMini Mac 迷你主机 mini Apple 网易邮箱大师 sqlserver 云服务 Ubuntu共享文件夹 共享目录 Linux共享文件夹 OpenManus cuda 版本 个人博客 浏览器自动化 Samba NAS .net 微信小程序 miniapp 真机调试 调试 debug 断点 网络API请求调试方法 AI写作 程序员创富 CLion ros1 Noetic 20.04 apt 安装 云桌面 微软 AD域控 证书服务器 visual studio 命名管道 客户端与服务端通信 CentOS 豆瓣 追剧助手 迅雷 ollama下载加速 unity3d 银河麒麟 kylin v10 麒麟 v10 DigitalOcean GPU服务器购买 GPU服务器哪里有 GPU服务器 王者荣耀 端口号 开放端口 访问列表 top Linux top top命令详解 top命令重点 top常用参数 postgresql springboot 设置代理 实用教程 远程 执行 sshpass 操作 rag 大模型部署 ux 代码调试 ipdb 大文件分片上传断点续传及进度条 如何批量上传超大文件并显示进度 axios大文件切片上传详细教 node服务器合并切片 vue3大文件上传报错提示错误 vu大文件秒传跨域报错cors DIFY GameFramework HybridCLR Unity编辑器扩展 自动化工具 权限 HCIE 数通 string模拟实现 深拷贝 浅拷贝 经典的string类问题 三个swap 压力测试 DevOps 软件交付 数据驱动 应用场景 minicom 串口调试工具 飞牛nas fnos MQTT协议 消息服务器 代码 高德地图 鸿蒙接入高德地图 HarmonyOS5.0 视觉检测 log4j 源码剖析 rtsp实现步骤 流媒体开发 n8n 工作流 linux环境变量 机柜 1U 2U Windsurf android studio IO netty 远程看看 远程协助 匿名管道 qps 高并发 直播推流 sqlite3 5G 3GPP 卫星通信 tar mq rocketmq Redis Desktop chatbox 系统 黑苹果 隐藏文件 隐藏目录 文件系统 管理器 通配符 GPU Linux的权限 flash-attention ansible jar gradle selenium alias unalias 别名 物联网开发 MQTT 正则表达式 系统安全 r语言 云耀服务器 C++ 统信UOS 麒麟 bonding 链路聚合 KylinV10 麒麟操作系统 Vmware Docker Hub docker pull 镜像源 daemon.json 执法记录仪 智能安全帽 smarteye IPMI NFS 监控k8s 监控kubernetes 智慧农业 开源鸿蒙 团队开发 kind 磁盘清理 WLAN 僵尸进程 ebpf uprobe 无人机 HP Anyware 智能手机 systemctl ci/cd composer SSH Xterminal iBMC UltraISO windows日志 爬虫 数据集 Hive环境搭建 hive3环境 Hive远程模式 retry 重试机制 zip unzip GCC aarch64 编译安装 HPC 基础环境 网络爬虫 自动化运维 流水线 脚本式流水线 frp 程序员 gpt 智能体 autogen openai coze edge浏览器 rime ESXi 磁盘监控 内网渗透 靶机渗透 大模型微调 WSL2 上安装 Ubuntu go c c/c++ 串口 MS Materials ArkTs ArkUI 进程程序替换 execl函数 execv函数 execvp函数 execvpe函数 putenv函数 file server http server web server linux上传下载 状态管理的 UDP 服务器 Arduino RTOS JDK LInux Windows 软链接 硬链接 harmonyOS面试题 模拟实现 硅基流动 ChatBox 自动化编程 openwrt threejs 3D okhttp 镜像下载 freebsd RAGFLOW Mac内存不够用怎么办 回显服务器 UDP的API使用 ros2 moveit 机器人运动 交互 armbian u-boot UOS 统信操作系统 嵌入式系统开发 LLM Web APP Streamlit ai小智 语音助手 ai小智配网 ai小智教程 智能硬件 esp32语音助手 diy语音助手 selete mybatis burpsuite 安全工具 mac安全工具 burp安装教程 渗透工具 WSL win11 无法解析服务器的名称或地址 copilot llama3 Chatglm 开源大模型 搜索引擎 全文检索 图搜索算法 环境配置 通信工程 毕业 CosyVoice Mermaid 可视化图表 自动化生成 wireshark 显示过滤器 ICMP Wireshark安装 RustDesk自建服务器 rustdesk服务器 docker rustdesk 低代码 Cookie 数据挖掘 网络用户购物行为分析可视化平台 大数据毕业设计 su sudo mock mock server 模拟服务器 mock服务器 Postman内置变量 Postman随机数据 统信 实战案例 迁移指南 ROS PX4 MAVROS 四旋翼无人机 SWAT 配置文件 服务管理 网络共享 vscode1.86 1.86版本 ssh远程连接 远程桌面 webrtc Docker Compose 路径解析 IIS服务器 IIS性能 日志监控 工具 服务器扩容没有扩容成功 openstack Xen KVM VSCode vmamba 高效I/O 键盘 playbook 剧本 FTP 服务器 一切皆文件 nac 802.1 portal ipython nohup 异步执行 视频平台 录像 视频转发 性能测试 视频流 存储 jdk 矩阵 TRAE 工业4.0 程序 编程 性能分析 信号 内核 KingBase YOLOv8 NPU Atlas800 A300I pro asi_bench 显示器 curl wget 客户端 博客 windwos防火墙 defender防火墙 win防火墙白名单 防火墙白名单效果 防火墙只允许指定应用上网 防火墙允许指定上网其它禁止 clickhouse 安装MySQL 政务 分布式系统 监控运维 Prometheus Grafana 图像处理 自动驾驶 yaml Ultralytics 可视化 v10 软件 bcompare Beyond Compare nvm matlab mount挂载磁盘 wrong fs type LVM挂载磁盘 Centos7.9 远程服务 VMware Tools vmware tools安装 vmwaretools安装步骤 vmwaretools安装失败 vmware tool安装步骤 vm tools安装步骤 vm tools安装后不能拖 vmware tools安装步骤 express p2p 大模型应用 CPU 使用率 系统监控工具 linux 命令 tcpdump Kylin-Server 国产操作系统 服务器安装 kali 共享文件夹 7z x64 SIGSEGV SSE xmm0 seatunnel 腾讯云大模型知识引擎 Web服务器 多线程下载工具 网络编程 PYTHON iperf3 带宽测试 dns SSH 密钥生成 SSH 公钥 私钥 生成 googlecloud linux安装配置 Linux的基础指令 Python glibc 安卓 docker搭建pg docker搭建pgsql pg授权 postgresql使用 postgresql搭建 中兴光猫 换光猫 网络桥接 自己换光猫 云原生开发 K8S k8s管理系统 zabbix mariadb 开发 fpga开发 docker搭建nacos详解 docker部署nacos docker安装nacos 腾讯云搭建nacos centos7搭建nacos 鸿蒙系统 毕设 html5 firefox kamailio sip VoIP 大数据平台 YOLOv12 ubuntu24.04.1 HiCar CarLife+ CarPlay QT RK3588 webstorm rc.local 开机自启 systemd Termux npm Mac软件 Chatbox Invalid Host allowedHosts vue 功能测试 自动化测试 强制清理 强制删除 mac废纸篓 firewalld ping++ 宝塔面板无法访问 大屏端 xml shell脚本免交互 expect linux免交互 samba 鲲鹏 昇腾 npu Portainer搭建 Portainer使用 Portainer使用详解 Portainer详解 Portainer portainer MCP server C/S mongodb 计算机系统 ragflow 源码启动 sysctl.conf vm.nr_hugepages Reactor 设计模式 中间件 iis 移动云 安防软件 宠物 毕业设计 免费学习 宠物领养 宠物平台 cudnn anaconda 微服务 springcloud H3C 沙盒 HarmonyOS NEXT 原生鸿蒙 SSL 域名 skynet Docker Kubernetes 相机 代码规范 服务器数据恢复 数据恢复 存储数据恢复 raid5数据恢复 磁盘阵列数据恢复 embedding DeepSeek r1 Open WebUI 高效远程协作 TrustViewer体验 跨设备操作便利 智能远程控制 cd 目录切换 银河麒麟操作系统 国产化 wsgiref Web 服务器网关接口 nfs 服务器部署ai模型 计算机 系统开发 binder 车载系统 framework 源码环境 NLP模型 NLP 单例模式 安全架构 安全威胁分析 Kylin OS 蓝桥杯 java-rocketmq 机架式服务器 1U工控机 国产工控机 Jellyfin 宝塔面板 同步 备份 建站 LORA apt 国内源 uv ELF加载 Netty VR手套 数据手套 动捕手套 动捕数据手套 tensorflow 监控 图形化界面 黑客技术 xpath定位元素 URL bat 输入法 api 服务器繁忙 本地部署AI大模型 av1 电视盒子 机顶盒ROM 魔百盒刷机 pyqt 源代码 跨域 内网环境 HarmonyOS Tabs组件 TabContent TabBar TabsController 导航页签栏 滚动导航栏 neo4j 数据仓库 数据库开发 数据库架构 linux 命令 sed 命令 华为OD 华为OD机试真题 可以组成网络的服务器 RoboVLM 通用机器人策略 VLA设计哲学 vlm fot robot 视觉语言动作模型 具身智能 大文件秒传跨域报错cors cpp-httplib 网工 服务器主板 AI芯片 keepalived MI300x sonoma 自动更新 CORS css less 硬件 设备 PCI-Express iphone SSH 服务 SSH Server OpenSSH Server chrome devtools chromedriver vasp安装 ROS2 消息队列 k8s部署 MySQL8.0 高可用集群(1主2从) AutoDL 自动化任务管理 ArcTS 登录 ArcUI GridItem 职场和发展 arkUI 命令行 基础入门 游戏服务器 TrinityCore 魔兽世界 CentOS Stream prompt easyui langchain js code-server SVN Server tortoise svn 群晖 文件分享 pppoe radius 推荐算法 fd 文件描述符 蓝耘科技 元生代平台工作流 ComfyUI Docker快速入门 NPS 雨云服务器 雨云 stable diffusion 能力提升 面试宝典 技术 IT信息化 db yum源切换 更换国内yum源 高效日志打印 串口通信日志 服务器日志 系统状态监控日志 异常记录日志 grep echarts 信息可视化 网页设计 ftp服务 文件上传 Xinference RAGFlow saltstack 相差8小时 UTC 时间 arcgis Qualcomm WoS QNN AppBuilder web3.py OpenHarmony 远程过程调用 Windows环境 文心一言 docker命令大全 其他 DocFlow 虚拟机安装 三级等保 服务器审计日志备份 ubuntu24 vivado24 图形渲染 数据可视化 minio 小游戏 五子棋 免费域名 域名解析 risc-v sdkman 边缘计算 EMQX 通信协议 向日葵 React Next.js 开源框架 联想开天P90Z装win10 termux 环境搭建 nvidia 加解密 Yakit yaklang rclone AList fnOS bootstrap 跨平台 ShapeFile GeoJSON Nginx 影刀 #影刀RPA# 小番茄C盘清理 便捷易用C盘清理工具 小番茄C盘清理的优势尽显何处? 教你深度体验小番茄C盘清理 C盘变红?!不知所措? C盘瘦身后电脑会发生什么变化? RTMP 应用层 mysql离线安装 ubuntu22.04 mysql8.0 源码 宕机切换 服务器宕机 混合开发 环境安装 数码 联机 僵尸毁灭工程 游戏联机 开服 考研 在线office etl idm 京东云 adobe pyicu 实习 es6 qt6.3 g726 大模型面经 大模型学习 webgl Minecraft opcua opcda KEPServer安装 AnythingLLM AnythingLLM安装 safari DOIT 四博智联 Linux权限 权限命令 特殊权限 数据管理 数据治理 数据编织 数据虚拟化 历史版本 下载 rpa iDRAC R720xd 域名服务 DHCP 符号链接 配置 ufw powerbi Ubuntu 22.04 MySql 算家云 算力租赁 chrome 浏览器下载 chrome 下载安装 谷歌浏览器下载 树莓派 VNC 可信计算技术 密码学 kvm qemu libvirt AD域 thingsboard WebVM 测试用例 金仓数据库 2025 征文 数据库平替用金仓 can 线程池 rsyslog 考试 日志分析 系统取证 scapy Ardupilot 自定义客户端 SAS dba 大版本升 升级Ubuntu系统 电视剧收视率分析与可视化平台 Isaac Sim 虚拟仿真 XFS xfs文件系统损坏 I_O error visualstudio ssh远程登录 FunASR ASR cnn 邮件APP 免费软件 支付 微信支付 开放平台 virtualbox VPN wireguard openssl X11 Xming Office Ubuntu Server Ubuntu 22.04.5 信号处理 web 智能电视 飞牛NAS 飞牛OS MacBook Pro 教程 Maven 用户缓冲区 论文阅读 Spring Security EasyConnect AP配网 AK配网 小程序AP配网和AK配网教程 WIFI设备配网小程序UDP开 openjdk SenseVoice wps Linux24.04 deepin AimRT k8s集群资源管理 流式接口 export env 变量 docker run 数据卷挂载 交互模式 Wi-Fi Kali 渗透 软件卸载 系统清理 SysBench 基准测试 esp32 蓝牙 网络攻击模型 技能大赛 scikit-learn 框架搭建 css3 yolov8 ssrf 失效的访问控制 cmake MNN Qwen SSL证书 华为证书 HarmonyOS认证 华为证书考试 ftp telnet 远程登录 MobaXterm 文件传输 kernel 深度优先 图论 并集查找 换根法 树上倍增 语音识别 dity make make命令 makefile文件 eNSP 网络规划 VLAN 企业网络 Xshell xrdp 镜像 Dell HPE 联想 浪潮 图文教程 VMware虚拟机 macOS系统安装教程 macOS最新版 虚拟机安装macOS Sequoia k8s资源监控 annotations自动化 自动化监控 监控service 监控jvm Linux Vim 即时通信 NIO searxng Docker引擎已经停止 Docker无法使用 WSL进度一直是0 镜像加速地址 trea idea gaussdb import save load 迁移镜像 llama.cpp ajax 环境迁移 asp.net大文件上传 asp.net大文件上传源码 ASP.NET断点续传 asp.net上传文件夹 asp.net上传大文件 .net core断点续传 .net mvc断点续传 cfssl AI作画 CUPS 打印机 Qt5 拓扑图 宝塔 产测工具框架 IMX6ULL 管理框架 磁盘 空间 查错 dash 思科模拟器 Cisco nuxt3 firewall Attention 服务器管理 配置教程 网站管理 Playwright gitea 微信公众平台 muduo P2P HDLC Typore 飞牛 mamba Vmamba HistoryServer Spark YARN jobhistory 实时内核 健康医疗 互联网医院 银河麒麟服务器操作系统 系统激活 双系统 kotlin python3.11 算力 社交电子 RAID RAID技术 Socket RAG 检索增强生成 文档解析 大模型垂直应用 sudo原理 su切换 代理服务器 显示管理器 lightdm gdm iTerm2 终端 模拟器 vscode 1.86 网站搭建 serv00 ceph 服务器部署 本地拉取打包 直流充电桩 充电桩 微信开放平台 微信公众号配置 AI代码编辑器 deep learning Linux awk awk函数 awk结构 awk内置变量 awk参数 awk脚本 awk详解 lb 协议 服务器时间 chfs ubuntu 16.04 医疗APP开发 app开发 强化学习 显卡驱动 Webserver 异步 CNNs 图像分类 NAT转发 NAT Server Reactor反应堆 网络穿透 云服务器 交叉编译 Nuxt.js linuxdeployqt 打包部署程序 appimagetool gpt-3 lighttpd安装 Ubuntu配置 Windows安装 服务器优化 conda配置 conda镜像源 nacos 多产物 弹性计算 裸金属服务器 弹性裸金属服务器 banner 毕昇JDK 稳定性 看门狗 小智 致远OA OA服务器 服务器磁盘扩容 上传视频至服务器代码 vue3批量上传多个视频并预览 如何实现将本地视频上传到网页 element plu视频上传 ant design vue vue3本地上传视频及预览移除 容器技术 游戏机 序列化反序列化 jina IPv4 子网掩码 公网IP 私有IP 网络文件系统 rustdesk netlink libnl3 常用命令 文本命令 目录命令 金融 网卡的名称修改 eth0 ens33 线程 服务器无法访问 ip地址无法访问 无法访问宝塔面板 宝塔面板打不开 半虚拟化 硬件虚拟化 Hypervisor Web应用服务器 excel 服务器配置 行情服务器 股票交易 速度慢 切换 股票量化接口 股票API接口 micropython mqtt ruby 工具分享 ollama api ollama外网访问 业界资讯 端口测试 模拟退火算法 autoware 田俊楠 Linux find grep 单元测试 mosquitto GRUB引导 Linux技巧 桌面环境 springboot远程调试 java项目远程debug docker远程debug java项目远程调试 springboot远程 ArkTS 移动端开发 玩游戏 换源 Debian pyside6 界面 umeditor粘贴word ueditor粘贴word ueditor复制word ueditor上传word图片 ueditor导入word ueditor导入pdf ueditor导入ppt AISphereButler hibernate lio-sam SLAM NVML nvidia-smi Linux环境 UDP diskgenius 联网 easyconnect 代理 Obsidian Dataview 代码托管服务 生活 FTP服务器 自学笔记 小米 澎湃OS Android wsl2 Carla 智能驾驶 Java Applet URL操作 服务器建立 Socket编程 网络文件读取 多进程 trae Node-Red 编程工具 流编程 ukui 麒麟kylinos openeuler W5500 OLED u8g2 TCP服务器 rnn Pyppeteer fast 火绒安全 VPS workflow 图片增强 增强数据 beautifulsoup asp.net大文件上传下载 办公自动化 pdf教程 OD机试真题 服务器能耗统计 DeepSeek行业应用 Heroku 网站部署 big data opensearch helm 分析解读 WebRTC uniapp 恒源云 Ark-TS语言 终端工具 远程工具 聊天服务器 套接字 智能音箱 智能家居 IPMITOOL BMC 硬件管理 pyautogui cmos ShenTong DBeaver next.js 部署next.js 开机自启动 大模型训练/推理 推理问题 mindie 繁忙 解决办法 替代网站 汇总推荐 AI推理 CDN token sas 小艺 Pura X bot sublime text3 重启 排查 系统重启 日志 原因 抓包工具 System V共享内存 进程通信 Anolis nginx安装 linux插件下载 根服务器 语法 zookeeper junit qt5 客户端开发 知识图谱 网络建设与运维 分布式账本 web3 智能合约 信任链 共识算法 ai工具 阿里云ECS ldap 用户管理 docker desktop image h.264 需求分析 规格说明书 支持向量机 项目部署到linux服务器 项目部署过程 机械臂 架构与原理 安全漏洞 信息安全 open Euler dde 阻塞队列 生产者消费者模型 服务器崩坏原因 kubeless word gunicorn 反向代理 crosstool-ng post.io 企业邮箱 搭建邮箱 react native MDK 嵌入式开发工具 论文笔记 管道 显卡驱动持久化 GPU持久化 xshell termius iterm2 docker部署翻译组件 docker部署deepl docker搭建deepl java对接deepl 翻译组件使用 冯诺依曼体系 企业网络规划 华为eNSP 服务网格 istio zerotier Unity Dedicated Server Host Client 无头主机 Qwen3 qwen3 32b vllm SystemV 大模型压力测试 EvalScope 锁屏不生效 GeneCards OMIM TTD wpf 崖山数据库 YashanDB 合成模型 扩散模型 图像生成 client-go k8s二次开发 Echarts图表 折线图 柱状图 异步动态数据 鸿蒙开发 可视化效果 midjourney 信创 信创终端 中科方德 商用密码产品体系 sentinel 搭建个人相关服务器 移动开发 佛山戴尔服务器维修 佛山三水服务器维修 捆绑 链接 谷歌浏览器 youtube google gmail swoole wordpress 无法访问wordpess后台 打开网站页面错乱 linux宝塔面板 wordpress更换服务器 laravel 无桌面 做raid 装系统 Radius lsb_release /etc/issue /proc/version uname -r 查看ubuntu版本 VM搭建win2012 win2012应急响应靶机搭建 攻击者获取服务器权限 上传wakaung病毒 应急响应并溯源 挖矿病毒处置 应急响应综合性靶场 怎么卸载MySQL MySQL怎么卸载干净 MySQL卸载重新安装教程 MySQL5.7卸载 Linux卸载MySQL8.0 如何卸载MySQL教程 MySQL卸载与安装 glm4 perl prometheus数据采集 prometheus数据模型 prometheus特点 pthread 干货分享 黑客工具 密码爆破 孤岛惊魂4 录音麦克风权限判断检测 录音功能 录音文件mp3播放 小程序实现录音及播放功能 RecorderManager 解决录音报错播放没声音问题 tailscale derp derper 中转 autodl webpack triton 模型分析 线性代数 电商平台 docker部署Python 流量运营 mysql安装报错 windows拒绝安装 Helm k8s集群 Python基础 Python教程 Python技巧 regedit 开机启动 IDEA docker search 欧标 OCPP 软件开发 IP 地址 lua 单一职责原则 vue-i18n 国际化多语言 vue2中英文切换详细教程 如何动态加载i18n语言包 把语言json放到服务器调用 前端调用api获取语言配置文件 Claude java-zookeeper IMM MAC SecureCRT 玩机技巧 软件分享 软件图标 LVM lvresize 磁盘扩容 pvcreate ECT转485串口服务器 ECT转Modbus485协议 ECT转Modbus串口服务器 音乐库 DenseNet 源代码管理 figma 笔灵AI AI工具 IO模型 增强现实 沉浸式体验 技术实现 案例分析 AR 智能体开发 GoogLeNet iventoy VmWare OpenEuler IPv4/IPv6双栈 双栈技术 网路规划设计 ensp综合实验 IPv4过渡IPv6 IPv4与IPv6 vpn 开源软件 僵尸世界大战 游戏服务器搭建 es 虚幻引擎 GIS 遥感 WebGIS 蓝桥杯C++组 MacOS c/s 问题解决 uni-file-picker 拍摄从相册选择 uni.uploadFile H5上传图片 微信小程序上传图片 移动魔百盒 USB网络共享 多个客户端访问 IO多路复用 TCP相关API 技术共享 cocoapods 我的世界 我的世界联机 macbook 浏览器开发 AI浏览器 IP配置 netplan 我的世界服务器搭建 initramfs Linux内核 Grub Sealos 烟花代码 烟花 元旦 jetty undertow deepseek r1 性能调优 安全代理 本地知识库部署 DeepSeek R1 模型 ISO镜像作为本地源 游戏开发 负载测试 进程间通信 Erlang OTP gen_server 热代码交换 事务语义 动静态库 网页服务器 web服务器 备份SQL Server数据库 数据库备份 傲梅企业备份网络版 minecraft 免密 公钥 私钥 磁盘镜像 服务器镜像 服务器实时复制 实时文件备份 网络搭建 神州数码 神州数码云平台 云平台 Ubuntu 24.04.1 轻量级服务器 win服务器架设 windows server hugo PPI String Cytoscape CytoHubba AI员工 dns是什么 如何设置电脑dns dns应该如何设置 kerberos Zoertier 内网组网 navicat 分布式训练 TCP协议 聊天室 抗锯齿 postgres Dify重启后重新初始化 localhost 券商 股票交易接口api 类型 特点 mac设置host 多路转接 AI agent deekseek qt项目 qt项目实战 qt教程 国标28181 视频监控 监控接入 语音广播 流程 SIP SDP nohup后台启动 状态模式 授时服务 北斗授时 Logstash 日志采集 对比 meld DiffMerge Charles NVM Node Yarn PM2 打不开xxx软件 无法检查其是否包含恶意软件 arkTs 项目部署 Qwen2.5-VL VS Code csrutil mac恢复模式进入方法 恢复模式 dock 加速 小智AI服务端 xiaozhi TTS proxy模式 AD 域管理 nosql SEO ecm bpm deepseak 豆包 KIMI 腾讯元宝 区块链项目 Apache Beam 批流统一 案例展示 数据分区 容错机制 rsync OpenSSH iNode Macos vsxsrv 7-zip 材料工程 嵌入式Linux IPC 软考设计师 中级设计师 SQL 软件设计师 EMUI 回退 降级 HTTP 服务器控制 ESP32 DeepSeek GPU训练 备选 网站 调用 示例 查询数据库服务IP地址 SQL Server 多端开发 智慧分发 应用生态 鸿蒙OS seleium EVE-NG xfce 计算机科学与技术 底层实现 卸载 列表 查看显卡进程 fuser ArtTS 弹性服务器 裸机装机 linux磁盘分区 裸机安装linux 裸机安装ubuntu 裸机安装kali 裸机 哈希算法 可执行程序 sqlite pgpool whistle 达梦 DM8 chromium dpi 电路仿真 multisim 硬件工程师 硬件工程师学习 电路图 电路分析 仪器仪表 csrf NVIDIA 银河麒麟高级服务器 外接硬盘 Kylin UOS1070e flink WINCC GRE 软负载 服务器ssl异常解决 新盘添加 partedUtil Alist mount 挂载 网盘 端口 查看 ss 超融合 星河版 deployment daemonset statefulset cronjob 内网服务器 内网代理 内网通信 hosts 数据采集 Crawlee g++ g++13 ranger MySQL8.0 银河麒麟桌面操作系统 在线预览 xlsx xls文件 在浏览器直接打开解析xls表格 前端实现vue3打开excel 文件地址url或接口文档流二进 飞书 Ubuntu 24 常用命令 Ubuntu 24 Ubuntu vi 异常处理 集群管理 shard IMX317 MIPI H265 VCU comfyui comfyui教程 llamafactory 微调 运维监控 可用性测试 XCC Lenovo 子系统 钉钉 分子对接 autodock mgltools PDB PubChem Trae叒更新了? 端口聚合 windows11 音乐服务器 Navidrome 音流 Headless Linux AzureDataStudio HAProxy RDP 大大通 第三代半导体 碳化硅 yashandb ardunio BLE 内存管理 paddle 搜狗输入法 中文输入法 接口优化 Claude Desktop Claude MCP Windows Cli MCP servlet 文件存储服务器组件 创业创新 resolv.conf IPv6 IPv6测试 IPv6测速 IPv6检测 IPv6查询 NFC 近场通讯 智能门锁 hdc tidb 解决方案 静态IP 火山引擎 mybase OpenCore 框架 linux子系统 忘记密码 sequoiaDB RK3568 EMC存储 NetApp存储 rtc 李心怡 Putty 花生壳 充电桩平台 充电桩开源平台 C++软件实战问题排查经验分享 0xfeeefeee 0xcdcdcdcd 动态库加载失败 程序启动失败 程序运行权限 标准用户权限与管理员权限 fiddler 桌面快捷方式 VGG网络 卷积层 池化层 qwen2vl yum换源 mvc 免费 solr 设备树 Unity插件 数字证书 签署证书 Bug解决 Qt platform OpenCV easyTier 组网 粘包问题 线程同步 线程互斥 条件变量 华为机试 带外管理 计算机学习路线 编程语言选择 massa sui aptos sei UFW 桥接模式 windows虚拟机 虚拟机联网 pycharm安装 服务器正确解析请求体 xss MVS 海康威视相机 输入系统 金仓数据库概述 金仓数据库的产品优化提案 photoshop brew watchtower 计算虚拟化 弹性裸金属 node 极限编程 hexo PyQt PySide6 ubuntu安装 linux入门小白 飞腾处理器 solidworks安装 物理地址 页表 虚拟地址 ABAP authing 配置原理 存储维护 Masshunter 质谱采集分析软件 使用教程 科研软件 macOS 海康 mm-wiki搭建 linux搭建mm-wiki mm-wiki搭建与使用 mm-wiki使用 mm-wiki详解 大模型推理 AI Agent 字节智能运维 网络原理 北亚数据恢复 oracle数据恢复 动态规划 西门子PLC 通讯 WireGuard 异地组网 风扇控制软件 程序化交易 量化交易 高频交易 Python 视频爬取教程 Python 视频爬取 Python 视频教程 Qt QModbus mcp服务器 client close 电脑桌面出现linux图标 电脑桌面linux图标删除不了 电脑桌面Liunx图标删不掉 linux图标删不掉 华为昇腾910b3 CAD瓦片化 栅格瓦片 矢量瓦片 Web可视化 DWG解析 金字塔模型 gru d3d12 logstash Linux的基础开发工具 百度云 矩池云 数据下载 数据传输 MinIO pythonai PlaywrightMCP 命令模式 设计规范 caddy vCenter服务器 ESXi主机 监控与管理 故障排除 日志记录 零售 VM虚拟机 华为鸿蒙系统 ArkTS语言 Component 生命周期 条件渲染 Image图片组件 鸿蒙NEXT 向量数据库 安装部署 milvus安装 脚本 跨域请求 Maxkb RAG技术 本地知识库 homeassistant finebi element-ui 上传视频并预览视频 vue上传本地视频及进度条功能 vue2选择视频上传到服务器 upload上传视频组件插件 批量上传视频 限制单个上传视频 STL lrzsz 三次握手 元服务 应用上架 vm archlinux kde plasma webview 知行EDI 电子数据交换 知行之桥 EDI AWS web开发 cpolar #STC8 #STM32 DrissionPage win向maOS迁移数据 android-studio 网络库 hosts文件管理工具 ACL 流量控制 基本ACL 规则配置 deepseek-v3 ktransformers 欧拉系统 finalsheel cocos2d 3dcoat PTrade QMT 量化股票 anythingllm open-webui docker国内镜像 进程池实现 匿名FTP 邮件传输代理 SSL支持 chroot监狱技术 GRANT REVOKE OS 接口返回 Github加速 Mac上Github加速 Chrome浏览器插件 bigdata qtcreator 数据库管理 aac Metastore Catalog