最新资讯

  • Linux:网络编程套接字及UDP

Linux:网络编程套接字及UDP

2025-05-01 02:00:47 1 阅读

一、预备知识

1.1 理解网络通信的本质 

问题1:在进行网络通信的时候,是不是我们的两台机器在进行通信呢??

——>思考一下我们打开qq软件,他属于应用层,完成了数据的发送和接受……

1、用户使用应用层软件,完成数据的发送和接受

2、网络协议的中下三层,主要解决的是将数据安全可靠的送到远端机器

        而要使用软件进行通信,就得先把这个软件启动起来,也就是进程,所以网络通信的本质就是进程间通信!!只不过是不同主机下的进程!!

1.2 理解IP地址和端口号 

       既然我们要进行两个主机之间的进程间通信,那么我们就要知道如何找到对方吧! 所以我们需要有IP地址来作为寻找主机的唯一标识。

     可是光有IP地址就能完成通信了呢??想象一下发qq消息的例子,有了IP地址能够把消息发送到对方的机器上,可是对方机器有那么多进程,我怎么知道我要发给哪个进程呢??因此我们还需要有一个标识来区分出信息要交给哪个进程,所以我们需要有端口号!

端口号(port)是传输层协议的内容.

端口号是一个2字节16位的整数;

端口号用来标识一个进程, 告诉操作系统, 当前的这个数据要交给哪一个进程来处理;

一个端口号只能被一个进程占用.

所以IP地址 + 端口号能够标识网络上的某一台主机的某一个进程;

传输层协议(TCP和UDP)的数据段中有两个端口号, 分别叫做源端口号和目的端口号. 就是在描述 "数据是谁发的, 要 发给谁" 

 1.3 端口号VS进程ID 

        我们之前在学习系统编程的时候, 学习了pid表示唯一一个进程; 此处我们的端口号也是唯一表示一个进程. 那么这 两者之间是怎样的关系?

问题1:pid已经能够标识一台主机上进程的唯一性了,为什么要需要搞一个端口号

-——>(1)首先从技术角度绝对是可以的,但是如果我们把网络和系统都用这个pid,那么一旦系统改了,网络也要跟着改牵一发而动全身,所以不如单独设计一套专属于网络的数据来让系统和网络功能解耦有点像生活中,我们有唯一的身份证,但是在学校要有学号,在公司要有工号,也就是说,我们存在的意义相似,但这并不代表我就得和你一样!!(2)不是所有的进程都需要网络通信,但是所有的进程都要有pid

 

 问题2:可是我们的客户端怎么知道服务端的端口号是多少呢?

-——>所以端口号必须是众所周知、精心设计、被用户所知晓的!!app和服务端都是一个公司开发的,所以端口号肯定提前已经被内置进去了,我们用户并不需要关心,我们只需要知道打开了这个app然后发送请求,对方就一定可以收到   所以客户端默认必须得知道服务端的端口号,所以无法通信!

问题3:一个进程可以绑定多个端口号么?一个端口号可以绑定多个进程么?

--——> 一个进程可以绑定多个端口号!但是一个端口号不能绑定多个进程!因为我们只是想在网络通信的时候能通过端口号找到进程就行了!!

1.4 TCP vs UDP

TCP(Transmission Control Protocol 传输控制协议)

传输层协议

有连接

可靠传输

面向字节流 

UDP(User Datagram Protocol 用户数据报协议)

传输层协议

无连接

不可靠传输

面向数据报

 问题1:有连接和无连接怎么理解?

——>连接就好比我们打电话的时候,会先“喂”,其实就是确保连接了之后我们的沟通才是有效的,而无连接就好比我们发送邮件,要么不发要么就发一整块,反正我发了就行,至于你收到没有我并不关心

问题2:为什么tcp看起来比udp好这么多,那为啥udp还得存在呢??

——>计算机中很多词语都是中性的,并无褒贬之意(比如可靠和不可靠) ,就好比我们物理学的惰性气体,只不过是在描述他的特征而已

       可靠是有成本的,而不可靠会更简单,比如tcp为了可靠所以要能够制定一个策略能够知道数据包是否丢失然后进行重传,而你在数据包丢出之后在还没确保传输成功之前你必然会把报文信息在传输层一直维护着,否则你拿什么重传呢??又或者需要重传几次呢??万一数据乱序了你是不是还得排序、编序号??  而udp就是一拿到数据包就转手往下扔,他也懒得维护报文信息,因为他压根不关心数据包的发送情况。

      注意,可靠的前提是网络必须连通!!

 1.5 网络字节序

         我们已经知道,内存中的多字节数据相对于内存地址有大端和小端之分, 磁盘文件中的多字节数据相对于文件中的偏移地址也有大端小端之分, 网络数据流同样有大端小端之分. 那么如何定义网络数据流的地址呢?

发送主机通常将发送缓冲区中的数据按内存地址从低到高的顺序发出;

接收主机把从网络上接到的字节依次保存在接收缓冲区中,也是按内存地址从低到高的顺序保存;

因此,网络数据流的地址应这样规定:先发出的数据是低地址,后发出的数据是高地址.

TCP/IP协议规定,网络数据流应采用大端字节序,即低地址高字节.

不管这台主机是大端机还是小端机, 都会按照这个TCP/IP规定的网络字节序来发送/接收数据;

如果当前发送主机是小端, 就需要先将数据转成大端; 否则就忽略, 直接发送即可;

 问题:为什么要有网络字节序呢??

——>在网络还没出现之前,就已经有大端和小端之说了,但是他们谁也说服不了谁,因为都没有一个很成熟的方案能够证明大端好还是小端好,而且当时这个标准即使制定了也没啥收益,所以大家并没有这个动力,因此在市面上大端和小端的机器都是有的!!在以往单机的情况下,其实都不会有很大的影响

      但是后来网络产生后,通信双方并不清楚对方是小端还是大端,所以在解析对方的信息的时候就会出现问题(因为大端和小端的解析方法不一样),从而导致发送方和接收方数据不一致的问题。

     所以网络说:既然我无法改变你们,那么我就做个规定,我发送报文的时候必须包含当前机器是大端还是小端的信息,这样对方在收到这个数据包之后就可以根据这个字段来采取不同的解析方法。   

     可是这样也是不行的!!因为大端还是小端决定了解析的方法,所以即使你在报文里提示了当前数据是大端还是小端,我的解析方式如果是错的我也压根提取不到!!!

    所以我们网络又说了:既然这样,那我规定不管你机器是大端还是小端的,只要你把这个数据发到网络上,那就必须得是大端的!!所以这就要求小端机器如要想要进行网络通信,就必须得先把自己的数据变成大端的才能往网络里发!

       为使网络程序具有可移植性,使同样的C代码在大端和小端计算机上编译后都能正常运行,可以调用以下库函数做网络字节序和主机字节序的转换。 

这些函数名很好记,h表示host,n表示network,l表示32位长整数,s表示16位短整数。 

例如:htonl表示将32位的长整数从主机字节序转换为网络字节序,例如将IP地址转换后准备发送。 

如果主机是小端字节序,这些函数将参数做相应的大小端转换然后返回 ;

如果主机是大端字节序,这些 函数不做转换,将参数原封不动地返回。

1.6 socket接口

socket 常见API

// 创建 socket 文件描述符 (TCP/UDP, 客户端 + 服务器)

int socket(int domain, int type, int protocol);

// 绑定端口号 (TCP/UDP, 服务器)

int bind(int socket, const struct sockaddr *address, socklen_t address_len);

// 开始监听socket (TCP, 服务器)

int listen(int socket, int backlog);

// 接收请求 (TCP, 服务器)

int accept(int socket, struct sockaddr* address, socklen_t* address_len);

// 建立连接 (TCP, 客户端)

int connect(int sockfd, const struct sockaddr *addr, socklen_t addrlen);

1.7 套接字的种类

 所谓套接字 (Socket),就是对网络中不同主机上的应用进程之间进行双向通信的端点的抽象。

 套接字的种类:

1、域间套接字(同一个机器内) struct sockaddr_un

2、原始套接字(网络工具)

 原始套接字一般不关心传输层的东西,他一般是绕过传输层去考虑网络层和链路层,所以他一般被用来封装一些网络工具:比如网络装包、网络诊断……

3、网络套接字(用户间通信)struct sockaddr_in

 但是我们想将网络接口统一抽象化,所以参数的类型必须是统一的!

所以我们统一是用sockaddr这个类型,然后根据他的前16位来分辨他是哪一种类型的套接字,所以在使用接口的时候要做一个强转

 问题:为什么要用sockaddr这个结构,用void*不好吗?C语言不是经常用他来做任意类型转换吗?然后我们再用short强转一下不就拿到前面的数据了吗??

——>因为网络接口出来的时候C语言的标准还没有void* 之后再想改也很难改回来了!

二、UDP

2.1 服务端

 所需要的类型:

 int _sockfd;//创建套接字对应的文件描述符

 uint16_t _port;//端口号

 string _ip;//服务端的ip地址   bind 0 表示绑定任意地址

 bool _isrunning;//服务端是否正在运行

2.1.1 Init-创建服务端

注意:其实可以在构造函数里做  但是我们平时尽量不要在构造函数里做一些有风险的事情!! 

1、首先要创建套接字

第一个参数  是套接字的域,AF_LOCAL是本地的,AF_INET是网络ipv4的

第二个参数  是套接字的类型  SOCK_STREAM是面向字节流的(TCP),SOCK_DGRAM是面向数据报的(UDP)

第三个参数  是协议类型  目前默认为0

返回值是如果创建成功返回文件描述符 (相当于是一个可以写入网络的一个文件),如果创建失败返回-1

2、绑定套接字

第一个参数是 文件描述符

第二个参数是  套接字的类型  类型是sockaddr* 

第三个参数是  套接字类型的长度 类型是socklen_t

返回值:如果成功了就返回0,如果绑定失败就返回-1 

问题:输入型参数的sockaddr类型

(1)我们先创建出来之后,然后可以用bzero(有点像C语言的memset)将指针内容先清空然后再填充

(2)local.sin_family  表明这个通用类型是属于网络套接字还是域间套接字

(3)local.sin_port 端口号 

因为端口号必须在两个主机之间流通,所以必须传输到网络中!!因此要转成字节序!!

(4)local.sin_addr.s_addr    ip地址  但是我们用户一般习惯输出的是 点分十进制,所以我们必须把他转化成 4字节类型的整数

问题:如何快速将整数IP和字符串IP相转化?? 

但是我们的库里面提供了这样的方法!!

 (5)最后再bind绑定一下!

 全部代码:

    void Init()//创建服务器
    {
      //1、首先第一步是创建套接字  第一个是套接字的域  第二个是面向数据段  第三个是协议类型
      _sockfd=socket(AF_INET, SOCK_DGRAM, 0);
      if(_sockfd<0)//创建失败
      {
        lg(Fatal,"socket creat error,sockfd:%d",_sockfd);
        exit(SOCKET_ERR);
      }
      lg(Info,"socket creat success,sockfd:%d",_sockfd);
      //2、 绑定套接字    (要先把里面的字段给初始化了)
      //先初始化一下字段
      struct sockaddr_in local; //创建套接字类型  
      bzero(&local, sizeof(local)); //将类型都清空 然后我们再填
      local.sin_family=AF_INET;//family是用来表明这个类型是网络套接字还是域间套接字
      local.sin_port=htons(_port);//端口号必须要先变成网络字节序
      local.sin_addr.s_addr=inet_addr(_ip.c_str());// inet_addr () 函数的作用是将点分十进制 的IPv4地址转换成网络字节序列的长整型。
      //bind绑定一下
      if(bind(_sockfd,(const struct sockaddr *)&local, sizeof(local)) < 0)// socelen_t 类型
      {
         lg(Fatal, "bind error, errno: %d, err string: %s", errno, strerror(errno));
         exit(BIND_ERR);
      }
      lg(Info, "bind success, errno: %d, err string: %s", errno, strerror(errno));
    }

2.1.2 Run-服务器启动 

 1、先将客户端的套接字信息收回来,拿到客户端的信息

 因为udp不是面向字节流的,所以只能用recvfrom接口 

第一个参数是服务器文件描述符fd

第二个是接受客户端发送给我们的数据

第三个是数据的大小

第四个是接收的方式,0表示阻塞接收

第五个和第六个是输出型参数,将客户端发来的套接字信息拿到(可以获取客户端的ip和端口号)

2、将接受到的数据加工一下然后再发回给客户端

 第五个和第六个是输入型数,通过客户端套接字信息将处理后的数据发送过去

 当然,其实这里我们其实可以将这些数据交给一个回调函数去处理

全部代码:

  void Run(func_t func) // 启动服务器
  {
    _isrunning = true;
    char inbuffer[size];
    while (_isrunning) // 肯定服务器要一直跑
    {
      // 1、第一步是要将客户端的套接字信息(输出型参数)收回来
      struct sockaddr_in client;
      socklen_t len = sizeof(client);
      ssize_t n = recvfrom(_sockfd, inbuffer, sizeof(inbuffer) - 1, 0, (struct sockaddr *)&client, &len);
      if (n < 0)
      {
        lg(Warning, "recvfrom error, errno: %d, err string: %s", errno, strerror(errno));
        continue;
      }
      // 2、我们将收回来的信息当成字符串加工一下  然后返回给客户端
      inbuffer[n] = 0;
      std::string info = inbuffer;
      std::string echo_string = func(info);
      sendto(_sockfd, echo_string.c_str(), echo_string.size(), 0, (const sockaddr *)&client, len);
    }
  }

2.1.3 关于port和ip 

port:[0-1023]一般是系统内定的端口号,有固定的应用协议使用 

ip:禁止直接bind公网ip (在虚拟机上可以)(因为服务端的机器可能会有多个网卡、多个ip,所以我们不能只绑定一个!!)

2.1.4 查看当前的网络状态 

2.1.5 环回地址

 2.1.6 地址转换函数

只介绍基于IPv4的socket网络编程,sockaddr_in中的成员struct in_addr sin_addr表示32位 的IP地址

但是我们通常用点分十进制的字符串表示IP 地址,以下函数可以在字符串表示 和in_addr表示之间转换;

字符串转in_addr的函数:

in_addr转字符串的函数:

 其中inet_pton和inet_ntop不仅可以转换IPv4的in_addr,还可以转换IPv6的in6_addr,因此函数接口是void *addrptr。

实例:

2.1.7 关于inet_ntoa

      inet_ntoa这个函数返回了一个char*, 很显然是这个函数自己在内部为我们申请了一块内存来保存ip的结果. 那么是 否需要调用者手动释放呢? 

man手册上说, inet_ntoa函数, 是把这个返回结果放到了静态存储区. 这个时候不需要我们手动进行释放.

那么问题来了, 如果我们调用多次这个函数, 会有什么样的效果呢? 参见如下代码:

       因为inet_ntoa把结果放到自己内部的一个静态存储区, 这样第二次调用时的结果会覆盖掉上一次的结果

在APUE中, 明确提出inet_ntoa不是线程安全的函数;(多线程可能会出问题)

但是在centos7上测试, 并没有出现问题, 可能内部的实现加了互斥锁;

 在多线程环境下, 推荐使用inet_ntop, 这个函数由调用者提供一个缓冲区保存结果, 可以规避线程安全问 题;

2.2 UDP客户端 

1、创建客户端的套接字  

 

问题:client要bind吗??

——> 要!只不过不需要用户显示的bind!一般有OS自由随机选择!(因为我们多个app的客户端都会在同一个手机上,如果需要自己绑定的话,那么还需要各大开发商互相协商,因此我们都同意由OS来给我们随机分配)

一个端口号只能被一个进程bind,对server是如此,对于client,也是如此!

其实client的port是多少,其实不重要,只要能保证主机上的唯一性就可以!

系统什么时候给我bind呢?首次发送数据的时候

2、用户输入数据,然后将数据和套接字类型发给服务端

3、从服务端将信息接收回来

代码: 

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

using namespace std;

void Usage(std::string proc)
{
    std::cout << "

Usage: " << proc << " serverip serverport
"
              << std::endl;
}

// ./udpclient serverip serverport
int main(int argc,char* argv[]) //必须知道服务器的ip和端口号
{
    if(argc!=3)
    {
      Usage(argv[0]);
      exit(0);
    }
    string serverip = argv[1];
    uint16_t serverport = std::stoi(argv[2]);

    //1、第一步 创建套接字
    int sockfd=socket(AF_INET, SOCK_DGRAM, 0);
    if(sockfd<0)
    {
        cout << "socker error" << endl;
        return 1;
    }
    //传服务器套接字类型
    struct sockaddr_in server;//输出型参数
    bzero(&server, sizeof(server));
    server.sin_family = AF_INET;
    server.sin_port = htons(serverport); //?
    server.sin_addr.s_addr = inet_addr(serverip.c_str());
    socklen_t len = sizeof(server);
    //将数据发给服务端 然后再接受回来
    string message;
    char buffer[1024];
    while(true)
    {
        cout<<"please enter@";
        getline(cin,message);
       // 1. 数据 2. 给谁发 目的机
        sendto(sockfd, message.c_str(), message.size(), 0, (struct sockaddr *)&server, len);
        struct sockaddr_in temp;
        socklen_t len = sizeof(temp);
        ssize_t s = recvfrom(sockfd, buffer, 1023, 0, (struct sockaddr*)&temp, &len);//输出型参数
        //会将服务端的套接字带回来
        if(s > 0)
        {
            buffer[s] = 0;
            cout << buffer << endl;
        }
    } 
}

2.3 主函数 

将外部的方法传进去

#include"UdpServer.hpp"
#include 
void Usage(std::string proc)
{
    std::cout << "

Usage: " << proc << " port[1024+]
" << std::endl;
}
string Handler(const string &str)
{
    std::string res = "Server get a message: ";
    res += str;
    std::cout << res << std::endl;
    return res;
}

int main(int argc,char*argv[])
{
    if(argc != 2)
    {
        Usage(argv[0]);
        exit(0);
    }
    uint16_t port = std::stoi(argv[1]);
    unique_ptr svr(new UdpServer(port));
    svr->Init();
    svr->Run(Handler);
    return 0;
}

要先在云服务器那里开放一下端口 

这样就可以进行通信了!! 

2.4 模拟云服务器命令输入

我们从客户端那里获得的命令肯定不仅仅只是简单字符串接受,我们还可以根据传过来的字符串当成是命令!! 

有一个函数是popen 

#include"UdpServer.hpp"
#include 
#include 
void Usage(std::string proc)
{
    std::cout << "

Usage: " << proc << " port[1024+]
" << std::endl;
}
string Handler(const string &str)
{
    std::string res = "Server get a message: ";
    res += str;
    std::cout << res << std::endl;
    return res;
}
bool SafeCheck(const std::string &cmd)
{
     int safe = false;
     vector key_word = {        
          "rm",
        "mv",
         "cp",
         "kill",
         "sudo",
         "unlink",
         "uninstall",
         "yum",
         "top",
        "while"
     };
     for(auto &word : key_word)
     {
         auto pos = cmd.find(word);
         if(pos != std::string::npos) return false;
     }

     return true;
 }
std::string ExcuteCommand(const std::string &cmd)
{
    // SafeCheck(cmd);

    FILE *fp = popen(cmd.c_str(), "r");
    if(nullptr == fp)
    {
        perror("popen");
        return "error";
    }
    std::string result;
    char buffer[4096];
    while(true)
    {
        char *ok = fgets(buffer, sizeof(buffer), fp);
        if(ok == nullptr) break;
        result += buffer;
    }
    pclose(fp);

    return result;
}

int main(int argc,char*argv[])
{
    if(argc != 2)
    {
        Usage(argv[0]);
        exit(0);
    }
    uint16_t port = std::stoi(argv[1]);
    unique_ptr svr(new UdpServer(port));
    svr->Init();
    svr->Run(ExcuteCommand);
    return 0;
}

2.5 实现聊天室+多线程

1、我们需要有一个ip来标识消息是谁发的(其实我们服务端是可以拿到客户端的ip地址的!)

2、群聊的话,我们客户端发的消息必须所有人都得看到,所以我们需要在服务端维护一张用户列表(有人发言的似时候先检查一下是不是在用户列表里,如果不在的话就新增一下),然后当服务端接收到消息的时候要把所有的消息再广播给其他客户端。

(1)检查并添加新用户 

void CheckUser(const struct sockaddr_in &client, const string clientip, uint16_t clientport)
  {
    auto iter = online_user_.find(clientip);
    if (iter == online_user_.end())
    {
      online_user_.insert({clientip, client});
      std::cout << "[" << clientip << ":" << clientport << "] add to online user." << endl;
    }
  }

(2)将消息广播给所有客户端

void Broadcast(const string &info, const string clientip, uint16_t clientport)
  {
    for (const auto &user : online_user_)
    {
      std::string message = "[";
      message += clientip;
      message += ":";
      message += std::to_string(clientport);
      message += "]# ";
      message += info;
      socklen_t len = sizeof(user.second);
      sendto(_sockfd, message.c_str(), message.size(), 0, (struct sockaddr *)(&user.second), len);
    }
  }

 但是这样是有问题的,因为我们的客户端必须先进行getline之后才会收到其他的群聊信息,可是如果我们长时间不说话的话我就会一直看不到其他的群聊信息,就会被阻塞到getline中,因此我们这里必须要用多线程,然后一个线程发, 一个线程收,这样发一旦阻塞住了才不会影响到收!!

所以我们的客户端要改成多线程版的

#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include "Terminal.hpp"

using namespace std;

void Usage(std::string proc)
{
    std::cout << "

Usage: " << proc << " serverip serverport
"
              << std::endl;
}

struct ThreadData
{
    struct sockaddr_in server;
    int sockfd;
    std::string serverip;
};

void *recv_message(void *args)
{
    // OpenTerminal();
    ThreadData *td = static_cast(args);
    char buffer[1024];
    while (true)
    {
        memset(buffer, 0, sizeof(buffer));
        struct sockaddr_in temp;
        socklen_t len = sizeof(temp);

        ssize_t s = recvfrom(td->sockfd, buffer, 1023, 0, (struct sockaddr *)&temp, &len);
        if (s > 0)
        {
            buffer[s] = 0;
            cerr << buffer << endl;
        }
    }
}

void *send_message(void *args)
{
    ThreadData *td = static_cast(args);
    string message;
    socklen_t len = sizeof(td->server);

    std::string welcome = td->serverip;
    welcome += " comming...";
    sendto(td->sockfd, message.c_str(), message.size(), 0, (struct sockaddr *)&(td->server), len);

    while (true)
    {
        cout << "Please Enter@ ";
        getline(cin, message);

        // std::cout << message << std::endl;
        // 1. 数据 2. 给谁发
        sendto(td->sockfd, message.c_str(), message.size(), 0, (struct sockaddr *)&(td->server), len);
    }
}

// 多线程
// ./udpclient serverip serverport
int main(int argc, char *argv[])
{
    if (argc != 3)
    {
        Usage(argv[0]);
        exit(0);
    }
    std::string serverip = argv[1];
    uint16_t serverport = std::stoi(argv[2]);

    struct ThreadData td;
    bzero(&td.server, sizeof(td.server));
    td.server.sin_family = AF_INET;
    td.server.sin_port = htons(serverport); //?
    td.server.sin_addr.s_addr = inet_addr(serverip.c_str());

    td.sockfd = socket(AF_INET, SOCK_DGRAM, 0);
    if (td.sockfd < 0)
    {
        cout << "socker error" << endl;
        return 1;
    }

    td.serverip = serverip;

    pthread_t recvr, sender;
    pthread_create(&recvr, nullptr, recv_message, &td);
    pthread_create(&sender, nullptr, send_message, &td);

    pthread_join(recvr, nullptr);
    pthread_join(sender, nullptr);

    close(td.sockfd);
    return 0;
}

2.6 聊天窗口

我们希望能够实现聊天窗口 在下面发消息,在上面看到全部的消息

通过这个可以知道当前的终端是哪个文件

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

std::string terminal = "/dev/pts/1";
int OpenTerminal()
{
    int fd = open(terminal.c_str(), O_WRONLY);
    if(fd < 0)
    {
        std::cerr << "open terminal error" << std::endl;
        return 1;
    }
    dup2(fd, 2);

    // printf("hello world
");
    // close(fd);
    return 0;
}

然后该线程的接受到的消息都会往另一个终端上面写,这样就实现输出和输出分离了!! 

还有一种更为简单的做法

2.7 windows客户端交互 

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

搜索文章

Tags

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