最新资讯

  • [Linux#58][HTTP] 自己构建服务器 | 实现网页分离 | 设计思路

[Linux#58][HTTP] 自己构建服务器 | 实现网页分离 | 设计思路

2026-01-30 22:52:17 栏目:最新资讯 4 阅读

目录

一. 最简单的HTTP服务器

二.服务器 2.0

Protocol.hpp

httpServer.hpp

子进程的创建和退出

子进程退出的意义

父进程关闭连接套接字

httpServer.cc

argc (argument count)

argv (argument vector)

三.服务器和网页分离

思考与补充:


一. 最简单的HTTP服务器

基于上一篇文章的理论:

我们可以尝试实现一个简单的 HTTP 服务器,它可以接受客户端连接并返回一个 "Hello World" 网页。为了详细说明这段代码,让我们逐行进行解释。

#include   // 引入套接字相关的头文件
#include   // 引入处理IPv4地址的头文件
#include    // 引入INET相关函数的头文件
#include       // 引入UNIX标准函数,如close()
#include        // 引入标准输入输出头文件
#include       // 引入字符串处理函数的头文件
#include       // 引入标准库函数,如atoi()

这些头文件包含了程序所需的各种函数和类型:

  • sys/socket.h: 提供套接字函数和数据结构。
  • netinet/in.h: 提供了用于处理 IPv4 地址的结构和函数。
  • arpa/inet.h: 提供了用于操作 IP 地址的函数,如 inet_addr
  • unistd.h: 提供了 UNIX 标准函数,如 close
  • stdlib.h: 提供了一些标准库函数,如 atoi
void Usage() {
    printf("usage: ./server [ip] [port]
");
}

定义了一个 Usage 函数,该函数打印使用说明,说明程序需要两个命令行参数,即 IP 地址和端口号。

int main(int argc, char* argv[]) {

程序的 main 函数开始。

    if (argc != 3) {
        Usage();
        return 1;
    }

检查命令行参数的数量。如果参数数量不等于 3(程序名、IP 地址和端口号

    int fd = socket(AF_INET, SOCK_STREAM, 0);
    if (fd < 0) {
        perror("socket"); // 如果创建失败,打印错误信息
        return 1;
    }

创建一个套接字AF_INET 表示使用 IPv4,SOCK_STREAM 表示使用 TCP。

    struct sockaddr_in addr; // 定义一个地址结构体
    addr.sin_family = AF_INET; // 设置为IPv4地址族
    addr.sin_addr.s_addr = inet_addr(argv[1]); // 设置IP地址
    addr.sin_port = htons(atoi(argv[2])); // 设置端口号,并转换为网络字节序

设置服务器端地址:

  • sin_family:家族类型为 AF_INET,即 IPv4。
  • sin_addr.s_addr:将命令行参数中的 IP 地址转化为网络字节序的二进制地址。
  • sin_port:将命令行参数中的端口号转化为网络字节序的端口号。
    int ret = bind(fd, (struct sockaddr*)&addr, sizeof(addr));
    if (ret < 0) {
        perror("bind"); // 如果绑定失败,打印错误信息
        return 1;
    }

套接字绑定到指定的 IP 地址和端口。

    ret = listen(fd, 10);
    if (ret < 0) {
        perror("listen"); // 如果监听失败,打印错误信息
        return 1;
    }

开始监听连接,允许最多 10 个连接等待队列。

    for (;;) {
        struct sockaddr_in client_addr; // 定义客户端地址结构体
        socklen_t len = sizeof(client_addr); // 定义长度变量
        int client_fd = accept(fd, (struct sockaddr*)&client_addr, &len);
        if (client_fd < 0) {
            perror("accept"); // 如果接受连接失败,打印错误信息
            continue; // 继续下一次循环
        }

进入一个无限循环,持续接受客户端的连接:

  • client_addr:用于存储客户端的地址。
  • len:保存地址 client_addr 的长度。
  • accept:接受一个客户端连接。

如果 accept 失败,打印错误信息并继续下一次循环。

        char input_buf[1024 * 10] = {0};
        ssize_t read_size = read(client_fd, input_buf, sizeof(input_buf) - 1);
        if (read_size < 0) {
            perror("read"); // 如果读取失败,打印错误信息
            close(client_fd); // 关闭客户端套接字
            continue; // 继续下一次循环
        }

        printf("[Request] %s
", input_buf);

定义一个缓冲区并读取客户端数据:

  • input_buf:存储从客户端读取的数据。
  • read:从客户端套接字读取数据至缓冲区。

如果读取失败,打印错误信息,关闭客户端套接字,并继续下一次循环。

        char buf[1024] = {0};
        const char* hello = "

hello world

"; sprintf(buf, "HTTP/1.0 200 OK Content-Length:%lu %s", strlen(hello), hello); write(client_fd, buf, strlen(buf));

定义一个缓冲区并发送响应:

  • hello:要发送的 HTML 内容。
  • sprintf:格式化 HTTP 响应,包括头部和内容。
  • write:将响应发送回客户端。
        close(client_fd); // 关闭客户端套接字
    }

关闭客户端连接。

    close(fd); // 关闭服务器套接字
    return 0; // 正常退出
}

关闭服务器套接字并正常退出程序。

总结:

该程序是一个基本的 HTTP 服务器,负责监听指定的 IP 地址和端口,接受客户端连接,读取请求并发送一个包含 "Hello World" 的 HTML 响应。它通过使用 UNIX 系统调用(如 socketbindlistenaccept 等)来实现这一功能。

完整代码:

#include   // 引入套接字相关的头文件
#include     // 引入处理IPv4地址的头文件
#include      // 引入INET相关函数的头文件
#include         // 引入UNIX标准函数,如close()
#include          // 引入标准输入输出头文件
#include         // 引入字符串处理函数的头文件
#include         // 引入标准库函数,如atoi()

// 打印服务器的使用方法
void Usage() {
    printf("usage: ./server [ip] [port]
");
}

int main(int argc, char* argv[]) {
    // 确保命令行参数数量正确(应为3个:程序名、IP地址和端口号)
    if (argc != 3) {
        Usage();
        return 1;
    }

    // 创建一个基于IPv4的TCP套接字
    int fd = socket(AF_INET, SOCK_STREAM, 0);
    if (fd < 0) {
        perror("socket"); // 如果创建失败,打印错误信息
        return 1;
    }

    struct sockaddr_in addr; // 定义一个地址结构体
    addr.sin_family = AF_INET; // 设置为IPv4地址族
    addr.sin_addr.s_addr = inet_addr(argv[1]); // 设置IP地址
    addr.sin_port = htons(atoi(argv[2])); // 设置端口号,并转换为网络字节序

    // 将套接字绑定到指定的IP地址和端口
    int ret = bind(fd, (struct sockaddr*)&addr, sizeof(addr));
    if (ret < 0) {
        perror("bind"); // 如果绑定失败,打印错误信息
        return 1;
    }

    // 开始监听传入的连接,允许最多10个连接同时等待
    ret = listen(fd, 10);
    if (ret < 0) {
        perror("listen"); // 如果监听失败,打印错误信息
        return 1;
    }

    // 无限循环,持续接受客户端的连接
    for (;;) {
        struct sockaddr_in client_addr; // 定义客户端地址结构体
        socklen_t len = sizeof(client_addr); // 定义长度变量
        // 接受一个客户端连接,并将客户端的地址信息存储在client_addr中
        int client_fd = accept(fd, (struct sockaddr*)&client_addr, &len);
        if (client_fd < 0) {
            perror("accept"); // 如果接受连接失败,打印错误信息
            continue; // 继续下一次循环
        }

        // 定义一个缓冲区,用于存储从客户端读取的数据
        char input_buf[1024 * 10] = {0};
        // 从客户端读取数据,最多读取缓冲区大小-1字节
        ssize_t read_size = read(client_fd, input_buf, sizeof(input_buf) - 1);
        if (read_size < 0) {
            perror("read"); // 如果读取失败,打印错误信息
            close(client_fd); // 关闭客户端套接字
            continue; // 继续下一次循环
        }

        // 打印接收到的请求
        printf("[Request] %s
", input_buf);

        // 定义一个缓冲区,用于存储响应数据
        char buf[1024] = {0};
        // 定义要发送的HTML内容
        const char* hello = "

hello world

"; // 格式化HTTP响应消息,包括HTTP头部和HTML内容 sprintf(buf, "HTTP/1.0 200 OK Content-Length:%lu %s", strlen(hello), hello); // 将响应消息发送回客户端 write(client_fd, buf, strlen(buf)); // 关闭客户端套接字 close(client_fd); } // 关闭服务器套接字 close(fd); return 0; // 正常退出 }

二.服务器 2.0

Protocol.hpp

#pragma once

#include 
#include 

using namespace std;

//客户端
class httpRequest
{

public:
    httpRequest(){};
    ~httpRequest(){};

public:
    string inbuffer;//缓冲区
    
 //简单一点主要看一下http的细节
    // string reqline;//请求行
    // vector reqheader;//报头
    // string body;//请求正文
    
    //第一行细分
    // string method;
    // string url;
    // string httpversion;
};

//服务器
class httpResponse
{

public:
    string outbuffer;//缓冲区
};

httpServer.hpp

#pragma once
// 确保头文件只被包含一次

#include "Protocol.hpp"
// 包含自定义的协议处理头文件,可能定义了 httpRequest 和 httpResponse 类

#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 


using namespace std;

// 定义错误码枚举
enum {
    USAGG_ERR = 1, // 使用错误
    SOCKET_ERR,     // 套接字创建错误
    BIND_ERR,       // 绑定错误
    LISTEN_ERR      // 监听错误
};

const int backlog = 5;
// 定义监听队列的最大长度

// 定义函数类型别名,用于处理HTTP请求和响应的回调函数
typedef function func_t;

// 处理HTTP请求的函数
void handlerEntery(int sock,func_t callback)
{
    // 1. 读到完整的http请求
    // 2. 反序列化
    // 3. httprequst, httpresponse, callback(req, resp)
    // 4. resp序列化
    // 5. send
	
	char buffer[4096];
    httpRequest req;
    httpResponse resp;
    ssize_t n=recv(sock,buffer,sizeof(buffer)-1,0);//大概率我们直接就能读取到完整的http请求
    if(n>0)
    {
        buffer[n]=0;
        req.inbuffer=buffer;
        callback(req,resp);
        send(sock,resp.outbuffer.c_str(),resp.outbuffer.size(),0);
    }
}


// HTTP服务器类
class httpServer {
public:
    // 构造函数,初始化端口号和监听套接字
    httpServer(const uint16_t port) : _port(port), _listensock(-1) {}

    // 初始化服务器
    void initServer() {
        // 创建套接字
        _listensock = socket(AF_INET, SOCK_STREAM, 0);
        if (_listensock < 0) {
            exit(SOCKET_ERR); // 如果创建失败,退出程序
        }

        // 绑定套接字到本地地址和端口
        struct sockaddr_in local;
        memset(&local, 0, sizeof(local));
        local.sin_family = AF_INET;
        local.sin_port = htons(_port);
        local.sin_addr.s_addr = INADDR_ANY; // 绑定到任意地址

        if (bind(_listensock, (struct sockaddr *)&local, sizeof(local)) < 0) {
            exit(BIND_ERR); // 如果绑定失败,退出程序
        }

        // 设置套接字为监听状态
        if (listen(_listensock, backlog) < 0) { // 设置监听队列长度
            exit(LISTEN_ERR); // 如果监听失败,退出程序
        }
    }

    // 启动服务器,处理请求
    void start(func_t func) {
        // 忽略子进程结束的信号
        signal(SIGCHLD, SIG_IGN);
        for (;;) { // 无限循环,等待连接
            // 接受新连接
            struct sockaddr_in peer;
            socklen_t len = sizeof(peer);
            int sock = accept(_listensock, (struct sockaddr *)&peer, &len);
            if (sock < 0) {
                continue; // 如果接受失败,继续下一次循环
            }

            // 创建子进程处理连接
            int fd = fork();
            if (fd == 0) {
                close(_listensock); // 子进程关闭监听套接字
                handlerEntery(sock, func); // 处理HTTP请求
                close(sock); // 处理完毕后关闭连接套接字
                exit(0); // 子进程退出
            }
            close(sock); // 父进程关闭连接套接字
        }
    }

    // 析构函数
    ~httpServer() {
        // 可以在这里进行资源清理
    }

private:
    uint16_t _port; // 服务器监听的端口号
    int _listensock; // 监听套接字的文件描述符
};

⭕ 如何理解这个地方子进程的退出和关闭?

start 函数中,服务器通过 fork() 系统调用创建子进程来处理每个新的连接。以下是对子进程退出和关闭操作的详细解释:

子进程的创建和退出

  1. 创建子进程:
    • int fd = fork();: 这行代码是创建子进程的关键。fork() 调用会创建一个新的子进程。在父进程中,fork() 返回子进程的进程ID;在子进程中,fork() 返回0。
  1. 在子进程中 (if (fd == 0)):
    • close(_listensock);: 子进程不需要监听新的连接,因此它关闭监听套接字。这是因为监听套接字由父进程负责,并且所有子进程都会继承父进程的文件描述符。
    • handlerEntery(sock, func);: 子进程调用 handlerEntery 函数来处理HTTP请求。这个函数会读取请求、反序列化、调用回调函数处理请求、序列化响应并发送响应。
    • close(sock);: 在处理完请求并发送响应后,子进程关闭与客户端的连接套接字,因为它不再需要这个套接字。
    • exit(0);: 子进程通过 exit(0) 退出。这个调用会导致子进程终止,并且操作系统会回收子进程占用的所有资源。

子进程退出的意义

  • 资源回收: 当子进程退出时,操作系统会自动回收子进程所占用的所有资源,包括打开的文件描述符、内存等。这是非常重要的,因为如果不回收资源,可能会导致资源泄漏。
  • 避免僵尸进程: 在调用 fork() 之前,父进程通过 signal(SIGCHLD, SIG_IGN); 忽略了 SIGCHLD 信号。这意味着当子进程结束时,父进程不会收到通知,操作系统会自动清理掉子进程,防止产生僵尸进程。

父进程关闭连接套接字

  • close(sock);: 在父进程中,fork() 返回的是子进程的ID,因此父进程不会进入 if (fd == 0) 块。父进程也不需要这个与客户端的连接套接字,因为它只负责监听新的连接,所以它关闭这个套接字。
    总结来说,子进程的退出和关闭操作确保了每个HTTP请求都能被单独的子进程处理,并且在处理完成后,子进程能够干净地退出,不会留下僵尸进程或资源泄漏。父进程继续监听新的连接请求,而子进程则负责处理已经接受的连接。

httpServer.cc

#include "httpServer.hpp"
#include 

// 打印程序使用方法的函数
void Usage(const string& proc) {
    cout << "
Usage:
	" << proc << " local_port

";
}

// 处理HTTP GET请求的函数,参数为请求和响应对象
void Get(const httpRequest &req, httpResponse &resp)
{

    cout << "----------------http start---------------" << endl;
    cout << req.inbuffer << endl;
    cout << "----------------http end-----------------" << endl;

     string respline = "HTTP/1.1 200 OK
";
    // string respheader;
     string respblank = "
";
	
	//随便做一个网页
     string body="for test

hello world

你好呀 祝你天天开心~

"; //序列化 resp.outbuffer += respline; resp.outbuffer += respblank; resp.outbuffer += body; } // 程序入口点 int main(int argc, char* argv[]) { // 检查命令行参数数 量是否正确 if (argc != 2) { // 如果参数数量不正确,显示使用方法并退出 Usage(argv[0]); exit(USAGG_ERR); // 假设 USAGG_ERR 是一个定义的错误代码 } // 将命令行参数转换为端口号 uint16_t serverport = static_cast(atoi(argv[1])); // 使用智能指针创建httpServer实例,自动管理内存 std::unique_ptr server(new httpServer(serverport)); // 初始化服务器 server->initServer(); // 启动服务器,并传入Get函数作为处理HTTP请求的回调 server->start(Get); // 程序正常结束 return 0; }

⭕ 解释argc 和argv的设计与运用

在C和C++程序中,argcargvmain 函数的两个参数,它们用于处理命令行参数。

argc (argument count)

argc 是一个整数,代表传递给程序的命令行参数的数量。它至少总是为1,因为 argv[0] 总是包含程序的名称或路径。

argv (argument vector)

argv 是一个指向字符指针的指针,它指向一个字符串数组,这些字符串包含了程序的命令行参数。argv[0] 是程序的名称或路径,argv[1] 是第一个命令行参数,依此类推。
以下是 argcargv 在上述代码中的设计与运用:

  1. 程序入口点:
int main(int argc, char* argv[]) {

这里 main 函数接收 argcargv 作为参数。

  1. 检查参数数量:
if (argc != 2) {

程序期望用户输入一个命令行参数,即端口号。如果 argc 不等于2(程序名称和一个参数),则说明用户没有正确输入参数。

  1. 打印使用方法:
Usage(argv[0]);

如果参数数量不正确,程序调用 Usage 函数,并传递 argv[0] 作为参数,这通常是程序的名称。Usage 函数会打印出如何正确使用程序的信息。

  1. 获取端口号:
uint16_t serverport = static_cast(atoi(argv[1]));

程序将 argv[1](第一个命令行参数,即用户输入的端口号字符串)转换为整数,并将其存储在 serverport 变量中。

  1. 启动服务器:
    程序使用 serverport 来初始化和启动 httpServer 实例。
    通过这种方式,argcargv 提供了一种灵活的方式来从命令行接收用户输入,使得程序可以根据不同的输入执行不同的操作。在上述代码中,它们用于指定HTTP服务器监听的端口号。如果用户没有提供正确的参数,程序会提示正确的使用方法并退出。

我们发现udp、tcp、http所有的底层逻辑都是差不多的,而我们只要写上层逻辑就好了。

这里我们主要说原理,下面1-5的工作我们都不做了,所以httpRequest,httpResponse也都给一个缓冲区就行了。

callback 的是 Get 函数

下面我们用浏览器充当客户端发起请求看一下结果

无法访问,我们来开放一下端口号,腾讯云可以直接在小程序上开,就还挺方便的~

然后就可以看到

报头我们暂时不要后面慢慢填,正文部分我们搞一个网页。
网页不会写,可以搜一下w3cschool html教程

这里我们先写到Get函数里,后面我们在分离

void Get(const httpRequest &req, httpResponse &resp)
{

    cout << "----------------http start---------------" << endl;
    cout << req.inbuffer << endl;
    cout << "----------------http end-----------------" << endl;

     string respline = "HTTP/1.1 200 OK
";
    // string respheader;
     string respblank = "
";
	
	//随便做一个网页
     string body="for test

hello world

你好呀 祝你天天开心~

"; //序列化 resp.outbuffer += respline; resp.outbuffer += respblank; resp.outbuffer += body; }

虽然我们在响应的时候没有带响应报头,但是我们的浏览器依旧是能识别的,这里想说的是现在浏览器很智能了,可以不用告诉它正文是什么也可以根据正文内容识别这是什么东西,但是有的浏览器做不到。这里我们用的是chrome浏览器。

如果我们要加一个报头里面可以带一些属性呢?

如Content-Type ,告诉别人返回的是什么资源。网上可以搜一下Content-Type 对照表,来进行添加

三.服务器和网页分离

简单实现之后,我们来解决服务器和网页分离,然后通过服务器把网页返回

引入:

在C++中,istringstream 类是在 头文件中定义的,所以你需要包含这个头文件来使用 istringstream 对象。下面是如何在代码中包含它的示例:

#include 
int main() {
    std::string line = "一些文本";
    std::istringstream iss(line);
    // ... 使用 iss ...
    return 0;
}

在这个例子中,istringstream 被用来从字符串 line 中读取数据,就像从文件中读取一样。

运用更新:

#pragma once

#include 
#include 
#include 
using namespace std;

class Util
{
public:
    // xxx yyy zzz
aaa
    static string GetOneline(string &buffer, const string &sep)
    {
        auto pos = buffer.find(sep);
        if (pos == string::npos)
            return "";
        string sub = buffer.substr(0, pos);
        return sub;
    }
};


const string sep = "
";//切割符

class httpRequest
{

public:
    httpRequest(){};
    ~httpRequest(){};

    void parse()
    {
        // 1. 从inbuffer中拿到第一行,分隔符

        string line = Util::GetOneline(inbuffer, sep);
        if (line.empty())
            return;
            
        // 2. 从请求行中提取三个字段
        istringstream iss(line);
        iss >> method >> url >> httpversion;

    }

public:
    string inbuffer;
    // string reqline;
    // vector reqheader;
    // string body;

    string method;
    string url;
    string httpversion;
};

//服务器
class httpResponse
{

public:
    string outbuffer;//缓冲区
};
#pragma once

#include 
#include 

using namespace std;

class Util
{
public:
    // xxx yyy zzz
aaa
    static string GetOneline(string &buffer, const string &sep)
    {
        auto pos = buffer.find(sep);
        if (pos == string::npos)
            return "";
        string sub = buffer.substr(0, pos);
        return sub;
    }
};

什么是web根目录

实际上未来一个web服务器写好之后,可不仅仅有这些代码。每一个web服务器都有web根目录,未来所有图片、视频、音频等各种web资源都在这个目录下,按照目录结构组织号好,未来想请求资源就从url请求。那如何保证按照我们的需求在指定路径下去寻找呢?

设计如下目录

err.html




  
    
    404 Not Found
    
  

  
    

404

页面未找到

您请求的页面可能已经被删除、更名或者您输入的网址有误。
请尝试使用以下链接或者自行搜索:

百度一下>

index.html:




  
    
    
    Document
  

  
    
    

这个是我们的首页

实现分离:

现在我们给网页添加一下功能,比如说网页是支持点击然后跳转链接的

跳转成功啦~


思考与补充:

1.请求和响应怎么保证应用层完整读取完毕了呢?

首先我们发现http请求都是字符串按行为单位,所以

  1. 我可以读取完整的一行
  2. while(读取完整一行) --> 所有的请求行+请求行报文全部读完 --> 直到空行!
  3. 我们没说正文也是按行为单位分开的没有办法保证把正文读完,但是我们能保证把报头读完,而报头里有一个Content-Length:xxx(代表正文长度)
  4. 解析出来内容长度,在根据内容长度,读取正文即可!

2.请求和响应是怎么做到序列化和反序列化的?

  • http是用的特殊字符自己实现的。http序列化什么都不做直接发就好了,反序列化 :第一行+请求/响应报头,只要按照 将字符串1->n即可!不用借助任何东西如Json
  • protobuf等。而正文序列化反序列也不用做直接发送就行了。如果你的正文携带结构化数据就要自己处理了。
  • 上面我们也通过写代码的方式,验证上面说的东西。
  • 以前写udp和tcp我们都写过服务端用过套接字,这里还是直接拿过来用啦

3. 如何监视查看网页端

按图片操纵即可

就可以查看到啦

下篇文章将继续讲解网页对图片的插入,和 http 设计的详细解读~

本文地址:https://www.yitenyun.com/3632.html

搜索文章

Tags

#ios面试 #ios弱网 #断点续传 #ios开发 #objective-c #ios #ios缓存 #远程工作 #服务器 #python #pip #conda 香港站群服务器 多IP服务器 香港站群 站群服务器 #kubernetes #笔记 #平面 #容器 #linux #学习方法 #运维 #Trae #IDE #AI 原生集成开发环境 #Trae AI #低代码 #爬虫 #音视频 #物联网 #websocket #进程控制 #学习 #开发语言 #云原生 #iventoy #VmWare #OpenEuler #分阶段策略 #模型协议 #人工智能 #docker #后端 #数据库 #MobaXterm #ubuntu #数信院生信服务器 #Rstudio #生信入门 #生信云服务器 #vscode #mobaxterm #深度学习 #计算机视觉 #内网穿透 #网络 #cpolar #node.js #fastapi #html #css #unity #c# #游戏引擎 #Conda # 私有索引 # 包管理 #科技 #自然语言处理 #神经网络 #算法 #大数据 #github #git #开源 #golang #java #redis #缓存 #web安全 #安全 #kylin #vllm #大模型 #Streamlit #Qwen #本地部署 #AI聊天机器人 #nginx #tcp/ip #RTP over RTSP #RTP over TCP #RTSP服务器 #RTP #TCP发送RTP #FTP服务器 #android #腾讯云 #centos #ssh #需求分析 #Dell #PowerEdge620 #内存 #硬盘 #RAID5 #jvm #hadoop #hbase #hive #zookeeper #spark #kafka #flink #我的世界 #华为云 #部署上线 #动静分离 #Nginx #新人首发 #http #c++ #性能优化 #asp.net大文件上传 #asp.net大文件上传下载 #asp.net大文件上传源码 #ASP.NET断点续传 #asp.net上传文件夹 #云计算 #ping通服务器 #读不了内网数据库 #bug菌问答团队 #银河麒麟高级服务器操作系统安装 #银河麒麟高级服务器V11配置 #设置基础软件仓库时出错 #银河麒高级服务器系统的实操教程 #生产级部署银河麒麟服务系统教程 #Linux系统的快速上手教程 #asp.net #ide #qt #架构 #计算机网络 #面试 #课程设计 #fiddler #c语言 #stm32 #华为 #ModelEngine #银河麒麟 #系统升级 #信创 #国产化 #多个客户端访问 #IO多路复用 #回显服务器 #TCP相关API #AI编程 #C++ #凤希AI伴侣 #gpu算力 #编辑器 #udp #研发管理 #禅道 #禅道云端部署 #json #RAID #RAID技术 #磁盘 #存储 #电脑 #自动化 #jmeter #功能测试 #软件测试 #自动化测试 #职场和发展 #elasticsearch #prometheus #grafana #Harbor #ollama #ai #llm #todesk #RustDesk #IndexTTS 2.0 #本地化部署 #毕业设计 #车辆排放 #Spring AI #MCP服务器 #STDIO协议 #Streamable-HTTP #McpTool注解 #服务器能力 #Android #Bluedroid #智能手机 #游戏 #flutter #数码相机 #SSH #X11转发 #Miniconda #windows #MCP #debian #改行学it #创业创新 #程序员创富 #压力测试 #flask #openlayers #bmap #tile #server #vue #1024程序员节 #php #前端 #claude #arm开发 #网络协议 #uni-app #小程序 #notepad++ #信令服务器 #Janus #MediaSoup #jenkins #jar #mysql #sqlserver #版本控制 #Git入门 #开发工具 #代码托管 #个人博客 #deepseek #制造 #n8n #cpp #项目 #高并发 #企业开发 #ERP #项目实践 #.NET开发 #C#编程 #编程与数学 #嵌入式编译 #ccache #distcc #gemini #gemini国内访问 #gemini api #gemini中转搭建 #Cloudflare #screen 命令 #分布式 #智能路由器 #django #mvp #个人开发 #设计模式 #树莓派4b安装系统 #oracle #SA-PEKS # 关键词猜测攻击 # 盲签名 # 限速机制 #时序数据库 #DisM++ # GLM-4.6V # 系统维护 #我的世界服务器搭建 #minecraft #金融 #mcp #金融投资Agent #Agent #京东云 #AIGC #ida #AI #大模型学习 #Ansible #Playbook #AI服务器 #MC #svn #javascript #流媒体 #NAS #飞牛NAS #监控 #NVR #EasyNVR #毕设 #vue.js #spring boot #vuejs #eBPF #高级IO #select #SPA #单页应用 #web3.py #语音识别 #说话人验证 #声纹识别 #CAM++ #swagger #visual studio code #测试工具 #ansible #麒麟OS #ci/cd #gitlab #pycharm #gitea #macos #微服务 #p2p #Windows #网站 #截图工具 #批量处理图片 #图片格式转换 #图片裁剪 #单片机 #嵌入式硬件 #mcu #网络安全 #阿里云 #journalctl #epoll #扩展屏应用开发 #android runtime #SSE # AI翻译机 # 实时翻译 #sqlite #openresty #lua #无人机 #Deepoc #具身模型 #开发板 #未来 #wordpress #雨云 #电气工程 #C# #PLC #聊天小程序 #NFC #智能公交 #服务器计费 #数据挖掘 #FP-增长 #tdengine #涛思数据 #apache #AI论文写作工具 #学术论文创作 #论文效率提升 #MBA论文写作 #tensorflow #arm #libosinfo #Proxmox VE #虚拟化 #VMware #spring #交互 #GPU服务器 #8U #硬件架构 #NPU #CANN #TCP #客户端 #嵌入式 #DIY机器人工房 #maven #ui #cosmic #windows11 #microsoft #系统修复 #集成测试 #H5 #跨域 #发布上线后跨域报错 #请求接口跨域问题解决 #跨域请求代理配置 #request浏览器跨域 #远程桌面 #远程控制 #游戏机 #JumpServer #堡垒机 #万悟 #联通元景 #智能体 #镜像 #振镜 #振镜焊接 #teamviewer #scala #测试用例 #webrtc #idm #bash #jupyter #YOLO # Triton # 目标检测 #微信小程序 #微信 #健身房预约系统 #健身房管理系统 #健身管理系统 #密码学 #经验分享 #安卓 #北京百思可瑞教育 #百思可瑞教育 #北京百思教育 #SRS #直播 #数据结构 #milvus #springboot #知识库 #web server #请求处理流程 #鸭科夫 #逃离鸭科夫 #鸭科夫联机 #鸭科夫异地联机 #开服 #risc-v #react.js #SSH公钥认证 # PyTorch # 安全加固 #rocketmq #单元测试 #selenium #守护进程 #复用 #screen #系统架构 #PyTorch #CUDA #Triton #部署 #语言模型 #DeepSeek #昇腾300I DUO #Clawdbot #个人助理 #数字员工 #opencv #搜索引擎 #umeditor粘贴word #ueditor粘贴word #ueditor复制word #ueditor上传word图片 #pytorch #IPv6 #DNS #运维开发 #源码 #闲置物品交易系统 #transformer #chatgpt #东方仙盟 #ssl #API限流 # 频率限制 # 令牌桶算法 #iBMC #UltraISO #视频去字幕 #黑群晖 #虚拟机 #无U盘 #纯小白 #支付 #java-ee #蓝湖 #Axure原型发布 #prompt #YOLOv8 # Docker镜像 #计算机 #mamba #llama #uv #uvx #uv pip #npx #Ruff #pytest #算力一体机 #ai算力服务器 #蓝耘智算 #910B #昇腾 # 高并发部署 #laravel #aws #MQTT协议 #深度优先 #DFS #webpack #学术写作辅助 #论文创作效率提升 #AI写论文实测 #tomcat # 双因素认证 # TensorFlow #负载均衡 #sql #intellij-idea #rustdesk #postgresql #连接数据库报错 #YOLOFuse # Base64编码 # 多模态检测 #进程 #操作系统 #进程创建与终止 #shell #1panel #vmware #unity3d #服务器框架 #Fantasy #C语言 #bootstrap #信息与通信 #信号处理 #tcpdump #PTP_1588 #gPTP #embedding #Termux #Samba #Linux #机器学习 #kmeans #聚类 #文件IO #输入输出流 #ms-swift # 大模型 # 模型训练 #ShaderGraph #图形 #VMware Workstation16 #服务器操作系统 #Java #rust #硬件工程 #fpga开发 #进程等待 #wait #waitpid #Smokeping #pdf #程序员 #大模型教程 #AI大模型 #pve #结构体 #LangGraph #CLI #Python #JavaScript #langgraph.json #harmonyos #鸿蒙PC #GPU #AutoDL ##租显卡 #paddleocr #企业级存储 #网络设备 #工具集 #大模型应用 #API调用 #PyInstaller打包运行 #服务端部署 #大语言模型 #能源 #Android16 #音频性能实战 #音频进阶 #zotero #WebDAV #同步失败 #代理模式 #H5网页 #网页白屏 #H5页面空白 #资源加载问题 #打包部署后网页打不开 #HBuilderX #CTF #VMWare Tool #openEuler #欧拉 #儿童AI #图像生成 #星图GPU #插件 #开源软件 #麒麟 #r-tree # IndexTTS 2.0 # 自动化运维 #心理健康服务平台 #心理健康系统 #心理服务平台 #心理健康小程序 #SSH保活 #远程开发 #rdp #目标检测 #海外服务器安装宝塔面板 #业界资讯 #论文笔记 #langchain #大模型开发 #推荐算法 #adb #大模型部署 #mindie #大模型推理 #系统安全 #数据分析 #SSH反向隧道 # Miniconda # Jupyter远程访问 #idea #intellij idea #简单数论 #埃氏筛法 #mongodb #cursor #浏览器自动化 #python #信息可视化 #claude code #codex #code cli #ccusage #yum #uvicorn #uvloop #asgi #event #5G #https #eureka #memcache #大剑师 #nodejs面试题 #SSH免密登录 # CUDA #rtsp #转发 #C2000 #TI #实时控制MCU #AI服务器电源 #leetcode #Llama-Factory # 树莓派 # ARM架构 #三维 #3D #三维重建 #银河麒麟操作系统 #openssh #华为交换机 #信创终端 #neo4j #NoSQL #SQL # 大模型推理 #UDP的API使用 #处理器 #CVE-2025-61686 #漏洞 #路径遍历高危漏洞 #统信UOS #win10 #qemu #HeyGem # 服务器IP # 端口7860 #智能体来了 #智能体对传统行业冲击 #行业转型 #AI赋能 #echarts #Socket网络编程 #web服务器 #win11 #RAG #LLM #chat # GPU租赁 # 自建服务器 #YOLO26 #muduo #TcpServer #accept #高并发服务器 #MinIO服务器启动与配置详解 #clickhouse #arm64 #DHCP #agent #ai大模型 #实时音视频 #postman #copilot #chrome #微PE #硬盘克隆 #DiskGenius #媒体 #串口服务器 #Modbus #MOXA #GATT服务器 #蓝牙低功耗 #交通物流 #散列表 #哈希算法 #Host #web #渗透测试 #SSRF #手机h5网页浏览器 #安卓app #苹果ios APP #手机电脑开启摄像头并排查 #IO #硬件 #ArkUI #ArkTS #鸿蒙开发 #政务 #Nacos #分类 #PowerBI #企业 #powerbi #go #dify #puppeteer #googlecloud #KMS #slmgr #vnstat #文心一言 #AI智能体 #vp9 #POC #问答 #交付 #xlwings #Excel #攻防演练 #Java web #红队 #GB28181 #SIP信令 #SpringBoot #视频监控 #WT-2026-0001 #QVD-2026-4572 #smartermail #翻译 #spring cloud #nfs #iscsi #飞牛nas #fnos #前端框架 #系统管理 #服务 #Modbus-TCP #文件管理 #文件服务器 #jetty #管道Pipe #system V #scanf #printf #getchar #putchar #cin #cout #esp32教程 #SAP #ebs #metaerp #oracle ebs #muduo库 # 高并发 #diskinfo # 磁盘健康 #cesium #可视化 #国产化OS #排序算法 #jdk #排序 #青少年编程 #ddos #vps #计算几何 #斜率 #方向归一化 #叉积 # 批量管理 #aiohttp #asyncio #异步 #Anaconda配置云虚拟环境 #数据仓库 #软件 #本地生活 #电商系统 #商城 #vivado license #html5 #LoRA # lora-scripts # 模型微调 #fabric #可信计算技术 #openHiTLS #TLCP #DTLCP #商用密码算法 #ONLYOFFICE #MCP 服务器 #.netcore #Aluminium #Google #链表 #链表的销毁 #链表的排序 #链表倒置 #判断链表是否有环 #服务器繁忙 #CPU #reactjs #web3 #测评 #CCE #Dify-LLM #Flexus #Go并发 #高并发架构 #Goroutine #系统设计 #Dify #ARM架构 #鲲鹏 #.net #net core #kestrel #web-server #asp.net-core #智能家居 #mybatis #集成学习 #serverless #EMC存储 #存储维护 #NetApp存储 #spine #ipmitool #BMC # 黑屏模式 # TTS服务器 #C #MC群组服务器 #STDIO传输 #SSE传输 #WebMVC #WebFlux #企业微信 #云服务器 #个人电脑 #IndexTTS2 # 阿里云安骑士 # 木马查杀 #模型上下文协议 #MultiServerMCPC #load_mcp_tools #load_mcp_prompt #unix #C/C++ #编程 #c++高并发 #百万并发 #机器人 #CS2 #debian13 #mariadb #Spring AOP #程序人生 #uip #k8s #wsl #人大金仓 #Kingbase #信创国产化 #达梦数据库 #树莓派 #温湿度监控 #WhatsApp通知 #IoT #MySQL #word #MS #Materials #多进程 #python技巧 #raid #raid阵列 #SMTP # 内容安全 # Qwen3Guard #黑客技术 #文件上传漏洞 #Kylin-Server #国产操作系统 #服务器安装 #平板 #零售 #智能硬件 #vncdotool #链接VNC服务器 #如何隐藏光标 #A2A #GenAI #Langchain-Chatchat # 国产化服务器 # 信创 #ue5 #PyCharm # 远程调试 # YOLOFuse #numpy #bond #服务器链路聚合 #网卡绑定 #database #pjsip #VS Code调试配置 #LobeChat #vLLM #GPU加速 #FHSS #算力建设 #everything #人脸识别sdk #视频编解码 #人脸识别 #开源工具 #服务器解析漏洞 #nodejs #SSH密钥 #n8n解惑 #练习 #基础练习 #数组 #循环 #九九乘法表 #计算机实现 #dynadot #域名 #ETL管道 #向量存储 #数据预处理 #DocumentReader #elk #rabbitmq #esb接口 #走处理类报异常 #agi #ffmpeg #ZooKeeper #ZooKeeper面试题 #面试宝典 #深入解析 #log #网路编程 #CosyVoice3 # 语音合成 #smtp #smtp服务器 #PHP #银河麒麟部署 #银河麒麟部署文档 #银河麒麟linux #银河麒麟linux部署教程 #模拟退火算法 #广播 #组播 #并发服务器 #x86_64 #数字人系统 #homelab #Lattepanda #Jellyfin #Plex #Emby #Kodi #yolov12 #研究生life #ServBay #Ascend #MindIE #SFTP #zabbix #gpu #nvcc #cuda #nvidia #其他 #AI 推理 #NV #RXT4090显卡 #RTX4090 #深度学习服务器 #硬件选型 #SQL注入主机 #ESP32 # OTA升级 # 黄山派 #ansys #ansys问题解决办法 #Jetty # CosyVoice3 # 嵌入式服务器 # WebUI # 网络延迟 #ARM服务器 # 多模态推理 #ranger #MySQL8.0 # Connection refused #RK3576 #瑞芯微 #硬件设计 #VibeVoice # 云服务器 #devops #戴尔服务器 #戴尔730 #装系统 #sql注入 #junit #gRPC #注册中心 #ThingsBoard MCP #雨云服务器 #Minecraft服务器 #教程 #MCSM面板 #LangFlow # 智能运维 # 性能瓶颈分析 #代理 #鸿蒙 # 服务器IP访问 # 端口映射 # 服务器配置 # GPU #遛狗 #bug #c #自动化运维 #AI-native #excel # 批量部署 #数据安全 #注入漏洞 # 键鼠锁定 #wpf #远程连接 # 一锤定音 # 大模型微调 #工程设计 #预混 #扩散 #燃烧知识 #层流 #湍流 #WinSCP 下载安装教程 #FTP工具 #服务器文件传输 #nas # ControlMaster #scrapy #hibernate #AI写作 # RTX 3090 #node #le audio #蓝牙 #低功耗音频 #通信 #连接 #参数估计 #矩估计 #概率论 #LE Audio #BAP #es安装 #Node.js # child_process #Qwen3-14B # 大模型部署 # 私有化AI #模型训练 # 远程连接 #c++20 #仙盟创梦IDE #GLM-4.6V-Flash-WEB # AI视觉 # 本地部署 #动态规划 #dlms #dlms协议 #逻辑设备 #逻辑设置间权限 # REST API # GLM-4.6V-Flash-WEB #scikit-learn #随机森林 # keep-alive #安全威胁分析 #SSH跳板机 # Python3.11 #LVDS #高速ADC #DDR #Minecraft #PaperMC #我的世界服务器 #驱动开发 #3d #指针 #anaconda #虚拟环境 #kong #Kong Audio #Kong Audio3 #KongAudio3 #空音3 #空音 #中国民乐 #Gunicorn #WSGI #Flask #并发模型 #容器化 #性能调优 #视频 #screen命令 #小艺 #搜索 #模版 #函数 #类 #笔试 #门禁 #梯控 #智能一卡通 #门禁一卡通 #消费一卡通 #智能梯控 #一卡通 #源代码管理 #超时设置 #客户端/服务器 #网络编程 #挖矿 #Linux病毒 #OPCUA #ai编程 #azure #ambari #产品经理 #就业 #duckdb #数据恢复 #视频恢复 #视频修复 #RAID5恢复 #流媒体服务器恢复 #WEB #CMake #Make #多模态 #微调 #超参 #LLamafactory #框架搭建 #V11 #kylinos #状态模式 #dba #Tokio #流量监控 #KMS激活 #react native #Java程序员 #Java面试 #后端开发 #Spring源码 #Spring #Gateway #认证服务器集成详解 #CPU利用率 #CSDN #RSO #机器人操作系统 #ASR #SenseVoice #glibc #中间件 #论文阅读 #软件工程 #CVE-2025-68143 #CVE-2025-68144 #CVE-2025-68145 #weston #x11 #x11显示服务器 #证书 #winscp #后端框架 # 自动化部署 # VibeThinker # 数字人系统 # 远程部署 #数字化转型 #实体经济 #商业模式 #软件开发 #数智红包 #商业变革 #创业干货 #AB包 #Ubuntu服务器 #硬盘扩容 #命令行操作 #Tracker 服务器 #响应最快 #torrent 下载 #2026年 #Aria2 可用 #迅雷可用 #BT工具通用 #AI技术 #Zabbix #语音合成 #FASTMCP #Docker #高斯溅射 #运维工具 #网络攻击模型 #pyqt #产品运营 #Puppet # IndexTTS2 # TTS #联机教程 #局域网联机 #局域网联机教程 #局域网游戏 #KMS 激活 #AI智能棋盘 #Rock Pi S #边缘计算 #领域驱动 #移动端h5网页 #调用浏览器摄像头并拍照 #开启摄像头权限 #拍照后查看与上传服务器端 #摄像头黑屏打不开问题 #身体实验室 #健康认知重构 #系统思维 #微行动 #NEAT效应 #亚健康自救 #ICT人 #云开发 #服务器IO模型 #非阻塞轮询模型 #多任务并发模型 #异步信号模型 #多路复用模型 #工业级串口服务器 #串口转以太网 #串口设备联网通讯模块 #串口服务器选型 #ceph #漏洞挖掘 #入侵 #日志排查 #SSH别名 #BoringSSL #云计算运维 #asp.net上传大文件 #VPS #搭建 #群晖 # ARM服务器 # 鲲鹏 #http头信息 # 公钥认证 # 权限修复 #STUN #turn #ICE #生信 # HiChatBox # 离线AI #策略模式 #租显卡 #训练推理 #TCP服务器 #开发实战 #全文检索 #银河麒麟服务器系统 #蓝桥杯 #iot #Anything-LLM #IDC服务器 #私有化部署 #游戏美术 #技术美术 #游戏策划 #游戏程序 #用户体验 #汽车 #java大文件上传 #java大文件秒传 #java大文件上传下载 #java文件传输解决方案 #可撤销IBE #服务器辅助 #私钥更新 #安全性证明 #双线性Diffie-Hellman #bigtop #hdp #hue #kerberos #pencil #pencil.dev #设计 #短剧 #短剧小程序 #短剧系统 #微剧 #轻量化 #低配服务器 #nosql #docker安装seata #TLS协议 #HTTPS #漏洞修复 #运维安全 #全链路优化 #实战教程 #CNAS #CMA #程序文件 #数据报系统 #程序开发 #程序设计 #计算机毕业设计 #大作业 #wireshark #网络安全大赛 #Syslog #系统日志 #日志分析 #日志监控 #matlab #生产服务器问题查询 #日志过滤 #Autodl私有云 #深度服务器配置 # 水冷服务器 # 风冷服务器 #VoxCPM-1.5-TTS # 云端GPU # PyCharm宕机 #outlook #错误代码2603 #无网络连接 #2603 #智能制造 #供应链管理 #工业工程 #库存管理 #实时检测 #卷积神经网络 #AI生成 # outputs目录 # 自动化 #DAG #stl #IIS Crypto #云服务器选购 #Saas #线程 #ComfyUI # 推理服务器 #具身智能 #编程助手 #HarmonyOS APP #智慧城市 #esp32 arduino #决策树 #HistoryServer #Spark #YARN #jobhistory #海外短剧 #海外短剧app开发 #海外短剧系统开发 #短剧APP #短剧APP开发 #短剧系统开发 #海外短剧项目 #sglang #SSH Agent Forwarding # 容器化 #spring ai #oauth2 #数据可视化 #内存接口 # 澜起科技 # 服务器主板 #rtmp # 显卡驱动备份 #声源定位 #MUSIC #晶振 #程序定制 #毕设代做 #课设 #Hadoop #AI电商客服 #ROS # 局域网访问 # 批量处理 #nacos #银河麒麟aarch64 # 服务器迁移 # 回滚方案 #大模型入门 # 高温监控 #开关电源 #热敏电阻 #PTC热敏电阻 #文件传输 #电脑文件传输 #电脑传输文件 #电脑怎么传输文件到另一台电脑 #电脑传输文件到另一台电脑 #fs7TF # 远程访问 #性能 #优化 #RAM #npu #gpt #TensorRT # 推理优化 #企业存储 #RustFS #对象存储 #高可用 #Xshell #Finalshell #生物信息学 #组学 #远程软件 #音乐 #IntelliJ IDEA #Spring Boot #Coturn #TURN #内网 # 跳板机 #clawdbot #上下文工程 #langgraph #意图识别 #log4j #模块 #分布式数据库 #集中式数据库 #业务需求 #选型误 #WRF #WRFDA #建筑缺陷 #红外 #数据集 #SMARC #ARM #代理服务器 #rsync # 数据同步 # 代理转发 #blender #设计师 #图像处理 #视觉检测 #visual studio #多线程 #claudeCode #content7 #跳槽 #工作 #odoo #重构 #机器人学习 #HarmonyOS #Reactor #Apple AI #Apple 人工智能 #FoundationModel #Summarize #SwiftUI #空间计算 #原型模式 #数据访问 #gateway #Comate # 串口服务器 # NPort5630 #appche #视觉理解 #Moondream2 #多模态AI #I/O模型 #并发 #水平触发、边缘触发 #多路复用 #ftp #sftp #勒索病毒 #勒索软件 #加密算法 #.bixi勒索病毒 #数据加密 #CA证书 #YOLO识别 #YOLO环境搭建Windows #YOLO环境搭建Ubuntu #SSH复用 # 远程开发 # 轻量化镜像 # 边缘计算 #OpenHarmony #磁盘配额 #存储管理 #形考作业 #国家开放大学 #系统运维 #Python办公自动化 #Python办公 #C++ UA Server #SDK #跨平台开发 #eclipse #servlet #webgl #区块链 #mssql #opc #opc ua #opc模拟服务器 #lucene #cpu #机器视觉 #6D位姿 #量子计算 #UOS #海光K100 #统信 #语音生成 #TTS #Keycloak #Quarkus #AI编程需求分析 #Fun-ASR # 语音识别 #AI部署 # ms-swift #PN 结 #密码 #firefox #safari #服务器线程 # SSL通信 # 动态结构体 #RWK35xx #语音流 #实时传输 #b树 #超算中心 #PBS #lsf #报表制作 #职场 #用数据讲故事 #lvs #adobe #memory mcp #Cursor #nmodbus4类库使用教程 #docker-compose #目标跟踪 #数据迁移 #测速 #iperf #iperf3 #windbg分析蓝屏教程 #express #cherry studio #Buck #NVIDIA #算力 #交错并联 #DGX #gmssh #宝塔 #Exchange #内存治理 #宝塔面板部署RustDesk #RustDesk远程控制手机 #手机远程控制 #系统安装 #铁路桥梁 #DIC技术 #箱梁试验 #裂纹监测 #四点弯曲 #IFix #可再生能源 #绿色算力 #风电 #麦克风权限 #访问麦克风并录制音频 #麦克风录制音频后在线播放 #用户拒绝访问麦克风权限怎么办 #uniapp 安卓 苹果ios #将音频保存本地或上传服务器 # 环境迁移 #面向对象 #基础语法 #标识符 #常量与变量 #数据类型 #运算符与表达式 #matplotlib #安全架构 #AI应用编程 #gerrit #若依 #主板 #总体设计 #电源树 #框图 # GLM-TTS # 数据安全 #前端开发 #EN4FE #xshell #host key #TTS私有化 # IndexTTS # 音色克隆 #自由表达演说平台 #演说 #AI Agent #开发者工具 #okhttp #范式 #计算机外设 #数学建模 #数模美赛 #iphone #Karalon #AI Test #ip #流程图 #图论 #国产开源制品管理工具 #Hadess #一文上手 #健康医疗 #网安应急响应 # GLM # 服务连通性 #ET模式 #非阻塞 #remote-ssh #工程实践 #AI应用 #图像识别 #高考 #服务器开启 TLS v1.2 #IISCrypto 使用教程 #TLS 协议配置 #IIS 安全设置 #服务器运维工具 #uniapp #合法域名校验出错 #服务器域名配置不生效 #request域名配置 #已经配置好了但还是报错 #uniapp微信小程序 #华为od #华为机试 #API #taro #SSH跳转 #wps #Linux多线程 # GPU集群 #Beidou #北斗 #SSR #samba #simulink #mtgsig #美团医药 #美团医药mtgsig #美团医药mtgsig1.2 #信息安全 #信息收集 #poll #Socket #套接字 #I/O多路复用 #字节序 #传统行业 # AI部署 # TURN # NAT穿透 #材料工程 #智能电视 #MCP服务器注解 #异步支持 #方法筛选 #声明式编程 #自动筛选机制 #VMware创建虚拟机 #远程更新 #缓存更新 #多指令适配 #物料关联计划 #挖漏洞 #攻击溯源 #warp #JNI #pxe #防毒面罩 #防尘面罩 #free #vmstat #sar #sentinel #m3u8 #HLS #移动端H5网页 #APP安卓苹果ios #监控画面 直播视频流 #Prometheus #MinIO #DooTask #UEFI #BIOS #Legacy BIOS #Discord机器人 #云部署 #程序那些事 #r语言 #交换机 #三层交换机 #TRO #TRO侵权 #TRO和解 #xss #Ward #webdav #思爱普 #SAP S/4HANA #ABAP #NetWeaver #文生视频 #WAN2.2 #AI视频生成 #UDP协议 #日志模块 #考研 #国产PLM #瑞华丽PLM #瑞华丽 #PLM #统信操作系统 #markdown #建站 #电梯 #电梯运力 #电梯门禁 #2026年美赛C题代码 #2026年美赛 #esp32 #mosquito #WinDbg #Windows调试 #内存转储分析 #resnet50 #分类识别训练 #运维 #AI视频创作系统 #AI视频创作 #AI创作系统 #AI工具 #AI创作工具 #华为od机试 #华为od机考 #华为od最新上机考试题库 #华为OD题库 #华为OD机试双机位C卷 #od机考题库 #2025年 #FRP #Matrox MIL #二次开发 #数据采集 #浏览器指纹 #vertx #vert.x #vertx4 #runOnContext #自动化巡检 #Ubuntu #CS336 #Assignment #Experiments #TinyStories #Ablation #UDP套接字编程 #网络测试 #vue上传解决方案 #vue断点续传 #vue分片上传下载 #vue分块上传下载 #rag #反向代理 #jquery #分子动力学 #化工仿真 #小智 #ESP32编译服务器 #Ping #DNS域名解析 #期刊 #SCI #session #游戏服务器断线 #静脉曲张 #腿部健康 #运动 #JADX-AI 插件 #Linly-Talker # 数字人 # 服务器稳定性 #边缘AI # Kontron # SMARC-sAMX8 #电子电气架构 #系统工程与系统架构的内涵 #自动驾驶 #Routine #starrocks #OSS #L6 #L10 #L9 #OpenAI #故障 #阿里云RDS #composer #symfony #java-zookeeper #coffeescript #dubbo #二值化 #Canny边缘检测 #轮廓检测 #透视变换 #新浪微博 #传媒