最新资讯

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

Linux:网络编程套接字及UDP

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

一、预备知识

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