一个无人机平台+算法监督平台的离线部署指南

文档清单

表1 主应用清单

序号 名称 位置 IP 用途

表格内容隐藏
mqtt_for_airport.7z 机场、设备接入
FuyaAirportCenter.7z 机场对接
mongodb-org-server-4.2.3-1.el7.x86_64.rpm 数据库
ufss-enterprise.7z 无人机平台-业务模块
mqtt_ins_1.7z 内部通信
ins.7z Web客户端
nginx-http.7z Web静态容器
ufss-station.7z 无人机平台-算法管理模块
mqtt_uss_1.7z 内部通信
geoserver-2.14.0.7z.001 geoserver-2.14.0.7z.002 geoserver-2.14.0.7z.003 geoserver-2.14.0.7z.004GIS服务
Dependent.tar.gz Maps.tar.gz schedule.tar.gz 航线规划算法
视频web插件_V1.3.2_20190929.7z 视频播放插件

表2 第三方组件清单

序号 名称 位置 IP 用途

表格内容隐藏

表3端口列表

序号 端口 主机 开放策略 功能

表格内容隐藏

注意事项

(1)以下所有指令都以root权限执行;
(2)指令中涉及单引号的,注意务必输入单引号, 不能用双引号替代;
(3)如果某一项指令的结果与预期不符合,请停止指令输入,立即联系厂家;
(4)如果非实机操作,需要用到远程ssh工具, 例如xshell/xftp.
(5)进机房前需要把整个ufss文件夹拷入U盘, 以下操作都以U盘数据为前提

详细安装步骤

文件拷贝(所有主机)

目标主机: 所有
步骤:
首先切换到root账户,然后按顺序执行以下指令:
(1)创建用户:

groupadd russ useradd -g russ russ passwd **** 

输入密码, 例如alkdfjpoaewif123456
这样系统将自动创建/home/russ文件夹
(1)挂载U盘:

modprobe usb-storage fdisk -l 

(注意: 参数是小写的L, 不是数字1)
这一步需要根据显示结果找到U盘对应的卷标, 例如我的U盘空间32G,可以确定就是下图的/dev/sdb4:

如果是其它卷标, 那么以下指令中/dev/sdb4需要被替换为实际卷标

mkdir /mnt/usb mount /dev/sdb4 /mnt/usb 

(2)拷贝文件

mkdir /home/russ/file cp -R /mnt/usb/ufss /home/russ/file chown -R russ:russ /home/russ/file/* cd /home/russ/file/ufss umount /dev/sdb4 

安装基础组件(所有主机)

目标主机: 所有
(1)安装7zip

cd /home/russ/file/ufss tar -zxvf p7zip.tar.gz chmod +x 7z/bin/* mv 7z /usr/local echo -e '\nexport PATH=$PATH:.:/usr/local/7z/bin'>> /etc/profile exportPATH=$PATH:.:/usr/local/7z/bin 7za a 

出现以下结果表示安装成功:

在这里插入图片描述

(2)安装base

cd /home/russ/file/ufss 7za x base.7z cd base rpm -Uvh *.rpm --nodeps --force cd.. cmake --version 

出现以下结果表示安装成功:

在这里插入图片描述

(3)安装gcc-centos

cd /home/russ/file/ufss 7za x gcc-centos.7z cd gcc-centos rpm -Uvh *.rpm --nodeps --force cd.. gcc -v 

出现以下结果表示安装成功:

在这里插入图片描述

(4)安装java

cd /home/russ/file/ufss tar -zxvf jdk-8u241-linux-x64.tar.gz chmod +x jdk1.8.0_241/bin/* chmod +x jdk1.8.0_241/jre/bin/* chmod +x jdk1.8.0_241/lib/jexec mkdir /usr/local/java mv jdk1.8.0_241 /usr/local/java echo -e '\nexport JAVA_HOME=/usr/local/java/jdk1.8.0_241\nexport JRE_HOME=${JAVA_HOME}/jre\nexport CLASSPATH=.:${JAVA_HOME}/lib:${JRE_HOME}/lib\nexport PATH=$PATH:${JAVA_HOME}/bin'>> /etc/profile source /etc/profile java -version 

出现以下结果表示安装成功:

在这里插入图片描述

(5)安装python

cd /home/russ/file/ufss 7za x python3.7z chmod +x python3/bin/* chmod +x python3/lib/*.a chmod +x python3/lib/python3.7/*.py mv python3 /usr/local/ echo -e '\nexport PATH=/usr/local/python3/bin:$PATH\nexport LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/usr/local/lib64:/usr/local/lib:.:/usr/local/python3/lib\n'>> /etc/profile echo -e '\n/usr/local/python3/lib\n'>> /etc/ld.so.conf source /etc/profile ldconfig python3 -V 

出现以下结果表示安装成功:

在这里插入图片描述

安装机场对接服务(ip:xxx)

目标主机: xxx
步骤:
(1)安装并启动mqtt

cd /home/russ/file/ufss 7za x mqtt_for_airport.7z mv emqx2 /home/russ/emqx2 cd /home/russ/emqx2/bin chmod +x * ./emqx start netstat -anp |grep21883

看到如下图示表示启动成功:

在这里插入图片描述

(2)安装并启动机场对接服务

cd /home/russ/file/ufss 7za x FuyaAirportCenter.7z mv FuyaAirportCenter /home/russ cd /home/russ/FuyaAirportCenter chmod +x airport_center chmod +x *.sh ./start_airport_loop.sh &

启动成功后将会有相应日志输出, 或者直接到log文件夹查看日志

(3)配置开机启动

echo -e '\n\n/home/russ/emqx2/bin/startup.sh'>> /etc/rc.local echo -e '\n/home/russ/FuyaAirportCenter/start_airport_loop.sh &'>> /etc/rc.local chmod +x /etc/rc.local 

(4)开启防火墙

firewall-cmd --permanent --add-port=1883/tcp firewall-cmd --permanent --add-port=8083/tcp firewall-cmd --permanent --add-port=21883/tcp firewall-cmd --permanent --add-port=28083/tcp firewall-cmd --permanent --add-port=12345/tcp 

(5)日志说明
FuyaAirportCenter产生的日志在当前工作目录下log子目录, 每次运行将会产生一个日志文件.

3.4.安装无人机作业平台(ip:yyy)
目标主机: yyy
(1)安装内部通信组件

cd /home/russ/file/ufss 7za x mqtt_ins_1.7z mv emqx /home/russ/emqx cd /home/russ/emqx/bin chmod +x * ./emqx start netstat -anp |grep1883

看到如下图示表示启动成功:

在这里插入图片描述

(2)安装数据库

cd /home/russ/file/ufss rpm -ivh mongodb-org-server-4.2.3-1.el7.x86_64.rpm service mongod start netstat -anp |grep27017

如下图表示启动成功:

在这里插入图片描述

(3)安装无人机作业平台服务

cd /home/russ/file/ufss 7za x ufss-enterprise.7z mv ufss-enterprise /home/russ/ cd /home/russ/ufss-enterprise chmod +x ufss-enterprise.sh ./ufss-enterprise.sh netstat -anp |grep18196

如下图表示启动成功:

在这里插入图片描述

(4)安装客户端容器

cd /home/russ/file/ufss 7za x nginx-http.7z chmod +x nginx-http/sbin/* mv nginx-http /usr/local 

(5)安装客户端静态页面

cd /home/russ/file/ufss 7za x ins.7z mv ins /usr/local/nginx-http/html cd /usr/local/nginx-http chmod +x sbin/* ./sbin/nginx -c ./conf/nginx.conf netstat -anp |grep :80 

如下图表示启动成功:

在这里插入图片描述

(6)配置开机启动

echo -e '\n\n/home/russ/emqx/bin/startup.sh'>> /etc/rc.local echo -e '\nservice mongod start'>> /etc/rc.local echo -e '\n/home/russ/ufss-enterprise/ufss-enterprise.sh'>> /etc/rc.local echo -e '\n/usr/local/nginx-http/startup.sh'>> /etc/rc.local chmod +x /etc/rc.local 

(7)开启防火墙

firewall-cmd --permanent --add-port=1883/tcp firewall-cmd --permanent --add-port=8083/tcp firewall-cmd --permanent --add-port=18196/tcp firewall-cmd --permanent --add-port=80/tcp firewall-cmd --permanent --add-port=27017/tcp 

(8)日志说明
无人机平台ufss-enterprise产生的日志在当前工作目录下logs子目录, 日志文件名为enterprise.log. 超过24M后自动打包归档.

3.5.安装算法监管平台(ip:zzz)
目标主机: zzz
(1)安装内部通信组件

cd /home/russ/file/ufss 7za x mqtt_uss_1.7z mv emqx /home/russ/emqx cd /home/russ/emqx/bin chmod +x /home/russ/emqx/bin/* ./emqx start netstat -anp |grep1883

看到如下图示表示启动成功:

在这里插入图片描述

(2)安装算法监管平台服务

cd /home/russ/file/ufss 7za x ufss-station.7z mv ufss-station /home/russ/ cd /home/russ/ufss-station chmod +x ufss-station.sh ./ufss-station.sh netstat -anp |grep18190

如下图所示表示启动成功:

在这里插入图片描述

(3)配置开机启动

echo -e '\n\n/home/russ/emqx/bin/startup.sh'>> /etc/rc.local echo -e '\n/home/russ/ufss-station/ufss-station.sh'>> /etc/rc.local chmod +x /etc/rc.local 

(4)开启防火墙

firewall-cmd --permanent --add-port=1883/tcp firewall-cmd --permanent --add-port=8080/tcp firewall-cmd --permanent --add-port=18190/tcp 

(5)日志说明
无人机平台ufss-station产生的日志在当前工作目录下logs子目录, 日志文件名为station.log. 超过24M后自动打包归档.

算法与GIS安装(ip:zzz)

创建用户

groupadd uav
useradd -g uav uav
passwd ****
输入密码,例如asdfafeewaf2018

安装GIS服务平台

目标主机: zzz
步骤:

cd /home/russ/file/ufss 7za x geoserver-2.14.0.7z.001 rm -rf geoserver-2.14.0/bin/guardGis.sh cp guardGis.sh geoserver-2.14.0/bin/ chown -R uav:uav geoserver-2.14.0 chmod +x geoserver-2.14.0/bin/*.sh find -type f|xargschmod644 geoserver-2.14.0 find -type d|xargschmod755 geoserver-2.14.0 mv geoserver-2.14.0 /home/uav cd /home/uav/geoserver-2.14.0/bin/ ./guardGis.sh &netstat -anp |grep8080

如下图所示表示启动成功:

在这里插入图片描述

配置开机自启动:

echo -e '\n/home/uav/geoserver-2.14.0/bin/guardGis.sh &' >> /etc/rc.local chmod +x /etc/rc.local 

4.3.安装算法服务平台
目标主机: zzz
步骤:

cd /home/russ/file/ufss tar -zxvf Dependent.tar.gz tar -zxvf Maps.tar.gz tar -zxvf schedule.tar.gz mkdir /gis mv Maps /gis mv Dependent /home/uav chmod +x /home/uav/Dependent/gdal/bin/* chmod +x /home/uav/Dependent/OpenBLAS/bin/* echo -e '\nPATH=$PATH:/home/uav/Dependent/gdal/bin\n'>> /etc/profile echo -e '\nLD_LIBRARY_PATH=$LD_LIBRARY_PATH:/home/uav/Dependent/gdal/bin:/home/uav/Dependent/gdal/lib:/home/uav/Dependent/arma/usr/lib64:/home/uav/Dependent/OpenBLAS/lib\n'>> /etc/profile source /etc/profile gdalinfo --version echo -e '\n/usr/lib\n/usr/local/lib\n/home/uav/schedule/Audit\n/home/uav/schedule/Route\n/home/uav/schedule/RouteNet\n/home/uav/Dependent/OpenBLAS/lib\n/home/uav/Dependent/gdal/lib\n/home/uav/Dependent/arma/usr/lib64'>> /etc/ld.so.conf ldconfig mv schedule /home/uav cd /home/uav/schedule/Main chmod +x Traffic chmod +x guardSchedule.sh ./guardSchedule.sh &

出现如下控制台输出,则安装成功

在这里插入图片描述

配置开机自启动:

echo -e '\n/home/uav/schedule/Main/guardSchedule.sh &'>> /etc/rc.local chmod +x /etc/rc.local 

安全防护通用操作

防火墙

(1). 永久性开启和关闭防火墙. 重启后生效
开启:systemctl enable firewalld.service
关闭:systemctl disable firewalld.service

(2). 临时开启和关闭防火墙,重启后失效
开启:systemctl start firewalld
关闭:systemctl stop firewalld

(3).查看防火墙状态
firewall-cmd --state
(4).重启防火墙
systemctl restart firewalld
(5).开放一个端口, 例如80
firewall-cmd --permanent --add-port=80/tcp
开放多个端口, 例如10000~20000
firewall-cmd --permanent --add-port=10000-20000/tcp

(6).关闭一个端口, 例如80
firewall-cmd --permanent --remove-port=80/tcp
关闭多个端口, 例如10000~20000
firewall-cmd --permanent --remove-port=10000-20000/tcp

(7).查看端口开放情况
firewall-cmd --permanent --list-ports

5.2.selinux
(1). 永久性开启和关闭selinux. 重启后生效
开启:
echo 'SELINUX=enforcing\nSELINUXTYPE=targeted' > /etc/selinux/config
关闭:
echo 'SELINUX=disabled\nSELINUXTYPE=targeted' > /etc/selinux/config

(2). 临时开启和关闭selinux,重启后失效
开启:setenforce 1
关闭:setenforce 0

(3).查看selinux状态
getenforce
输出Enforcing表示运行中;输出Permissive表示已停止

Read more

大疆无人机常见故障提示及应对指南

大疆无人机常见故障提示及应对指南

大疆无人机在使用过程中,故障提示主要通过 DJI Fly/DJI GO 4 App 弹窗、机身指示灯状态及遥控器提示音三种方式呈现。以下按「连接通信类」「传感系统类」「动力系统类」「图传相机类」「电池电源类」五大核心场景,整理常见故障提示、核心原因及分步解决办法,帮助快速定位并处理问题。 北京云升智维科技有限责任公司是一家专业从事电子设备维修第三方服务企业,我们拥有深厚的电路原理知识和丰富的维修经验,能够为各种设备和电路板提供专业的检测和维修服务。我们的服务范围广泛,包括但不限于电路板、工控主板、工业机械、医疗设备、精密仪器、大地测量仪器及驱动器等。我们拥有一支技术过硬,经验丰富的维修团队,精通各类设备维修,结合多年实战维修经验,快速准确诊断故障,提高维修效率,为客户节省35%及以上维修成本及时间成本,我们致力于为客户提供高质量、可靠的服务,确保设备的稳定运行。我们坚持诚实守信、笃行致远的原则,以确保客户满意。 一、连接通信类故障提示 核心表现:App 提示连接异常,遥控器与无人机无法联动,

埃斯顿机器人快速入门

埃斯顿机器人快速入门

本文章适合有一定基础的人学习如:abb,发那科,库卡等这些主流的机器人,一些通用的知识点就不在这里过多描述,只讲一下不同的地方以便快速入门接手项目。 有一定基础!!! 有一定基础!!! 有一定基础!!! 目录 * 1.仿真软件Editor * 1.1下载Editor2.6.05 * 1.2官方最新版下载 * 2.界面介绍 * 3.IO配置 * 4.程序变量与语法 * 5.程序下载 1.仿真软件Editor 1.1下载Editor2.6.05 这个软件是埃斯顿机器人的仿真软件,适合在没有机器人前期准备程序及配置的时候使用。入门学习也非常合适,毕竟也不是一直有都有机会拿实机去练习的。 仿真软件可以选择在官网下载,但是在官网下载有点问题一开始我都找不到,使用我这里先给一个截止到这一篇文章发布前最新版的连接。点🐔下载!!! 1.2官方最新版下载 进入埃斯顿官网点击资料下载见面,你会发现哎嘿!你要搜索相关的手册或者安装包的名称才能下载,输错了就找不到了! 可以跟着我输入关键字:Editor 2.

【硬核实战】Mac mini M4 部署 OpenClaw + Ollama 本地大模型:从零到一打通飞书机器人

【硬核实战】Mac mini M4 部署 OpenClaw + Ollama 本地大模型:从零到一打通飞书机器人

文章目录 * 一、 核心环境准备 * 二、 避坑指南:环境初始化在 Mac 终端部署时,首要解决的是权限与路径问题。 * 1. 终端常用快捷键* `Control + C`:强制停止当前运行的命令(如安装卡死时)。 * 2. Node.js 环境修复若遇到 `zsh: command not found: openclaw`,说明 NVM 路径未加载。 * 3. 临时加载环境 * 4. 永久写入配置 * 三、 模型选择:M4 性能调优 * 四、 OpenClaw 配置手术 (JSON 详解) * 五、 飞书机器人接入:最后的临门一脚 * 六、 运行与调试 * 启动 Gateway * 第一次发消息需授权 (Pairing) * 💡 结语

飞书机器人实战:5分钟搞定图片消息发送(含常见报错解决方案)

飞书机器人实战:5分钟搞定图片消息发送(含常见报错解决方案) 你是否遇到过这样的场景:服务器监控系统捕捉到一个异常峰值,你希望它能自动将一张清晰的图表截图,直接推送到团队的飞书群里,而不是一封冰冷的邮件;或者,你的自动化日报系统生成了精美的数据可视化图片,你希望它能无缝地出现在每日的晨会通知中。对于许多开发者和运维工程师来说,将图片消息集成到自动化流程中,是一个能极大提升信息传达效率和体验的“刚需”。 飞书机器人提供了强大的消息推送能力,但初次接触其图片消息发送功能时,你可能会发现它比预想的要“曲折”一些——它不像发送文本那样直接丢一个图片链接就行,而是需要经过一个“上传-获取密钥-发送”的流程。这个过程里,权限配置、tenant_access_token获取、图片上传格式、image_key的使用,每一步都可能藏着一个小坑。别担心,这篇文章就是为你准备的“避坑指南”。我们将抛开官方文档那略显冰冷的步骤罗列,从一个实战者的角度,带你用大约5分钟的时间,彻底打通从零到一发送飞书图片消息的全链路,并重点剖析那些你可能马上就会遇到的报错及其根因解决方案。我们的目标是:让你看完就能用,用了