最新资讯

  • Linux:线程池和单例模式

Linux:线程池和单例模式

2025-05-14 21:00:46 1 阅读

一、普通线程池

1.1 线程池概念 

线程池:一种线程使用模式。线程过多会带来调度开销,进而影响缓存局部性和整体性能。而线程池维护着多个线程,等待着监督管理者分配可并发执行的任务。这避免了在处理短时间任务时创建与销毁线程的代价(用空间换时间的一种策略)。线程池不仅能够保证内核的充分利用,还能防止过分调度。可用线程数量应该取决于可用的并发处理器、处理器内核、内存、网络sockets等的数量。 *

线程池的应用场景:

* 1. 需要大量的线程来完成任务,且完成任务的时间比较短。 WEB服务器完成网页请求这样的任务,使用线程池技术是非常合适的。因为单个任务小,而任务数量巨大,你可以想象一个热门网站的点击次数。 但对于长时间的任务,比如一个Telnet连接请求,线程池的优点就不明显了。因为Telnet会话时间比线程的创建时间大多了。

* 2. 对性能要求苛刻的应用,比如要求服务器迅速响应客户请求。

* 3. 接受突发性的大量请求,但不至于使服务器因此产生大量线程的应用。突发性大量客户请求,在没有线程池情况下,将产生大量线程,虽然理论上大部分操作系统线程数目最大值不是问题,短时间内产生大量线程可能使内存到达极限, 出现错误.

* 线程池示例(也是一个生产消费模型):

* 1. 创建固定数量线程池,循环从任务队列中获取任务对象,

* 2. 获取到任务对象后,执行任务对象中的任务接口

1.2 线程池的实现

线程池:

#pragma once

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

struct ThreadInfo
{
    pthread_t tid;
    std::string name;
};

static const int defalutnum = 5;

template 
class ThreadPool
{
public:
    void Lock()
    {
        pthread_mutex_lock(&mutex_);
    }
    void Unlock()
    {
        pthread_mutex_unlock(&mutex_);
    }
    void Wakeup()
    {
        pthread_cond_signal(&cond_);
    }
    void ThreadSleep()
    {
        pthread_cond_wait(&cond_, &mutex_);
    }
    bool IsQueueEmpty()
    {
        return tasks_.empty();
    }
    std::string GetThreadName(pthread_t tid)
    {
        for (const auto &ti : threads_)
        {
            if (ti.tid == tid)
                return ti.name;
        }
        return "None";
    }

public:
    static void *HandlerTask(void *args)
    {
        ThreadPool *tp = static_cast *>(args);
        std::string name = tp->GetThreadName(pthread_self());
        while (true)
        {
            tp->Lock();

            while (tp->IsQueueEmpty())
            {
                tp->ThreadSleep();
            }
            T t = tp->Pop();
            tp->Unlock();

            t();
            std::cout << name << " run, "
                      << "result: " << t.GetResult() << std::endl;
        }
    }
    void Start()
    {
        int num = threads_.size();
        for (int i = 0; i < num; i++)
        {
            threads_[i].name = "thread-" + std::to_string(i + 1);
            pthread_create(&(threads_[i].tid), nullptr, HandlerTask, this);
        }
    }
    T Pop()
    {
        T t = tasks_.front();
        tasks_.pop();
        return t;
    }
    void Push(const T &t)
    {
        Lock();
        tasks_.push(t);
        Wakeup();
        Unlock();
    }

private:
    ThreadPool(int num = defalutnum) : threads_(num)
    {
        pthread_mutex_init(&mutex_, nullptr);
        pthread_cond_init(&cond_, nullptr);
    }
    ~ThreadPool()
    {
        pthread_mutex_destroy(&mutex_);
        pthread_cond_destroy(&cond_);
    }
private:
    std::vector threads_;
    std::queue tasks_;

    pthread_mutex_t mutex_;
    pthread_cond_t cond_;
};


       如果我们将线程的方法写在类内,我们的phread方法没法传参数!!因为类成员函数默认会携带this指针!!   所以我们不想要这个this指针,就必须把这个成员函数变成静态的!

        但是还不够!!因为如果我们把他定义成静态成员函数,那么他是无法使用类内的非静态成员函数的!!因此我们如果要解决这个问题,我们就可以将this对象通过参数传递过去,这样的话我们就可以在静态函数内通过这个对象去调用类内的非静态成员方法了!

    既然我们这些函数都写在类内了,那么我们就可以将一些函数封装一下,从而增加代码的可读性! 

主函数:

#include 
#include 
#include "ThreadPool.hpp"
#include "Task.hpp"


pthread_spinlock_t slock;


int main()
{
    // pthread_spin_init(&slock, 0);
    // pthread_spin_destroy(&slock);

    // 如果获取单例对象的时候,也是多线程获取的呢?
    std::cout << "process runn..." << std::endl;
    sleep(3);
    ThreadPool *tp = new ThreadPool(5);
    srand(time(nullptr) ^ getpid());

    while(true)
    {
        //1. 构建任务
        int x = rand() % 10 + 1;
        usleep(10);
        int y = rand() % 5;
        char op = opers[rand()%opers.size()];

        Task t(x, y, op);
        tp->Push(t);
        //2. 交给线程池处理
        std::cout << "main thread make task: " << t.GetTask() << std::endl;

        sleep(1);
    }
}

 任务函数:

#pragma once
#include 
#include 

std::string opers="+-*/%";

enum{
    DivZero=1,
    ModZero,
    Unknown
};

class Task
{
public:
    Task()
    {}
    Task(int x, int y, char op) : data1_(x), data2_(y), oper_(op), result_(0), exitcode_(0)
    {
    }
    void run()
    {
        switch (oper_)
        {
        case '+':
            result_ = data1_ + data2_;
            break;
        case '-':
            result_ = data1_ - data2_;
            break;
        case '*':
            result_ = data1_ * data2_;
            break;
        case '/':
            {
                if(data2_ == 0) exitcode_ = DivZero;
                else result_ = data1_ / data2_;
            }
            break;
        case '%':
           {
                if(data2_ == 0) exitcode_ = ModZero;
                else result_ = data1_ % data2_;
            }            break;
        default:
            exitcode_ = Unknown;
            break;
        }
    }
    void operator ()()
    {
        run();
    }
    std::string GetResult()
    {
        std::string r = std::to_string(data1_);
        r += oper_;
        r += std::to_string(data2_);
        r += "=";
        r += std::to_string(result_);
        r += "[code: ";
        r += std::to_string(exitcode_);
        r += "]";

        return r;
    }
    std::string GetTask()
    {
        std::string r = std::to_string(data1_);
        r += oper_;
        r += std::to_string(data2_);
        r += "=?";
        return r;
    }
    ~Task()
    {
    }

private:
    int data1_;
    int data2_;
    char oper_;

    int result_;
    int exitcode_;
};

二、c++模式封装线程库

 C++其实是提供了线程库的,但是他的底层也是用的原生线程库做封装,所以也必须指定链接。

#pragma once

#include 
#include 
#include 
#include 

typedef void (*callback_t)();//函数指针
static int num = 1;

class Thread
{
public:
    static void *Routine(void *args)
    {
        Thread* thread = static_cast(args);
        thread->Entery();
        return nullptr;
    }
public:
    Thread(callback_t cb):tid_(0), name_(""), start_timestamp_(0), isrunning_(false),cb_(cb)
    {}
    void Run()
    {
        name_ = "thread-" + std::to_string(num++);
        start_timestamp_ = time(nullptr);
        isrunning_ = true;
        pthread_create(&tid_, nullptr, Routine, this);
    }
    void Join()
    {
        pthread_join(tid_, nullptr);
        isrunning_ = false;
    }
    std::string Name()
    {
        return name_;
    }
    uint64_t StartTimestamp()
    {
        return start_timestamp_;
    }
    bool IsRunning()
    {
        return isrunning_;
    }
    void Entery()
    {
        cb_();
    }
    ~Thread()
    {}
private:
    pthread_t tid_;
    std::string name_;
    uint64_t start_timestamp_;//启动的时间戳
    bool isrunning_;//是否启动了

    callback_t cb_;//线程方法!
};

问题:如果我们的线程方法想带参数怎么办??

——>改一下构造函数,多增加一个类对象,将参数传递给这个类对象,然后再在方法里面将这个类对象传递给线程函数

主函数:

#include 
#include 
#include 
#include "Thread.hpp"

using namespace std;

void Print()
{
    while(true)
    {
        printf("haha, 我是一个封装的线程...
");
        sleep(1);
    }
}

int main()
{
    std::vector threads;

    for(int i = 0 ;i < 10; i++)
    {
        threads.push_back(Thread(Print));
    }

    for(auto &t : threads)
    {
        t.Run();
    }

    
    for(auto &t : threads)
    {
        t.Join();
    }
    // Thread t(Print);
    // t.Run();

    // cout << "是否启动成功: " << t.IsRunning() << endl;
    // cout << "启动成功时间戳: " << t.StartTimestamp() << endl;
    // cout << "线程的名字: " << t.Name() << endl;

    // t.Join();

    return 0;
}

三、线程安全的单例模式

3.1 单例模式和设计模式 

 单例模式是一种 "经典的, 常用的, 常考的" 设计模式.

        IT行业这么火, 涌入的人很多. 俗话说林子大了啥鸟都有. 大佬和菜鸡们两极分化的越来越严重. 为了让菜鸡们不太拖大佬的后腿, 于是大佬们针对一些经典的常见的场景, 给定了一些对应的解决方案, 这个就是设计模式

单例模式的特点 :

某些类, 只应该具有一个对象(实例), 就称之为单例.

例如一个男人只能有一个媳妇.

在很多服务器开发场景中, 经常需要让服务器加载很多的数据 (上百G) 到内存中. 此时往往要用一个单例的类来管理这些数据.

3.2 饿汉模式和懒汉模式 

吃完饭, 立刻洗碗, 这种就是饿汉方式. 因为下一顿吃的时候可以立刻拿着碗就能吃饭.

吃完饭, 先把碗放下, 然后下一顿饭用到这个碗了再洗碗, 就是懒汉方式.

懒汉方式最核心的思想是 "延时加载". 从而能够优化服务器的启动速度 

例子1:我们申请内存的时候,首先是在地址空间上申请,而当我们真正要使用的时候,才会发生缺页中断从而建立虚拟地址和物理地址的映射关系!! 

例子2:我们打开文件的时候,文件的属性必然会先被加载起来,但是文件的内容则是我们需要使用的时候才会加载进来!! 

饿汉方式实现单例模式 

template  
class Singleton { 
 static T data; 
public: 
 static T* GetInstance() { 
 return &data; 
 } 
}; 

 只要通过 Singleton 这个包装类来使用 T 对象, 则一个进程中只有一个 T 对象的实例.

懒汉方式实现单例模式 

template  
class Singleton { 
 static T* inst; 
public: 
 static T* GetInstance() { 
 if (inst == NULL) { 
 inst = new T(); 
 } 
 return inst; 
 } 
};

存在一个严重的问题, 线程不安全.

第一次调用 GetInstance 的时候, 如果两个线程同时调用, 可能会创建出两份 T 对象的实例.

——>所以我们必须加锁!!  可是我们我们会发现其实也就第一次调用的时候可能会出现这种情况,但是后续再次调用, 基本上都是直接返回,所以加锁就没有什么意义了,还大大降低效率!!——>解决方法,外面再加一层判断!!

// 懒汉模式, 线程安全 
template  
class Singleton { 
 volatile static T* inst; // 需要设置 volatile 关键字, 否则可能被编译器优化. 
 static std::mutex lock; 
public: 
 static T* GetInstance() { 
 if (inst == NULL) { // 双重判定空指针, 降低锁冲突的概率, 提高性能. 
 lock.lock(); // 使用互斥锁, 保证多线程情况下也只调用一次 new. 
 if (inst == NULL) { 
 inst = new T(); 
 } 
 lock.unlock(); 
 } 
 return inst; 
 } 
}; 

注意事项:

1. 加锁解锁的位置

2. 双重 if 判定, 避免不必要的锁竞争

3. volatile关键字防止过度优化

3.3 懒汉模式的线程池修改 

#pragma once

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

struct ThreadInfo
{
    pthread_t tid;
    std::string name;
};

static const int defalutnum = 5;

template 
class ThreadPool
{
public:
    void Lock()
    {
        pthread_mutex_lock(&mutex_);
    }
    void Unlock()
    {
        pthread_mutex_unlock(&mutex_);
    }
    void Wakeup()
    {
        pthread_cond_signal(&cond_);
    }
    void ThreadSleep()
    {
        pthread_cond_wait(&cond_, &mutex_);
    }
    bool IsQueueEmpty()
    {
        return tasks_.empty();
    }
    std::string GetThreadName(pthread_t tid)
    {
        for (const auto &ti : threads_)
        {
            if (ti.tid == tid)
                return ti.name;
        }
        return "None";
    }

public:
    static void *HandlerTask(void *args)
    {
        ThreadPool *tp = static_cast *>(args);
        std::string name = tp->GetThreadName(pthread_self());
        while (true)
        {
            tp->Lock();

            while (tp->IsQueueEmpty())
            {
                tp->ThreadSleep();
            }
            T t = tp->Pop();
            tp->Unlock();

            t();
            std::cout << name << " run, "
                      << "result: " << t.GetResult() << std::endl;
        }
    }
    void Start()
    {
        int num = threads_.size();
        for (int i = 0; i < num; i++)
        {
            threads_[i].name = "thread-" + std::to_string(i + 1);
            pthread_create(&(threads_[i].tid), nullptr, HandlerTask, this);
        }
    }
    T Pop()
    {
        T t = tasks_.front();
        tasks_.pop();
        return t;
    }
    void Push(const T &t)
    {
        Lock();
        tasks_.push(t);
        Wakeup();
        Unlock();
    }
    static ThreadPool *GetInstance()
    {
        if (nullptr == tp_) // ???
        {
            pthread_mutex_lock(&lock_);
            if (nullptr == tp_)
            {
                std::cout << "log: singleton create done first!" << std::endl;
                tp_ = new ThreadPool();
            }
            pthread_mutex_unlock(&lock_);
        }

        return tp_;
    }

private:
    ThreadPool(int num = defalutnum) : threads_(num)
    {
        pthread_mutex_init(&mutex_, nullptr);
        pthread_cond_init(&cond_, nullptr);
    }
    ~ThreadPool()
    {
        pthread_mutex_destroy(&mutex_);
        pthread_cond_destroy(&cond_);
    }
    ThreadPool(const ThreadPool &) = delete;
    const ThreadPool &operator=(const ThreadPool &) = delete; // a=b=c
private:
    std::vector threads_;
    std::queue tasks_;

    pthread_mutex_t mutex_;
    pthread_cond_t cond_;

    static ThreadPool *tp_;
    static pthread_mutex_t lock_;
};

template 
ThreadPool *ThreadPool::tp_ = nullptr;

template 
pthread_mutex_t ThreadPool::lock_ = PTHREAD_MUTEX_INITIALIZER;

四、STL、智能指针和线程安全

STL中的容器是否是线程安全的?

——> 不是.

原因是, STL 的设计初衷是将性能挖掘到极致, 而一旦涉及到加锁保证线程安全, 会对性能造成巨大的影响.

而且对于不同的容器, 加锁方式的不同, 性能可能也不同(例如hash表的锁表和锁桶).

因此 STL默认不是线程安全. 如果需要在多线程环境下使用, 往往需要调用者自行保证线程安全.

智能指针是否是线程安全的?

对于 unique_ptr, 由于只是在当前代码块范围内生效, 因此不涉及线程安全问题.

对于 shared_ptr, 多个对象需要共用一个引用计数变量, 所以会存在线程安全问题. 但是标准库实现的时候考虑到了这个问题, 基于原子操作(CAS)的方式保证 shared_ptr 能够高效, 原子的操作引用计数.

五、其他各种锁

悲观锁:在每次取数据时,总是担心数据会被其他线程修改,所以会在取数据前先加锁(读锁,写锁,行 锁等),当其他线程想要访问数据时,被阻塞挂起。(我们使用的一般都是这个)

乐观锁:每次取数据时候,总是乐观的认为数据不会被其他线程修改,因此不上锁。但是在更新数据前, 会判断其他数据在更新前有没有对数据进行修改。主要采用两种方式:版本号机制和CAS操作。

CAS操作:当需要更新数据时,判断当前内存值和之前取得的值是否相等。如果相等则用新值更新。若不等则失败,失败则重试,一般是一个自旋的过程,即不断重试。

自旋锁,公平锁,非公平锁?

自旋锁的介绍:

       讲个故事,张三发现明天要考试了,非常慌,于是打电话找到了李四,让李四帮他复习一下,李四说我目前还在看书,还得等我一个小时,于是这个时候张三就先去学校旁边的网吧打了一个小时的游戏,等打完回来正好李四下来了 于是一起去复习了 最后考了60分。

     第二次又考试了,这次张三还是一样打电话给李四,这个时候李四说他上个厕所就下来了,这个时候你想的是他一会就下来了!那我还是在这等等吧,就不去网吧了。

 所以这个时候张三决策的依据就是李四究竟要让他等多久

——> 当前其他申请不到锁的进程是应该阻塞还是应该重复申请,取决于其执行临界区代码的时长

 所以我们以前学的锁叫做挂起等待锁,而需要不断申请直到获得的锁叫做自旋锁!

实现方式:trylock加锁就是如果当前没有加锁成功,就直接返回! 所以我们只要在外围封装一个while循环,那么该线程就会一直申请锁直到申请成功!!

 但其实pthread库给我们实现了一个自旋锁!!

第一个就是相当于帮我们封装了这个while循环,他会一直申请直到申请到锁。

第二个就跟前面学的差不多,只要申请失败了就会返回!! 

六、读者写者问题、

6.1 引入

    读者写者问题本身也是生产消费者模型 遵循321原则,但是其中最大的一个差别就是  读和读是共享关系!!因为读的过程并不会影响到数据!!(比如我们学校的黑板报或者博客)

 线程库为我们提供了读写锁

      一般来说都是读的多写的少,所以读的竞争能力比写的竞争能力大很多,所以可能会导致写较大概率的饥饿问题!!(中性现象) 

有两种策略:读者优先和写者优先            优先就是当两者一块来的时候,让其中一方先进去

线程库的读写锁默认是读者优先!! 

6.2 读写锁接口

设置读写优先

int pthread_rwlockattr_setkind_np(pthread_rwlockattr_t *attr, int pref);

/* pref 共有 3 种选择

PTHREAD_RWLOCK_PREFER_READER_NP (默认设置) 读者优先,可能会导致写者饥饿情况

PTHREAD_RWLOCK_PREFER_WRITER_NP 写者优先,目前有 BUG,导致表现行为和 PTHREAD_RWLOCK_PREFER_READER_NP 一致 PTHREAD_RWLOCK_PREFER_WRITER_NONRECURSIVE_NP 写者优先,但写者不能递归加锁 */

 初始化

int pthread_rwlock_init(pthread_rwlock_t *restrict rwlock,const pthread_rwlockattr_t *restrict attr);

销毁

int pthread_rwlock_destroy(pthread_rwlock_t *rwlock);  

加锁和解锁

int pthread_rwlock_rdlock(pthread_rwlock_t *rwlock);

int pthread_rwlock_wrlock(pthread_rwlock_t *rwlock);

int pthread_rwlock_unlock(pthread_rwlock_t *rwlock);  

 6.3 样例代码

#include  
#include  
#include  
#include  
#include  
#include  
#include  
 
 
volatile int ticket = 1000; 
pthread_rwlock_t rwlock; 
 
 
void * reader(void * arg) 
{ 
 char *id = (char *)arg; 
 while (1) { 
 pthread_rwlock_rdlock(&rwlock); 
 if (ticket <= 0) { 
 pthread_rwlock_unlock(&rwlock); 
 break; 
 } 
 printf("%s: %d
", id, ticket); 
 pthread_rwlock_unlock(&rwlock); 
 usleep(1); 
 } 
 
 return nullptr; 
} 
 
 
void * writer(void * arg) 
{ 
 char *id = (char *)arg; 
 while (1) { 
 pthread_rwlock_wrlock(&rwlock); 
 if (ticket <= 0) { 
 pthread_rwlock_unlock(&rwlock); 
 break; 
 } 
 printf("%s: %d
", id, --ticket); 
 pthread_rwlock_unlock(&rwlock); 
 usleep(1); 
 } 
 
 return nullptr; 
} 
 
 
struct ThreadAttr 
{ 
 pthread_t tid; 
 std::string id; 
}; 
 
 
std::string create_reader_id(std::size_t i) 
{ 
 // 利用 ostringstream 进行 string 拼接 
 std::ostringstream oss("thread reader ", std::ios_base::ate); 
 oss << i; 
 return oss.str(); 
} 
 
 
std::string create_writer_id(std::size_t i) 
{ 
 // 利用 ostringstream 进行 string 拼接 
 std::ostringstream oss("thread writer ", std::ios_base::ate); 
 oss << i; 
 return oss.str(); 
} 
 
 
void init_readers(std::vector& vec) 
{ 
 for (std::size_t i = 0; i < vec.size(); ++i) { 
 vec[i].id = create_reader_id(i); 
 
 pthread_create(&vec[i].tid, nullptr, reader, (void *)vec[i].id.c_str()); 
 } 
} 
 
 
void init_writers(std::vector& vec) 
{ 
 for (std::size_t i = 0; i < vec.size(); ++i) { 
 vec[i].id = create_writer_id(i); 
 
 pthread_create(&vec[i].tid, nullptr, writer, (void *)vec[i].id.c_str()); 
 } 
} 
 
 
void join_threads(std::vector const& vec) 
{ 
 // 我们按创建的 逆序 来进行线程的回收 
 for (std::vector::const_reverse_iterator it = vec.rbegin(); it != 
vec.rend(); ++it) { 
 pthread_t const& tid = it->tid; 
 pthread_join(tid, nullptr); 
 } 
} 
 
 
void init_rwlock() 
{ 
#if 0 // 写优先 
 pthread_rwlockattr_t attr; 
 pthread_rwlockattr_init(&attr); 
 pthread_rwlockattr_setkind_np(&attr, PTHREAD_RWLOCK_PREFER_WRITER_NONRECURSIVE_NP); 
 pthread_rwlock_init(&rwlock, &attr); 
 pthread_rwlockattr_destroy(&attr); 
#else // 读优先,会造成写饥饿 
 pthread_rwlock_init(&rwlock, nullptr); 
#endif 
} 
 
 
int main() 
{ 
 // 测试效果不明显的情况下,可以加大 reader_nr 
 // 但也不能太大,超过一定阈值后系统就调度不了主线程了 
 const std::size_t reader_nr = 1000; 
 const std::size_t writer_nr = 2; 
 
 std::vector readers(reader_nr); 
 std::vector writers(writer_nr); 
 
 init_rwlock(); 
 
 init_readers(readers); 
 init_writers(writers); 
 
 join_threads(writers); 
 join_threads(readers); 
 
 pthread_rwlock_destroy(&rwlock); 
} 

 makefile

main: main.cpp g++ -std=c++11 -Wall -Werror $^ -o $@ -lpthread

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

搜索文章

Tags

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