最新资讯

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

Linux:网络编程套接字及UDP

2025-04-29 05:00:48 0 阅读

一、预备知识

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/5281.html

搜索文章

Tags

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