• 【网络篇】从零写UDP客户端/服务器:回显程序源码解析

【网络篇】从零写UDP客户端/服务器:回显程序源码解析

2025-04-25 22:34:29 1 阅读

大家好呀
我是浪前

今天讲解的是网络篇的第四章:从零写UDP客户端/服务器:回显程序源码解析

从零写UDP客户端/服务器:回显程序源码解析

  • UDP 协议特性​
    • 核心类介绍​
  • UDP的socket应该如何使用:
  • 1: DatagramSocket
  • 2: DatagramPacket
    • 回显服务器
    • 进行网络编程的第一步
    • 服务器的代码(回显服务器)
      • 创建一个DatagramSocket的对象:
      • 定义服务器启动方法:
      • 手动创建内存空间:
      • 将读取到的数据转成字符串:
      • 封装分用:
    • 客户端的代码:
    • 通信过程:

UDP 协议特性​

UDP(User Datagram Protocol)作为传输层协议,有着与 TCP 截然不同的特性,在网络通信中扮演着独特的角色,适用于对实时性要求高、能容忍少量数据丢失的场景。​

无连接通信:UDP 在数据传输前,发送方和接收方无需像 TCP 那样进行三次握手建立连接,可直接发送数据。无需复杂的连接建立过程,极大降低了传输延迟。

不可靠传输:它不保证数据一定能到达接收方,也不确保数据的顺序和完整性。若在网络传输中,UDP 数据包丢失或乱序,协议本身不会重传或纠正。

面向数据报:UDP 以独立的数据报为单位传输数据,每个数据报都包含完整的目标地址等信息,可独立传输,服务器收到后直接响应,简单高效。​

全双工通信:同一 UDP Socket 可同时进行数据的发送和接收。在语音通话应用中,双方能同时说话并实时听到对方声音,就是因为 UDP 的全双工特性,保证了语音数据的双向实时传输。​

核心类介绍​

在 Java 的 UDP 网络编程里,DatagramSocket和DatagramPacket是两个关键类,分别负责 socket 通信和数据报的封装传输,相互配合实现 UDP 通信功能。

UDP的socket应该如何使用:

UDP的API主要是提供了两个类:

  1. DatagramSocket
  2. DatagramPacket

1: DatagramSocket

socket: 本质上是操作系统中的一个概念,本质上是一个特殊的文件
这里的socket属于就是把“网卡”这个设备,给抽象成了文件,而进行网络通信最核心的硬件设备就是网卡

往socket文件中写数据,就相当于是通过网卡发送数据
往socket文件中读数据,就相当于是通过网卡接收数据

上面就是把文件操作和网络通信给统一了
在Java中就是使用这个 DatagramSocket 类就是来表示系统内部的socket文件
这个 DatagramSocket 类负责文件读写,也就是借助网卡发送和接收数据

2: DatagramPacket

使用这个类就是来表示一个UDP数据报:
UDP是面向数据报的
每次进行传输,都要以UDP数据报为基本单位
每次传输都只能够传输一个完整的数据报,不可以传输半个数据报,也不可以传输一个半数据报

写一个简单的UDP的客户端/服务器通信的程序:
这个程序没有什么业务逻辑,请求什么,就响应什么
只是单纯滴调用Socket API

让客户端给服务器发送一个请求,请求就是一个从控制台输入的字符串,服务器收到字符串之后,也就会把这个字符串原封不动地返回给客户端,然后客户端再显示出来,
这个程序就是请求什么,就响应什么
这个程序是最简单的网络通信程序,叫做回显服务器

回显服务器

服务器的主要功能:

负责接收客户端的请求,然后根据实际的业务场景来返回不同的响应

有一种服务器是回显服务器:

回显服务器的作用就是客户端发啥请求,回显服务器就立马返回啥请求,没有业务逻辑的

比如:
客户端发送想吃蛋炒饭的请求
服务器就接收到蛋炒饭的请求之后,就返回蛋炒饭的响应

这个回显服务器是网络编程中最简单的程序,相当与网络编程中的“Hello World”

回显服务器的作用

  1. 学会掌握Socket API的基本使用
  2. 学会典型的客户端服务器的工作流程

进行网络编程的第一步

服务器的代码(回显服务器)

我们先来写一个服务器代码:

创建一个DatagramSocket的对象:

注意:
这个对象是在创建在内存中的,直接对内存进行操作就可以影响到网卡

程序启动的同时要关联/绑定一个端口号,这个端口号是专门用来区分主机的

一个主机只能够有一个端口号,同时一个主机中的端口号只能和一个进程进行绑定,
一个端口号和进程A进行了绑定之后,如果进程B也要和这个端口号进行绑定,那么进程B会绑定失败

但是一个进程是可以同时和多个端口号进行绑定的
为什么?
因为每一个端口号对应了一个DatagramSocket对象,如果一个进程中有多个DatagramSocket对象的话,就可以和多个端口号进行绑定
如下图所示:

同时我们在创建DatagramSocket对象的时候必须要手动指定一个端口号
在运行一个服务器程序的时候,也要手动指定端口号

DatagramSocket对象的代码创建如下:

package netWork;  
  
import java.net.DatagramSocket;  
import java.net.SocketException;  
  
public class Server {  
    private DatagramSocket socket = null;  
  
    public Server(int port) throws SocketException{  
        socket = new DatagramSocket(port);  
    }  
  
      
}

上述的代码抛出的异常为SocketException
这个异常是在创建DatagramSocket对象时,当主机的端口号已经被其他进程绑定的时候会抛出的异常

定义服务器启动方法:

接下来定义一个start方法来作为服务器启动的方法:
start方法的执行逻辑如下所示:

在start方法中会有一个while循环:
由于服务器每天从客户端那里接收到的请求有很多,
所以服务器会每时每刻都在不停地运行,每循环一次,就是服务器在接收到请求,返回响应的过程

在每次while循环中,会经历下面三个步骤 :

  1. 服务器读取客户端发来的请求,解析请求
  2. 服务器根据请求来计算响应(回显服务器没有这一步)
  3. 服务器向客户端返回响应
    代码如下:
public void start(){  
    System.out.println("服务器启动");  
    while(true){  
        //每次循环,都是一次服务器在接收请求,返回响应的过程  
        //1.读取请求,解析请求  
        socket.receive();  
        //2.根据请求计算响应(回显服务器不需要这一步)  
        //3. 返回响应  
                  
}  
}

第一步:读取请求,进行解析,

socket.receive()

上面代码中的这个receive方法中需要填写一个DatagramPacket类型的参数,
这个参数是一个输出型参数,这个参数在文件IO中也涉及到了,实际上在DatagramPacket内部就会包含一个字节数组,如下所示

DatagramPacket requestPacket = new DatagramPacket(new byte[4096], 4096);

这个字符数组会保存收到的消息正文,这个消息正文就是应用层数据包,也就是UDP数据报载荷部分,这个载荷空间的大小可以灵活设置

将这个参数传入socket.receive()中后,会抛出一个异常:

IOException : //网络编程,读写socket本质就是IO

public void start() throws IOException {  
    System.out.println("服务器启动");  
    while(true){  
        //每次循环,都是一次服务器在接收请求,返回响应的过程  
        //1.读取请求,解析请求  
        DatagramPacket requestPacket = new DatagramPacket(new byte[4096], 4096);  
        socket.receive(requestPacket);  
        //2.根据请求计算响应(回显服务器不需要这一步)  
        //3. 返回响应  
    }  
}

手动创建内存空间:

当收到数据的时候,需要搞一个内存空间来保存这个数据

所以上面的requestPacket对象是用来承载从网卡那里读到的数据

但是由于在DatagramPacket的内部是不可以自行分配内存空间的,所以需要手动把内存空间创建好

这里创建了一个字节数组,这个字节数组就是真正的用来承载数据的内存空间
然后再交给DatagramPacket处理:

之后receive就会从这个requestPacket对象中读取数据,然后把读取到的数据填充到socket对象中去

此处receive就可以从网卡中读取一个UDP数据报

这个UDP数据报就是被放进了requestPacket对象中

其中UDP数据报的载荷部分被放进了requestPacket内置的字节数组中,同时,UDP的报头部分和收到的数据源IP,源IP端口都会被保存在 requestPacket的其他属性中

所以我们requestPacket还可以知道数据是从哪里来的(源IP源端口)

如果执行到receive的时候,还没有客户端发来请求,那么此时receive就没有可以读取的数据,此时receive就会发生阻塞,一直阻塞到客户端发来请求为止

将读取到的数据转成字符串:

此时的receive会读取到一个字节数组,
当receive读取完毕之后,数据是以二进制的形式存储到DatagramPacket中

要想能够把这里的数据给显示出来,就需要把这个二进制数据转化为字符串
所以,此时的读的字节数组必须要先转成(字符串)String之后,才方便后续的逻辑处理:

String request = new String(requestPacket.getData(),0,requestPacket.getLength());

基于字节数组构造String,字节数组里面保存的内容不一定就是二进制数据,也可能是文本数据
而字符串(String) 不仅可以保存二进制数据,还可以保存文本数据,所以需要将这个字节数组转成字符串 :

注意:
在getLength()中获取的字节数组的有效数据的长度不一定就是4096
这个4096是这个字节数组的最大长度,
而getLength()获取到的结果是收到的数据的真实长度,即发送方这一次实际发送了多少个数据
比如:
如果这一次收到的数据长度是10,那么这个getLength()获取到的就是10。
所以我们这里构造字符串是使用有效数据长度来进行构造,不能使用字节数组的最大长度来构造

以上就是把一个请求转化为字符串了

封装分用:

网路通信过程中涉及到"封装和分用":

只有当应用层调用传输层提供的API的时候,才会把这个数据给读取到;
数据来到服务器时,会经由物理层,一层层分用到应用层:

在传输层中:会给每一个socket对象都分配一个缓冲区(这个缓冲区在操作系统内核里)
每次网卡收到一个数据都是经由层层分用,解析好之后,最终放到缓冲区里
在应用层的应用程序调用receive就是从这个缓冲区里面拿走一个数据
这个本质上就是生产者-消费者模型,而此处给socket对象分配的缓冲区就是阻塞队列

所以从客户端传过来的数据 不是存在socket文件中,而是存在socket对象中的一个内存缓冲区的阻塞队列中

第二步:根据请求来构造响应:

String response = process(request);

这个代码要根据请求构造响应,通过这个process方法来构造响应

public  String process(String request) {  
    return request;  
}

由于此处是回显服务器,所以只需要单纯滴返回这个请求就可以了

第三步: 把响应返回给客户端:

1: 构造一个响应对象DatagramPacket作为响应对象

同时由于UDP是无连接的,所以UDP不会保存要发给谁

所以就需要在每次发送的时候,重新指定,数据要发送到哪里去

所以在这个响应对象(数据报)中需要指定数据内容,也要指定数据具体要发送给谁。

//构造一个DatagramPacket作为响应对象  
DatagramPacket responsePacket = new DatagramPacket(response.getBytes(StandardCharsets.UTF_8),
response.getBytes().length);

刚刚的socket对象还没有构造完毕,在构造时还需要指定一个socketAddress进去:

DatagramPacket responsePacket = new DatagramPacket(response.getBytes(StandardCharsets.UTF_8),
response.getBytes().length,requestPacket.getAddress(),requestPacket.getPort());

这个requestPacket.getAddress()和requestPacket.getPort()
方法会获取到一个IP和一个端口号

这个IP和端口号是和服务器通信的对端的客户端的IP和 端口号
这个IP和端口号是从这个requestPacket这个客户端数据包中获取的

同时在代码中的response.getBytes().length获取到的是字节

在进行网络传输的时候,一定是使用字节来进行传输的

而response.length() 获取到的是字符,如果全是英文,那么字节和字符的个数一样,但是如果有中文,那么此时字节和字符的个数就不一样了。

为什么要获取到这个客户端的IP和端口号?

这里是把客户端(请求)中的源IP和源端口,作为响应的目的IP和目的端口
此时就可以做到把消息返回给客户端的效果了

此时我们的响应对象就构造好了,只需要将这个responsePacket作为参数使用send方法传递出去即可:

socket.send(responsePacket);

上述代码中,可以看到UDP 是无连接通信,UDP socket自身不保存对端(客户端)的IP和端口号 :

这个IP和端口号是在数据包中有一个,同时在代码中也没有"建立连接"和"接受连接"的操作

这个是直接读取请求,若没有请求,则阻塞等待,若有请求,则对请求进行解析,然后根据请求构造响应,最后返回响应

所谓的UDP不可靠传输目前代码中没有体现:

而UDP的面向数据报有体现: 上述代码中的send和receive的参数接收都是以DatagramPacket为单位进行发送和接收的

UDP的全双工在代码中也有体现:
一个socket既可以发送又可以接收,就叫做全双工

最后在代码中进行一个打印日志的操作:

//打印日志:  
System.out.printf("[%s:%d] req: %s,resp: %s
",requestPacket.getAddress().toString(),  
        requestPacket.getPort(), request, response);

之后撰写一个main方法即可:

public static void main(String[] args) throws IOException {  
    Server server = new Server(9090);  
    server.start();  
}

上述服务器的代码编写完毕,

下面是回显服务器的完整代码:

package netWork;  
  
import javax.xml.crypto.Data;  
import java.io.IOException;  
import java.net.*;  
import java.sql.SQLOutput;  
  
public class UdpServer {  
    //创建一个DatagramSocket对象,是后续进行网卡的基础  
    private DatagramSocket socket = null;  
  
    public UdpServer(int port)  throws SocketException{  
        //下面是手动指定端口  
        socket = new DatagramSocket(port);  
  
        //下面这么写就是系统自动分配端口  
        //socket = new DatagramSocket();  
    }  
  
    //程序的主方法,通过这个方法来启动服务器  
    public void start() throws IOException {  
        System.out.println("服务器启动");  
        //一个服务器要不停滴运行,所以需要一个while循环来进行操作,一个服务器程序是要长时间运行的  
        //为了保证客户端随时来,随时可以响应,  
        while(true){  
            //1.第一步,读取请求并解析  
            DatagramPacket requestPacket = new DatagramPacket(new byte[4090],4090);  
            socket.receive(requestPacket);  
            //将请求转化为字符串  
            String request = new String(requestPacket.getData(),0,requestPacket.getLength());  
  
            //2.根据请求计算响应  
            //这个步骤是服务器最核心的一个步骤,  
            String response = process(request);  
  
  
            //3. 把响应返回给客户端  
            //使用一个响应对象  DatagramPacket  往响应对象中构造刚才的数据,再通过send返回  
            DatagramPacket responsePacket = new DatagramPacket(response.getBytes(),response.getBytes().length,  
                    requestPacket.getSocketAddress());  

			//使用send方法传入参数进行发送
			socket.send(responsePacket);
  
  
            System.out.printf("[%s:%d] req = %s,resp = %s
",requestPacket.getAddress().toString(),  
                    requestPacket.getPort(),request,response);  
  
        }  
    }  
  
    public String process(String request){  
        return request;  
    }  
  
    public static void main(String[] args) throws IOException {  
        UdpServer server = new UdpServer(9090);  
        server.start();  
    }  
}

为什么上述的代码中没有出现close()?
socket也是一个文件,不进行关闭的话,会造成文件资源泄露

什么是文件资源泄露?
你一直申请,但是一直都没有进行close,没有进行释放,结果到最后,你想用的时候,发现用不了了,就是文件资源泄露。

为什么这里不写close()方法,也不会出现文件资源泄露呢?
因为socket是文件描述符表中的一个表项.

每次打开一个文件,就会占用一个位置,文件描述符是在PCB(进程)上的,是跟随进程的
这个socket在整个程序过程中一直都在使用,不可以提前释放,不可以提前关闭

当socket不使用的时候,此时整个程序也要结束了
当进程结束时,文件描述符表也会跟随着进程的结束被销毁,就可能发生泄露问题了。

总结:

不会泄露的原因是因为socket会随着进程销毁的过程中,被系统自动回收了

什么时候会出现泄露?

代码中频繁地打开文件,但是不关闭,在一个进程的运行过程中,不断积累打开的文件,逐渐消耗掉了文件描述符表里的内容,最后内容会被消耗光,就出现了泄露

但是如果进程的生命周期很短,打开一下就关闭了,也就不会出现泄露了
所以文件资源泄露的问题在服务器上经常出现,因为服务器的进程生命周期很长,要一直运行
泄露的问题在客户端上很少出现,因为客户端的进程的生命周期很短,客户端打开之后用一下就直接关闭了

客户端的代码:

接下来我们去 编写客户端的代码:

注意:服务器需要手动指定端口号
但是客户端不需要手动指定端口号,不手动指定也有端口号,
因为系统会自动给客户端分配一个空闲的端口号

为什么服务器必须要自己手动指定一个端口号?
因为服务器要保证端口号是固定不变的

因为只有在服务器代码中手动指定一个端口号

才能保证端口始终是固定的,如果不手动指定,服务器依赖系统自动分配端口号,就会导致服务器每次开机重启后,系统自动分配的端口号就发生了改变 。

如果服务器的端口号发生了改变,那么客户端就可能会找不到这个服务器在哪里了,所以服务器的端口号必须要在代码中手动指定

那么为什么客户端中的端口号不需要手动指定, 可以通过系统自动分配呢?

客户端的端口号让系统随机分配,系统会去分配给客户端一个空间中可用的端口号
如果是手动指定端口号,那么就无法确定这个端口号是不是可控的,有没有被别的进程占用

为什么服务器的端口号就不怕被别的进程占用呢?

因为服务器这个机器是在程序员手中的,程序员对于服务器上有哪些端口号是可用的一清二楚

但是客户端是在用户手中的,有千千万万个用户,上面的环境也千差万别,程序员无法得知端口号是否被占用,如果强行手动指定客户端的端口号就会导致端口绑定失败.

所以程序员手中的服务器的端口号是可以手动指定的,但是在用户手中的客户端的端口号是不能手动指定的,只能靠系统自动分配一个空闲的端口号

在构造方法中,由于UDP自身不会保存对端的信息,所以就需要在应用程序中,把对端的情况给记录下来,在构造方法中主要记录的就是对端的IP和端口,也就是目的IP和目的端口:

  
public class Client {  
    //首先要创建socket对象,但是此处不需要手动指定端口号  
    DatagramSocket socket = null;  
  
    //构造方法:要传输服务器IP(目的IP)和服务器端口(目的端口)  
    public Client(String serverIp, int serverPort) throws SocketException {  
        socket = new DatagramSocket();  
    }  
}

接下来创建start方法来启动客户端:
在这个start方法中,依然是使用一个循环来不停滴发送请求:
在循环中一共要做四件事情:

  1. 从控制台中读取请求数据
  2. 构造请求并发送
  3. 读取服务器的响应
  4. 把响应显示到控制台上
public void start(){  
    System.out.println("客户端启动");  
    Scanner scanner = new Scanner(System.in);  
    while(true){  
        System.out.println("-> ");  
        //1. 从控制台中读取请求数据   
        //2. 构造请求并发送  
        //3. 读取服务器的响应  
        //4. 把响应显示到控制台上  
    }  
}

第一步: 从控制台中读取数据,作为请求:

String request = scanner.next();

这里从控制台读取请求,使用scanner读取字符串,最好使用next来读取,而不是使用nextLine

因为如果使用nextLine读取,可能会读取不到空格

nextLine遇到空格就自动作为分隔符了,所以需要手动输入换行符

使用enter来控制,由于enter键不仅仅会产生 ,还会产生其他的字符,就会导致当前的这个读取到的内容会出问题

而使用next其实是以“空白符”作为分隔符,包括但不限于换行,回车,空格,制表符,垂直制表符

总结:

如果从控制台读取内容,就使用next()
如果是从文件读取内容,那么使用next()和nextLine()都可以

第二步: 把请求的内容构造成一个DatagramPacket对象,在对象中保存数据,长度, 目的IP和目的端口:

DatagramPacket requestPacket = new DatagramPacket(request.getBytes(),  
        request.getBytes().length, InetAddress.getByName(serverIp),serverPort);

然后将这个对象发给服务器:

socket.send(requestPacket);

OK,此时客户端已经向服务器发送了请求,那么接下来就只需要去读取服务器返回的响应即可:

第三步: 尝试读取服务器返回的响应:
此时我们也是需要先构造一个空的DatagramPacket对象来接收响应的数据:

DatagramPacket responsePacket = new DatagramPacket(new byte[4096],4096);

接下来使用这个responsePacket对象对响应进行接收即可:

socket.receive(responsePacket);

第四步: 把响应转换成字符串,并显示出来:

//4. 把响应转化成字符串,并显示到控制台上  
String response = new String(responsePacket.getData(),0,responsePacket.getLength());  
System.out.println(response);

上述的start方法就结束了,最后再补上一个main方法即可:

  
public static void main(String[] args) throws IOException {  
    Client client = new Client("127.0.0.1",9090);  
    client.start();  
}

综上所述:客户端的完整代码如下所示:

package netWork;  
  
import java.io.IOException;  
import java.net.*;  
import java.util.Scanner;  
  
public class Client {  
    //首先要创建socket对象,但是此处不需要手动指定端口号  
    DatagramSocket socket = null;  
  
    private String serverIp;  
    private int serverPort;  
  
    //构造方法:要传输服务器IP(目的IP)和服务器端口(目的端口)  
    public Client(String serverIp, int serverPort) throws SocketException {  
        this.serverIp = serverIp;  
        this.serverPort = serverPort;  
        //下面就是自动分配一个端口号  
        socket = new DatagramSocket();  
    }  
  
    public void start() throws IOException {  
        System.out.println("客户端启动");  
        Scanner scanner = new Scanner(System.in);  
        while(true){  
            System.out.println("-> ");  
            //1. 从控制台中读取请求数据  
            String request = scanner.next();  
  
            //2. 构造请求并发送  
            DatagramPacket requestPacket = new DatagramPacket(request.getBytes(),  
                    request.getBytes().length, InetAddress.getByName(serverIp),serverPort);  
  
            socket.send(requestPacket);  
  
            //3. 读取服务器的响应  
            DatagramPacket responsePacket = new DatagramPacket(new byte[4096],4096);  
  
            socket.receive(responsePacket);  
  
            //4. 把响应转化成字符串,并显示到控制台上  
            String response = new String(responsePacket.getData(),0,responsePacket.getLength());  
            System.out.println(response);  
  
        }  
    }  
  
    public static void main(String[] args) throws IOException {  
        Client client = new Client("127.0.0.1",9090);  
        client.start();  
    }  
  
}

通信过程:

此时客户端和服务器就可以相互配合,完成通信过程:

步骤如下:

  1. 先启动服务器
  2. 再启动客户端
  3. 在客户端中编写hello
  4. 然后就可以在服务器中看见

下面是 客户端的界面展示:

下面是服务器的界面展示:

执行过程:

  1. 第一步:服务器启动,进入while循环,执行到receive这里时发生阻塞(此时客户端还没有发送请求)
  2. 第二步:客户端开始启动: 也会进入while循环,执行scanner.next,并且在这里阻塞,直到用户在控制台输入,当用户输入字符串之后,next就会返回,从而构造请求数据并发送出来
  3. 第三步:客户端发送出数据之后,在服务器那边,就会从receive中返回数据,进一步的解析请求为字符串,执行process操作,执行send操作。 此时的客户端也会继续往下执行,执行到receive,等待服务器的响应
  4. 客户端收到服务器返回的数据之后,就会从receive中返回,执行这里的打印操作,也就把响应给显示出来了
  5. 服务器完成一次循环之后,就又会执行到receive,重新进入阻塞
  6. 客户端完成一次循环之后,就又会执行到scanner.next,重新进入阻塞

我们重点要理解网络程序的交互逻辑

刚刚的两个程序都是在一个主机上的,没有实现跨主机通信的效果

能否让同学使用客户端程序来访问老师的服务器代码呢?

如果我的服务器就在我的电脑上,此时,你是不可以直接访问的,除非老师和同学的电脑都在同一个局域网下,即同一个路由器下,才可以

但是还有一种方式“ 云服务器”
有了这个,就可以访问老师的电脑了,因为老师的电脑没有公网IP,但是云服务器有公网IP

jar包是java打包的一种基本方式

把刚才的UDP服务器部署到云服务器上,进一步的,就可以让大家来访问了

之后可以调整一下客户端的代码,让客户端访问云服务器上的服务程序,就只需要把IP地址换成云服务器的IP即可

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

搜索文章

Tags

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