最新资讯

  • 【Linux网络编程】第四弹---构建UDP服务器与字典翻译系统:源码结构与关键组件解析

【Linux网络编程】第四弹---构建UDP服务器与字典翻译系统:源码结构与关键组件解析

2026-01-28 20:00:21 栏目:最新资讯 2 阅读

个人主页: 熬夜学编程的小林

💗系列专栏: 【C语言详解】 【数据结构详解】【C++详解】【Linux系统编程】【Linux网络编程】

目录

1、UdpServer.hpp

1.1、函数对象声明

1.2、Server类基本结构

1.3、构造函数

1.4、Start()

2、Dict.hpp

2.1、基本结构

2.2、加载字典文件

2.3、构造函数

2.4、翻译函数

2.5、dict.txt

3、UdpServerMain.cc

4、完整源码

4.1、Dict.hpp

4.2、dict.txt

4.3、InetAddr.hpp

4.4、LockGuard.hpp

4.5、Log.hpp

4.6、Makefile

4.7、nocopy.hpp

4.8、UdpClientMain.cc

4.9、UdpServerMain.cc


上一弹我们能够完成客户端与服务端的正常通信,但是我们在实际生活中不仅仅是要进行通信,还需要完成某种功能,此弹实现一个英文翻译成中文版服务端!!

注意:此弹内容的实现是在上一弹的原始代码基础上修改的!!

1、UdpServer.hpp

Server类的基本实现没变,但是要增加实现中英文翻译成中文功能的执行函数(即函数类型成员变量),并适当调整构造函数和启动函数!!!

1.1、函数对象声明

此处需要实现一个英文翻译成中文的执行函数,因此函数参数是一个字符串,返回值也是一个字符串!!!

// 声明函数对象
using func_t = std::function;

1.2、Server类基本结构

基本结构与上一弹的Server类基本一致,只增加了函数对象类型!!!

class UdpServer : public nocopy
{
public:
    UdpServer(func_t func,uint16_t localport = glocalport);
    void InitServer();
    void Start();
    ~UdpServer();
private:
    int _sockfd;          // 文件描述符
    uint16_t _localport;  // 端口号
    bool _isrunning;

    func_t _func; // 执行相应函数
};

1.3、构造函数

 构造函数只需增加一个函数对象参数,初始化列表初始化变量即可!!!

UdpServer(func_t func,uint16_t localport = glocalport)
    : _func(func), _sockfd(gsockfd), _localport(localport), _isrunning(false)
{
}

1.4、Start()

上一弹的Start()函数是先接收客户端的消息,然后将客户端的消息发送回去此弹接收客户端的英文单词,然后服务端翻译成中文,然后将中文发送回去!!!

void Start()
{
    _isrunning = true;
    char inbuffer[1024];
    while (_isrunning)
    {
        // sleep(1);
        struct sockaddr_in peer;
        socklen_t len = sizeof(peer);
        // 接收客户端的英文单词
        ssize_t n = recvfrom(_sockfd, inbuffer, sizeof(inbuffer) - 1, 0, (struct sockaddr *)&peer, &len);
        if (n > 0)
        {
            InetAddr addr(peer);
            inbuffer[n] = 0;
            // 一个一个的单词
            std::cout << "[" << addr.Ip() << ":" << addr.Port() << "]# " << inbuffer << std::endl;
            
            std::string result = _func(inbuffer); // 执行翻译功能

            // 将翻译的中文结果发回客户端
            sendto(_sockfd,result.c_str(),result.size(),0,(struct sockaddr *)&peer,len);
        }
    }
}

2、Dict.hpp

Dict类执行加载字典文件和执行翻译的功能!!

2.1、基本结构

Dict成员包含一个存储字典的KV结构和一个文件路径

class Dict
{
private:
    // 加载字典文件
    void LoadDict(const std::string& path);
public:
    // 构造
    Dict(const std::string& dict_path);
    // 英语翻译为中文
    std::string Translate(std::string word);
    ~Dict()
    {}
private:
    std::unordered_map _dict; // 字典结构
    std::string _dict_path;                             // 文件路径
};

2.2、加载字典文件

注意:此处的字典文件是以冒号 + 空格来分割英文与中文的!

加载字典文件的本质是以KV的形式将英文单词和中文翻译插入到_dict哈希表中

 加载文件包含3个大的步骤:

  • 1、读方式打开文件
  • 2、按行读取内容[需要考虑中间有空格情况,一行中没找到分隔符情况]
  • 3、关闭文件
const static std::string sep = ": "; // 分隔符 冒号+空格

// 加载字典文件
void LoadDict(const std::string &path)
{
    // 1.读方式打开文件
    std::ifstream in(path);
    // 判断是否打开成功
    if (!in.is_open())
    {
        LOG(FATAL, "open %s failed
", path.c_str());
        exit(1);
    }

    std::string line;
    // 2.按行读取内容
    while (std::getline(in, line))
    {
        LOG(DEBUG, "load info : %s ,success
", line.c_str());
        if (line.empty())
            continue; // 中间有空格情况

        auto pos = line.find(sep); // 使用find找到分割符位置,返回迭代器位置
        if (pos == std::string::npos)
            continue; // 一行中没找到分隔符

        // apple: 苹果
        std::string key = line.substr(0, pos); // [) 前闭后开
        if (key.empty())
            continue;

        std::string value = line.substr(pos + sep.size()); // 从pos + 分隔符长度开始到结尾
        if (value.empty())
            continue;

        _dict.insert(std::make_pair(key, value));
    }
    LOG(INFO, "load %s done
", path.c_str());
    in.close(); // 3.关闭文件
}

2.3、构造函数

构造函数初始化字典文件和加载字典文件(将字典文件以KV格式插入到_dict中)。

// 构造
Dict(const std::string &dict_path) : _dict_path(dict_path)
{
    LoadDict(_dict_path);
}

2.4、翻译函数

翻译函数在_dict中查找是否有该单词,有该单词则返回_dict的value值(没找到返回None)

// 英语翻译为中文
std::string Translate(std::string word)
{
    if (word.empty())
        return "None";
    auto iter = _dict.find(word);
    if (iter == _dict.end())
        return "None";
    else
        return iter->second;
}

2.5、dict.txt

dict.txt文件存储对应的英文单词和翻译结果

apple: 苹果
banana: 香蕉
cat: 猫
dog: 狗
book: 书
pen: 笔
happy: 快乐的
sad: 悲伤的
run: 跑
jump: 跳
teacher: 老师
student: 学生
car: 汽车
bus: 公交车
love: 爱
hate: 恨
hello: 你好
goodbye: 再见
summer: 夏天
winter: 冬天

3、UdpServerMain.cc

服务端主函数基本结构没变,但是构造指针对象时需要传递翻译函数对象,但是这个函数对象的参数是字符串类型,返回值是字符串类型,而Dict类中的翻译函数有this指针,因此我们需要使用bind()绑定函数

// .udp_client local-port
// .udp_client 8888
int main(int argc, char *argv[])
{
    if (argc != 2)
    {
        std::cerr << "Usage: " << argv[0] << "  server-port" << std::endl;
        exit(0);
    }

    uint16_t port = std::stoi(argv[1]);
    EnableScreen();

    Dict dict("./dict.txt");                                                      // 构造字典类
    func_t translate = std::bind(&Dict::Translate, &dict, std::placeholders::_1); // 绑定翻译函数

    std::unique_ptr usvr = std::make_unique(translate, port); // C++14标准
    usvr->InitServer();
    usvr->Start();

    return 0;
}

运行结果 

4、完整源码

4.1、Dict.hpp

#pragma once

#include 
#include 
#include 
#include 
#include "Log.hpp"

using namespace log_ns;

const static std::string sep = ": "; // 分隔符 冒号+空格

class Dict
{
private:
    // 加载字典文件
    void LoadDict(const std::string &path)
    {
        // 1.读方式打开文件
        std::ifstream in(path);
        // 判断是否打开成功
        if (!in.is_open())
        {
            LOG(FATAL, "open %s failed
", path.c_str());
            exit(1);
        }

        std::string line;
        // 2.按行读取内容
        while (std::getline(in, line))
        {
            LOG(DEBUG, "load info : %s ,success
", line.c_str());
            if (line.empty())
                continue; // 中间有空格情况

            auto pos = line.find(sep); // 使用find找到分割符位置,返回迭代器位置
            if (pos == std::string::npos)
                continue; // 一行中没找到分隔符

            // apple: 苹果
            std::string key = line.substr(0, pos); // [) 前闭后开
            if (key.empty())
                continue;

            std::string value = line.substr(pos + sep.size()); // 从pos + 分隔符长度开始到结尾
            if (value.empty())
                continue;

            _dict.insert(std::make_pair(key, value));
        }
        LOG(INFO, "load %s done
", path.c_str());
        in.close(); // 3.关闭文件
    }

public:
    // 构造
    Dict(const std::string &dict_path) : _dict_path(dict_path)
    {
        LoadDict(_dict_path);
    }
    // 英语翻译为中文
    std::string Translate(std::string word)
    {
        if (word.empty())
            return "None";
        auto iter = _dict.find(word);
        if (iter == _dict.end())
            return "None";
        else
            return iter->second;
    }
    ~Dict()
    {
    }

private:
    std::unordered_map _dict; // 字典结构
    std::string _dict_path;                             // 文件路径
};

4.2、dict.txt

apple: 苹果
banana: 香蕉
cat: 猫
dog: 狗
book: 书
pen: 笔
happy: 快乐的
sad: 悲伤的
run: 跑
jump: 跳
teacher: 老师
student: 学生
car: 汽车
bus: 公交车
love: 爱
hate: 恨
hello: 你好
goodbye: 再见
summer: 夏天
winter: 冬天

4.3、InetAddr.hpp

#pragma once

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

class InetAddr
{
private:
    // 网络地址转本地地址 
    void ToHost(const struct sockaddr_in& addr) 
    {
        _port = ntohs(addr.sin_port); // 网络转主机
        _ip = inet_ntoa(addr.sin_addr); // 结构化转字符串
    }
public:
    InetAddr(const struct sockaddr_in& addr):_addr(addr)
    {
        ToHost(addr);
    }
    std::string Ip()
    {
        return _ip;
    }
    uint16_t Port()
    {
        return _port;
    }
    ~InetAddr()
    {}
private:
    std::string _ip;
    uint16_t _port;
    struct sockaddr_in _addr;
};

4.4、LockGuard.hpp

#pragma once 
#include 

class LockGuard
{
public:
    LockGuard(pthread_mutex_t* mutex):_mutex(mutex)
    {
        pthread_mutex_lock(_mutex);
    }
    ~LockGuard()
    {
        pthread_mutex_unlock(_mutex);
    }
private:
    pthread_mutex_t* _mutex;
};

4.5、Log.hpp

#pragma once

#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include "LockGuard.hpp"

namespace log_ns
{

    // 日志等级
    enum
    {
        DEBUG = 1,
        INFO,
        WARNING,
        ERROR,
        FATAL
    };

    std::string LevelToString(int level)
    {
        switch (level)
        {
        case DEBUG:
            return "DEBUG";
        case INFO:
            return "INFO";
        case WARNING:
            return "WARNING";
        case ERROR:
            return "ERROR";
        case FATAL:
            return "FATAL";
        default:
            return "UNKNOW";
        }
    }

    std::string GetCurrTime()
    {
        time_t now = time(nullptr); // 时间戳
        struct tm *curr_time = localtime(&now);
        char buffer[128];
        snprintf(buffer, sizeof(buffer), "%d-%02d-%02d %02d:%02d:%02d",
                    curr_time->tm_year + 1900,
                    curr_time->tm_mon + 1,
                    curr_time->tm_mday,
                    curr_time->tm_hour,
                    curr_time->tm_min,
                    curr_time->tm_sec);
        return buffer;
    }

    class logmessage
    {
    public:
        std::string _level;        // 日志等级
        pid_t _id;                 // pid
        std::string _filename;     // 文件名
        int _filenumber;           // 文件行号
        std::string _curr_time;    // 当前时间
        std::string _message_info; // 日志内容
    };

#define SCREEN_TYPE 1
#define FILE_TYPE 2

    const std::string glogfile = "./log.txt";
    pthread_mutex_t glock = PTHREAD_MUTEX_INITIALIZER;

    // log.logMessage(""/*文件名*/,12/*文件行号*/,INFO/*日志等级*/,"this is a %d message,%f,%s,hello world"/*日志内容*/,x,,);
    class Log
    {
    public:
        // 默认向显示器打印
        Log(const std::string &logfile = glogfile) : _logfile(logfile), _type(SCREEN_TYPE)
        {
        }
        // 打印方式
        void Enable(int type)
        {
            _type = type;
        }
        // 向屏幕打印
        void FlushToScreen(const logmessage &lg)
        {
            printf("[%s][%d][%s][%d][%s] %s",
                    lg._level.c_str(),
                    lg._id,
                    lg._filename.c_str(),
                    lg._filenumber,
                    lg._curr_time.c_str(),
                    lg._message_info.c_str());
        }
        // 向文件打印
        void FlushToFile(const logmessage &lg)
        {
            std::ofstream out(_logfile, std::ios::app); // 追加打开文件
            if (!out.is_open())
                return; // 打开失败直接返回

            char logtxt[2048];
            snprintf(logtxt, sizeof(logtxt), "[%s][%d][%s][%d][%s] %s",
                        lg._level.c_str(),
                        lg._id,
                        lg._filename.c_str(),
                        lg._filenumber,
                        lg._curr_time.c_str(),
                        lg._message_info.c_str());
            out.write(logtxt, strlen(logtxt)); // 写文件
            out.close();                       // 关闭文件
        }
        // 刷新日志
        void FlushLog(const logmessage &lg)
        {
            // 加过滤逻辑 --- TODO
            // ...

            LockGuard lockguard(&glock); // RAII锁
            switch (_type)
            {
            case SCREEN_TYPE:
                FlushToScreen(lg);
                break;
            case FILE_TYPE:
                FlushToFile(lg);
                break;
            }
        }
        // ... 可变参数(C语言)
        // 初始化日志信息
        void logMessage(std::string filename, int filenumber, int level, const char *format, ...)
        {
            logmessage lg;

            lg._level = LevelToString(level);
            lg._id = getpid();
            lg._filename = filename;
            lg._filenumber = filenumber;
            lg._curr_time = GetCurrTime();

            va_list ap;           // va_list-> char*指针
            va_start(ap, format); // 初始化一个va_list类型的变量
            char log_info[1024];
            vsnprintf(log_info, sizeof(log_info), format, ap);
            va_end(ap); // 释放由va_start宏初始化的va_list资源
            lg._message_info = log_info;

            // std::cout << lg._message_info << std::endl; // 测试
            // 日志打印出来(显示器/文件)
            FlushLog(lg);
        }
        ~Log()
        {
        }

    private:
        int _type;            // 打印方式
        std::string _logfile; // 文件名
    };

    Log lg;
// 打印日志封装成宏,使用函数方式调用
#define LOG(Level, Format, ...)                                          
    do                                                                   
    {                                                                    
        lg.logMessage(__FILE__, __LINE__, Level, Format, ##__VA_ARGS__); 
    } while (0)
// 设置打印方式,使用函数方式调用
#define EnableScreen()          
    do                          
    {                           
        lg.Enable(SCREEN_TYPE); 
    } while (0)
// 设置打印方式,使用函数方式调用
#define EnableFile()          
    do                        
    {                         
        lg.Enable(FILE_TYPE); 
    } while (0)

}

4.6、Makefile

.PHONY:all
all:udpserver udpclient

udpserver:UdpServerMain.cc
	g++ -o $@ $^ -std=c++14

udpclient:UdpClientMain.cc
	g++ -o $@ $^ -std=c++14

.PHONY:clean 
clean:
	rm -rf udpserver udpclient

4.7、nocopy.hpp

#pragma once

class nocopy
{
public:
    nocopy(){}
    ~nocopy(){}
    nocopy(const nocopy&) = delete;
    const nocopy& operator=(const nocopy&) = delete;
};

4.8、UdpClientMain.cc

#include "UdpServer.hpp"
#include 
#include 
#include 
#include 
#include 
#include 

// 客户端在未来一定要知道服务器的IP地址和端口号
// .udp_client server-ip server-port
// .udp_client 127.0.0.1 8888
int main(int argc, char *argv[])
{
    if (argc != 3)
    {
        std::cerr << "Usage: " << argv[0] << " server-ip server-port" << std::endl;
        exit(0);
    }

    std::string serverip = argv[1];
    uint16_t serverport = std::stoi(argv[2]);

    // 1.创建套接字
    int sockfd = ::socket(AF_INET, SOCK_DGRAM, 0);
    if (sockfd < 0)
    {
        std::cerr << "create socket eror
"
                  << std::endl;
        exit(1);
    }

    // client的端口号,一般不让用户自己设定,而是让client 所在OS随机选择?怎么选择?什么时候?
    // client 需要bind它自己的IP和端口,但是client 不需要 "显示" bind它自己的IP和端口
    // client 在首次向服务器发送数据的时候,OS会自动给client bind它自己的IP和端口

    struct sockaddr_in server;
    memset(&server, 0, sizeof(server));
    server.sin_family = AF_INET;
    server.sin_port = htons(serverport); // 转换重要!!!
    server.sin_addr.s_addr = inet_addr(serverip.c_str());

    while (true)
    {
        std::string line;
        std::cout << "Please Enter# ";
        std::getline(std::cin, line); // 以行读取消息
        // 发消息,你要知道发送给谁
        int n = sendto(sockfd, line.c_str(), line.size(), 0, (struct sockaddr *)&server, sizeof(server));
        if(n > 0)
        {
            // 收消息
            struct sockaddr_in temp;
            socklen_t len = sizeof(temp);
            char buffer[1024];
            int m = recvfrom(sockfd,buffer,sizeof(buffer),0,(struct sockaddr*)&temp,&len);
            if(m > 0)
            {
                buffer[m] = 0;
                std::cout << buffer << std::endl;
            }
            else
            {
                break;
            }
        }
        else
        {
            break;
        }
    }

    // 关闭套接字
    ::close(sockfd);
    return 0;
}

4.9、UdpServerMain.cc

#include "UdpServer.hpp"
#include "Dict.hpp"
#include 

// .udp_client local-port
// .udp_client 8888
int main(int argc, char *argv[])
{
    if (argc != 2)
    {
        std::cerr << "Usage: " << argv[0] << "  server-port" << std::endl;
        exit(0);
    }

    uint16_t port = std::stoi(argv[1]);
    EnableScreen();

    Dict dict("./dict.txt");                                                      // 构造字典类
    func_t translate = std::bind(&Dict::Translate, &dict, std::placeholders::_1); // 绑定翻译函数

    std::unique_ptr usvr = std::make_unique(translate, port); // C++14标准
    usvr->InitServer();
    usvr->Start();

    return 0;
}

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

搜索文章

Tags

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