• Modbus-RTU详解

Modbus-RTU详解

2025-04-25 22:00:45 2 阅读

目录

Modbus-RTU协议

Modbus-RTU 核心特性

数据帧格式

帧结构示例

应用场景与示例

1. PLC 控制电机启停

2. 读取温度传感器数据

CRC16校验算法

CRC16算法的过程

modbus-rtu的使用

发送数据

接收数据

tcp网口完整实现modbus-rtu协议

Modbus-RTU和Modbus-TCP的趋区别

使用NModbus4实现modbus-rtu协议

安装NModbus4库。

串口实现NModbus4


Modbus-RTU协议

Modbus RTU 协议是一种开放的串行协议,广泛应用于当今的工业监控设备中。该协议使用 RS-232 或 RS-485 串行接口进行通信,并得到市场上几乎所有商业 SCADA、HMI、OPC 服务器和数据采集软件程序的支持。因此,很容易将 Modbus 兼容设备集成到新的或现有的监控应用程序中,并具有即时的软件支持。


Modbus-RTU 核心特性

特性说明
传输方式二进制数据传输(紧凑高效)
物理接口RS-485(多设备总线)或 RS-232(点对点)
校验方式循环冗余校验(CRC-16),校验范围包括整个数据帧
传输效率高(无字符转换开销)
最大设备数RS-485 总线支持最多 32~247 个设备(依赖驱动能力)
典型应用工业实时控制、设备监控、高速数据采集

数据帧格式

帧结构:设备地址、功能码、数据和CRC校验字段。

常用功能码:Modbus-RTU协议定义了一系列常用的功能码,用于执行不同的操作,如读取保持寄存器、写入单个寄存器、写入多个寄存器等。

(1). 功能码-0x03读保持寄存器:该功能码用于从设备中读取一个或多个保持寄存器的值。
(2). 功能码-0x06写单个寄存器:该功能码用于向设备中写入一个保持寄存器的值。
(3). 功能码-0x10写多个寄存器:该功能码用于向设备中写入多个连续的保持寄存器的值。

帧结构示例

Modbus RTU 功能 01 用于从 Modbus 从站数据采集设备读取线圈状态或数字输出状态。请参阅下面的典型命令和响应以及使用说明。

    主机发送:  01 03 00 00 00 01 84 0A
    从机响应:  01 03 02 19 98 B2 7E

该例子中,主机发送的数据为`地址 + 功能码 + 数据 + 校验`​,CRC校验码是根据前面的数据计算得出的

回复的数据格式


应用场景与示例

1. PLC 控制电机启停
  • 请求帧(主机 → 从机地址 0x02)
    02 05 00 01 FF 00 8C 09

    • 功能码 0x05:写单个线圈。

    • 地址 0x0001:电机控制寄存器。

    • 值 FF 00:ON(FF00 表示 ON,0000 表示 OFF)。

2. 读取温度传感器数据
  • 请求帧(主机 → 从机地址 0x03)
    03 04 00 00 00 01 70 0B

    • 功能码 0x04:读输入寄存器。

    • 地址 0x0000:温度传感器寄存器。

    • 数量 0x0001:读取 1 个寄存器。


CRC16校验算法

CRC全称循环冗余校验(Cyclic Redundancy Check, CRC),是通信领域数据传输技术中常用的检错方法,用于保证数据传输的可靠性。

CRC校验的基本思路是数据发送方发送数据之前,先生成一个CRC校验码,可以是单bit也可以是多bit,并附在有效数据末尾,以串行方式发送到接收方。接收方接收到数据后,进行CRC校验,根据校验结果就可以知道数据是否有误。

CRC校验码的生成:将有效数据**扩展后**作为被除数,使用一个指定的**多项式**作为除数,进行模二除法,得到的**余数**就是校验码。

数据接收方的CRC校验:将接受的数据(**有效数据+CRC校验码**)扩展后作为被除数,用指定的多项式作为除数,进行模二除法,得到**余数为0**,则表示校验正确。

我们使用代码向设备发送命令帧时需要使用CRC算法计算校验值,当设备响应数据时使用CRC算法校验该数据是否正确,

CRC16算法的过程

1 初始化一个16位的寄存器地址 用作初始值
2 遍历数据字节,从最高位到最低位, 
3 将数据字节与寄存器异或
4 对寄存器进行8次迭代,每一次迭代将寄存器右移一位
5 如果最低位位1,将寄存器与生成多项式0x8005异或,否则只进行右移操作
6 重复上述步骤直到遍历完所有的字节
7 最终寄存器的值就是crc16校验码
8 crc计算之后高低位进行互换

以下是封装的CRC16效验算法类:

    public static class CRC16
    {
        /// 
        /// CRC校验,参数data为byte数组
        /// 
        /// 校验数据,字节数组
        /// 字节0是高8位,字节1是低8位
        public static byte[] CRCCalc(byte[] data)
        {
            //crc计算赋初始值
            int crc = 0xffff;
            for (int i = 0; i < data.Length; i++)
            {
                crc = crc ^ data[i];
                for (int j = 0; j < 8; j++)
                {
                    int temp;
                    temp = crc & 1;
                    crc = crc >> 1;
                    crc = crc & 0x7fff;
                    if (temp == 1)
                    {
                        crc = crc ^ 0xa001;
                    }
                    crc = crc & 0xffff;
                }
            }
            //CRC寄存器的高低位进行互换
            byte[] crc16 = new byte[2];
            //CRC寄存器的高8位变成低8位,
            crc16[1] = (byte)((crc >> 8) & 0xff);
            //CRC寄存器的低8位变成高8位
            crc16[0] = (byte)(crc & 0xff);
            return crc16;
        }
    
        /// 
        /// CRC校验,参数为空格或逗号间隔的字符串
        /// 
        /// 校验数据,逗号或空格间隔的16进制字符串(带有0x或0X也可以),逗号与空格不能混用
        /// 字节0是高8位,字节1是低8位
        public static byte[] CRCCalc(string data)
        {
            //分隔符是空格还是逗号进行分类,并去除输入字符串中的多余空格
            IEnumerable datac = data.Contains(",") ? data.Replace(" ", "").Replace("0x", "").Replace("0X", "").Trim().Split(',') : data.Replace("0x", "").Replace("0X", "").Split(' ').ToList().Where(u => u != "");
            List bytedata = new List();
            foreach (string str in datac)
            {
                bytedata.Add(byte.Parse(str, System.Globalization.NumberStyles.AllowHexSpecifier));
            }
            byte[] crcbuf = bytedata.ToArray();
            //crc计算赋初始值
            return CRCCalc(crcbuf);
        }
    
        /// 
        ///  CRC校验,截取data中的一段进行CRC16校验
        /// 
        /// 校验数据,字节数组
        /// 从头开始偏移几个byte
        /// 偏移后取几个字节byte
        /// 字节0是高8位,字节1是低8位
        public static byte[] CRCCalc(byte[] data, int offset, int length)
        {
            byte[] Tdata = data.Skip(offset).Take(length).ToArray();
            return CRCCalc(Tdata);
        }
    }


modbus-rtu的使用

发送数据

现要读取变送器设备(地址 0x01)的风速值,文档如图所示

我们发送的命令帧应为

根据命令帧计算校验码(3种方式)

    byte[] buffer = new byte[] { 0x01, 0x03, 0x00, 0x00, 0x00, 0x01 };
    byte[] crc16 = CRC16.CRCCalc(buffer);  // 根据字节数组计算
    Console.WriteLine($"{crc16[0]:X2} {crc16[1]:X2}");
    
    string data1 = "0x01,0x03,0x00,0x00,0x00,0x02";
    string data1 = "0x01 0x03 0x00 0x00 0x00 0x02";
    byte[] crc16 = CRC16.CRCCalc(data1);    // 根据字符串计算
    Console.WriteLine($"{crc16[0]:X2} {crc16[1]:X2}");
    
     byte[] buffer = new byte[] { 0x01, 0x03, 0x00, 0x00, 0x00, 0x02, 0xC4, 0x0B };
     byte[] crc16 = CRC16Calc(buffer,0,6);  // 从字节数组中截取某部分计算
     Console.WriteLine($"{crc16[0]:X2} {crc16[1]:X2}");

将数据和校验码数组进行合并然后发送

    byte[] buffer = new byte[] { 0x01, 0x03, 0x00, 0x00, 0x00, 0x01 };
    byte[] crc16 = CRC16.CRCCalc(buffer);
    byte[] data = buffer.Concat(crc16).ToArray();
    serialPort.Write(data, 0, data.Length);

接收数据

我们将命令帧(请求帧、问询码)发送后,如果没有错误,从设备会返回对应的数据,如下读取变送器设备(地址 0x01)的实时风力等级值,将会返回如图所示的数据,我们需要将数据读取、校验、计算、展示

    // 假设这是从设备响应的数据
    // 0x01:设备地址码
    // 0x03:功能码
    // 0x02:读取到的数据字节
    // 0x00, 0x01:当前风力等级
    // 0x79, 0x84:校验码
    byte[] value = new byte[] { 0x01, 0x03, 0x02, 0x00, 0x01, 0x79, 0x84 };
    // 1、验证校验码是否正确
    byte[] crc = CRC16.CRCCalc(value, 0, value.Length - 2);
    if (crc[0] != value[value.Length - 2] || crc[1] != value[value.Length-1] ) {
        MessageBox.Show("数据校验错误,应忽略");
        return;
    }
    // 2、验证设备地址
    if (value[0] !=  0x01)
    {
        MessageBox.Show("设备地址不正确");
        return;
    }
    // 3、计算数据
    // int v = value[3] * 256 + value[4];  // 因为这个数据占两个字节,每个字节最大255,相当于256进制,转换为10进制
    int v = (value[3] << 8) + value[4];       // 也可以使用左移运算符,高位左移8位,相当于乘2的8次方
    
    // 4、数据展示
    MessageBox.Show("风力等级:" + v);

tcp网口完整实现modbus-rtu协议

public partial class Form1 : Form
{
    /// 
    /// 套接字
    /// 
    Socket socket;
    
    /// 
    /// IP地址
    /// 
    string Ip = "192.168.107.5";

    /// 
    /// 端口
    /// 
    string Dk = "8016";

    /// 
    /// 命令帧
    /// 
    string Icommand = "01 03 00 00 00 02";

    public Form1()
    {
        InitializeComponent();
        button1.Enabled = false;
        checkBox1.Enabled = false;
    }

    /// 
    /// 打开连接
    /// 
    /// 
    /// 
    private void button2_Click(object sender, EventArgs e)
    {
        if (button2.Text == "连接网口")
        {
            try
            {
                socket = new Socket(AddressFamily.InterNetwork, SocketType.Stream, ProtocolType.Tcp);
                socket.Connect(Ip, int.Parse(Dk));

                button1.Enabled = true;
                checkBox1.Enabled = true;
                button2.Text = "断开";
                this.timer1.Start();
            }
            catch (Exception ex)
            {
                MessageBox.Show(ex.Message);
            }
        }
        else
        {
            if (socket == null) return;
            socket.Close();
            button1.Enabled = false;
            checkBox1.Enabled = false;
            checkBox1.Checked = false;
            button2.Text = "连接网口";
            this.timer1.Stop();
        }
        
    }


    /// 
    /// 刷新风速风向数据
    /// 
    /// 
    /// 
    private async void button1_Click(object sender, EventArgs e)
    {
        byte[] bs = new byte[1024];
        bs = StringToByte(Icommand);
        byte[] bb = CRCCalc(bs);
        bs = bs.Concat(bb).ToArray();
        await Task.Run(() =>
        {
            socket.Send(bs); // 发送请求帧

            byte[] body = new byte[1024];
            int length = socket.Receive(body); // 获取响应帧

            double value = (body[3] * 256+ body[4]) *0.01;
            double value2 = (body[5] * 256 + body[6]);
            this.Invoke(new Action(() =>
            {
                this.textBox1.Text = value.ToString() + "m/s";
                this.textBox2.Text = value2.ToString();
            }));

        });

    }



    /// 
    /// 字符串转字节
    /// 
    /// 
    /// 
    byte[] StringToByte(string s)
    {
        string[] strings = s.Split(' ') ;
        byte[] bs = new byte[strings.Length];
        for (int i = 0; i < strings.Length; i++)
        {
            bs[i] = Convert.ToByte(strings[i],16);
        }
        return bs;
    }


    /// 
    /// CRC效验
    /// 
    /// 
    /// 
    public static byte[] CRCCalc(byte[] data)
    {
        //crc计算赋初始值
        int crc = 0xffff;
        for (int i = 0; i < data.Length; i++)
        {
            //XOR
            //(1) 0^0=0,0^1=1  0异或任何数=任何数
            //(2) 1 ^ 0 = 1,1 ^ 1 = 0  1异或任何数-任何数取反
            //(3) 1 ^ 1 = 0,0 ^ 0 = 0  任何数异或自己=把自己置0
            //异或操作符是^。异或的特点是相同为false,不同为true。
            crc = crc ^ data[i]; //和^表示按位异或运算。
                                 //0x0fff ^ 0x01 Console.WriteLine(result.ToString("X")); 
                                 // 输出结果为4094,即十六进制数1001
            for (int j = 0; j < 8; j++)
            {
                int temp;
                temp = crc & 1; // & 运算符(与) 1 & 0 为 0  ;0 & 0 为0;1 & 1 为1

                //右移 (>>) 将第一个操作数向右移动第二个操作数所指定的位数,空出的位置补0。右移相当于整除. 右移一位相当于除以2;右移两位相当于除以4;右移三位相当于除以8。
                //int i = 7;
                //int j = 2;
                //Console.WriteLine(i >> j);   //输出结果为1
                crc = crc >> 1;
                crc = crc & 0x7fff;
                if (temp == 1)
                {
                    crc = crc ^ 0xa001;
                }
                crc = crc & 0xffff;
            }
        }
        //CRC寄存器的高低位进行互换
        byte[] crc16 = new byte[2];
        //CRC寄存器的高8位变成低8位,
        crc16[1] = (byte)((crc >> 8) & 0xff);
        //CRC寄存器的低8位变成高8位
        crc16[0] = (byte)(crc & 0xff);
        return crc16;
    }
}

Modbus-RTU和Modbus-TCP的趋区别

特性Modbus-RTUModbus-TCP
物理层RS-485/RS-232以太网(RJ45)
传输速率最高 115.2 kbps100 Mbps ~ 1 Gbps
拓扑结构总线型星型/树型/网状
实时性高(确定性延迟)依赖网络状况
扩展性有限(受总线长度限制)

高(支持跨网段通信)


使用NModbus4实现modbus-rtu协议

NModbus4是一个C#实现的Modbus库,它允许开发者以Modbus RTU的方式与工业设备进行通信。

安装NModbus4库。

通过NuGet安装NModbus4

串口实现NModbus4

public partial class Form1 : Form
{
    // 创建对象
    ModbusSerialMaster master;
    public Form1()
    {
        InitializeComponent();
        this.serialPort1.PortName = "COM2"; // 串口名
        this.serialPort1.BaudRate = 9600;
        this.serialPort1.DataBits = 8;
        this.serialPort1.Parity =System.IO.Ports.Parity.None;
        this.serialPort1.StopBits = System.IO.Ports.StopBits.One;

        serialPort1.Open();
        master = ModbusSerialMaster.CreateRtu(serialPort1);
    }

    /// 
    ///  读取数据
    /// 
    /// 
    /// 
    private async void button1_Click(object sender, EventArgs e)
    {
        // ReadHoldingRegistersAsync 异步读取数据
        // await 等待异步任务执行完之后 再往下执行
        // 参数1 从站地址, 参数2 起始地址  参数3:寄存器个数
        // values 元素个数和寄存器个数有关
        ushort[] values = await master.ReadHoldingRegistersAsync(1,0x00,3);
        comboBox1.DataSource = values;
    }

    /// 
    /// 写入数据
    /// 
    /// 
    /// 
    private async void button2_Click(object sender, EventArgs e)
    {
        // 写入 单个的寄存器
        // 参数1 从站地址
        // 参数2 写入的地址
        // 参数3 写入的数据 
        // short 短整型
        // ushort 无符号的短整型
        await master.WriteSingleRegisterAsync(1,0x04,14);
    }
}

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

搜索文章

Tags

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