最新资讯

  • 【Linux】线程ID与互斥、同步(锁、条件变量)

【Linux】线程ID与互斥、同步(锁、条件变量)

2025-05-09 04:01:07 0 阅读

  🌈个人主页:秦jh__https://blog.csdn.net/qinjh_?spm=1010.2135.3001.5343
🔥 系列专栏:https://blog.csdn.net/qinjh_/category_12625432.html

目录

线程ID及进程地址空间布局

 线程简单封装

 线程互斥

进程线程间的互斥相关背景概念

 锁简单封装

 互斥量实现原理

 Linux线程同步

 同步概念与竞态条件

 条件变量

认识接口 

 生产者消费者模型

 基于BlockingQueue的生产者消费者模型

BlockQueue.hpp

main.cc

Task.hpp


前言

    💬 hello! 各位铁子们大家好哇。

             今日更新了Linux线程的内容
    🎉 欢迎大家关注🔍点赞👍收藏⭐️留言📝

线程ID及进程地址空间布局

 运行代码,这个很大的数字就是线程id。

通过 ps -aL 指令,看到LWP跟线程id是不一样的。

给用户提供的线程的id,不是内核中的lwp,而是pthread库维护的一个唯一值。

我们把上面的数字转换成十六进制,可以看出这是一个地址

 理解库

动态库被运行时加载,动态库没被加载前在磁盘中。

pthread库本质是一个文件。

我们刚刚写的可执行程序,它也是个文件,所以他也在磁盘中。可执行程序内部用线程库来创建多线程。

程序运行时,会变成一个进程,加载到内存中,内存中就有该进程的代码和数据。创建线程时,要先把库加载到内存中,然后再映射到该进程的地址空间才能用。映射要映射到堆栈之间的共享区。如果有多个多线程进程,它只需要把共享区的代码,经过页表映射到已经加载到内存的库,此时多个进程就可以使用同一个库里的方法来创建线程。

Linux只维护轻量级进程,linux中的pcb里与执行流相关的属性都是轻量级进程的属性,所有的属性都是围绕lwp展开的。我们在用户层的概念是线程,要的是线程的id,与线程相关的内容在Linux中是没有的,它没有维护。所以这部分属性由库来进行维护。  

为了更好的管理线程,创建线程时,库会为我们的每一个线程申请一个内存块(描述线程的相关结构体字段属性)。

未来要找一个线程的所有属性,只要找到线程控制块的地址即可。所以pthread_t id就是一个地址。

pthread_t类型的线程ID,本质就是线程属性集合的起始虚拟地址 ---- 在pthread库中维护。

 由上图可得,一个全局变量,本身就是被所有线程共享的。

 如果我们想让两个线程各自私有一份变量,g++有一个编译选项 __thread  

用__thread修饰这个全局变量即可。运行后,主线程和新线程gval的地址也不一样了。这种情况叫线程的局部存储,原始代码里只看到一个gval,但是他们用的是各自的gval。

这种情况只在Linux中有效。__thread只能用来修饰内置类型。

 线程简单封装

#pragma once
#include 
#include 
#include 

namespace ThreadMoudle
{
    // 线程要执行的方法,后面我们随时调整
    typedef void (*func_t)(const std::string &name); // 函数指针类型

    class Thread
    {
    public:
        void Excute()
        {
            std::cout << _name << " is running" << std::endl;
            _isrunning = true;
            _func(_name);
            _isrunning = false;
        }
    public:
        Thread(const std::string &name, func_t func):_name(name), _func(func)
        {
            std::cout << "create " << name << " done" << std::endl;
        }
        static void *ThreadRoutine(void *args) // 变成static,内部没有this指针,pthread_create就能匹配上了
        {
            Thread *self = static_cast(args); // 获得了当前对象
            self->Excute();
            return nullptr;
        }
        bool Start()
        {
            int n = ::pthread_create(&_tid, nullptr, ThreadRoutine, this);//传this,线程函数才能拿到_func方法
            if(n != 0) return false;
            return true;
        }
        std::string Status()
        {
            if(_isrunning) return "running";
            else return "sleep";
        }
        void Stop()
        {
            if(_isrunning)
            {
                ::pthread_cancel(_tid);
                _isrunning = false;
                std::cout << _name << " Stop" << std::endl;
            }
        }
        void Join()
        {
            ::pthread_join(_tid, nullptr);
            std::cout << _name << " Joined" << std::endl;
        }
        std::string Name()
        {
            return _name;
        }
        ~Thread()
        {
        }

    private:
        std::string _name;
        pthread_t _tid;
        bool _isrunning;
        func_t _func; // 线程要执行的回调函数
    };
} // namespace ThreadModle

 线程互斥

进程线程间的互斥相关背景概念

  • 临界资源:多线程执行流共享的资源就叫做临界资源
  • 临界区:每个线程内部,访问临界资源的代码,就叫做临界区
  • 互斥:任何时刻,互斥保证有且只有一个执行流进入临界区,访问临界资源,通常对临界资源起保护作用
  • 原子性:不会被任何调度机制打断的操作,该操作只有两态,要么完成,要么未完成 

 下面通过抢票代码演示:

void route(const std::string &name)
{
    while(true)
    {
        if(tickets > 0)
        {
            // 抢票过程
            usleep(1000); // 1ms -> 抢票花费的时间
            printf("who: %s, get a ticket: %d
", name.c_str(), tickets);
            tickets--;
        }
        else
        {
            break;
        }
    }
}

int main()
{
    Thread t1("thread-1", route);
    Thread t2("thread-2", route);
    Thread t3("thread-3", route);
    Thread t4("thread-4", route);

    t1.Start();
    t2.Start();
    t3.Start();
    t4.Start();

    t1.Join();
    t2.Join();
    t3.Join();
    t4.Join();
}

线程就用我们前面封装的线程。每抢到一张票就--,直到没票为止。

由上面结果可知,抢票抢到负数去了。因此多线程并发访问公共资源时可能会引发异常。 

  • 大部分情况,线程使用的数据都是局部变量,变量的地址空间在线程栈空间内,这种情况,变量归属单个线程,其他线程无法获得这种变量。
  • 但有时候,很多变量都需要在线程间共享,这样的变量称为共享变量,可以通过数据的共享,完成线程之间的交互。
  • 多个线程并发的操作共享变量,会带来一些问题。

 为什么会出现抢到负数的问题呢?

判断的过程是计算,由cpu来做。判断的过程:数据要先从内存移动到对应的寄存器中,然后再进行逻辑判断,然后才能得到结果,最后cpu再决定要执行if还是else。

之前讲过,cpu内寄存器只有一套,但是寄存器里的数据可以有多套。

这里有四个线程进行抢票,  如果一个线程在判断到一半时被切换了,他需要把寄存器里的数值带走,等到被唤醒的时候,他又要把数值恢复。

比如:假设票只剩一张了,线程a已经在判断完了,当他准备抢票的时候,他被切换了。此时他就把上下文数据保存。线程b被唤醒了,他也来进行票数判断,因为刚刚线程a还没来得及抢票,票数没--,所以线程b也判断成功,他也要抢票。线程a此时被唤醒,就往后执行代码进行抢票,然后--,票数就变成0。线程b又被唤醒,票数又--,就变成负数了。

如何解决上面的问题呢?加锁!

 pthread_mutex_t是互斥锁类型。

互斥锁在任何时刻,只允许一个线程进行资源访问。

有了锁,我们往往需要初始化和销毁锁,初始化有两种做法:

  1. 如果定义的是全局或者静态的锁,可以只使用pthread_mutex_t 锁的名字 =PTHREAD_MUTEX_INITIALIZER  
  2. 如果定义的这把锁是动态申请的,比如new或栈上开辟的,必须使用pthread_mutex_init函数来进行初始化。参数1就是你自己定义的锁,参数2是属性,直接设为nullptr即可。

用完锁后,还需要销毁,用pthread_mutex_destroy函数,参数是锁的地址。如果锁是静态或者全局的,我们不需要destroy,全局的或者静态的变量会随着进程的运行而一直存在,进程结束他也就自动释放了。初始化和销毁的返回值,成功返回0,失败返回-1。

一旦有了锁,我们就需要对临界区进行保护, 就需要加锁和解锁。要对某个区域加锁,就要调用pthread_mutex_lock函数来加锁,参数就是你定义的锁。要解锁,就用pthread_mutex_unlock函数。

lock的情况:

  • 互斥量处于未锁状态,该函数会将互斥量锁定,同时返回成功
  • 发起函数调用时,其他线程已经锁定互斥量,或者存在其他线程同时申请互斥量,但没有竞争到互斥量, 那么pthread_ lock调用会陷入阻塞(执行流被挂起),等待互斥量解锁。

所谓对临界区资源进行保护,本质是对临界区代码进行保护。 

把前面抢票的代码改一下,加锁。运行结果发现不会再抢到负数了,而且运行时间明显比之前要长。 

  1.  加锁的范围,粒度要尽量小,即临界区尽量小。
  2. 所有线程申请锁,前提是所有线程都看得到这把锁,因此锁本身也是共享资源。所以加锁的过程必须是原子的
  3. 原子性:要么不做,要么完成了。没有中间状态,就是原子性。
  4. 如果线程申请锁失败了,线程就要被阻塞
  5. 如果线程申请锁成功了,就继续往后运行,执行临界区代码。

 在执行临界区代码期间,线程可以被切换。假设线程1正在执行临界区代码,此时线程被切换了,其他线程也无法进入临界区,因为线程1并没有释放锁。

结论:我这个线程访问临界区,对其他线程来说是原子的。因为对于其他线程,我要么没有申请锁,要么释放了锁,这样对他们才有意义。

下面用局部的锁,使用前,先对线程重新封装

上面是增加的内容,下面是完整的代码

#pragma once
#include 
#include 
#include 

namespace ThreadMoudle
{
    class ThreadData
    {
    public:
        ThreadData(const std::string &name,pthread_mutex_t *lock):_name(name),_lock(lock)
        {}
    public:
        std::string _name;
        pthread_mutex_t* _lock;
    };


    // 线程要执行的方法,后面我们随时调整
    typedef void (*func_t)(ThreadData* td); // 函数指针类型
 
    class Thread
    {
    public:
        void Excute()
        {
            std::cout << _name << " is running" << std::endl;
            _isrunning = true;
            _func(_td);
            _isrunning = false;
        }
    public:
        Thread(const std::string &name, func_t func,ThreadData* td):_name(name), _func(func),_td(td)
        {
            std::cout << "create " << name << " done" << std::endl;
        }
        static void *ThreadRoutine(void *args) // 变成static,内部没有this指针,pthread_create就能匹配上了
        {
            Thread *self = static_cast(args); // 获得了当前对象
            self->Excute();
            return nullptr;
        }
        bool Start()
        {
            int n = ::pthread_create(&_tid, nullptr, ThreadRoutine, this);//传this,线程函数才能拿到_func方法
            if(n != 0) return false;
            return true;
        }
        std::string Status()
        {
            if(_isrunning) return "running";
            else return "sleep";
        }
        void Stop()
        {
            if(_isrunning)
            {
                ::pthread_cancel(_tid);
                _isrunning = false;
                std::cout << _name << " Stop" << std::endl;
            }
        }
        void Join()
        {
            ::pthread_join(_tid, nullptr);
            std::cout << _name << " Joined" << std::endl;
            delete _td;
        }
        std::string Name()
        {
            return _name;
        }
        ~Thread()
        {
        }

    private:
        std::string _name;
        pthread_t _tid;
        bool _isrunning;
        func_t _func; // 线程要执行的回调函数
        ThreadData* _td;
    };
} // namespace ThreadModle

运行代码,结果如下图,4个线程的锁都是同一个地址,说明他们访问的都是同一把锁。

最后再把线程函数代码换成抢票的代码即可,结果跟用全局的一样。

因此锁的使用既可以用全局的,也可以以参数的形式传递给线程。

 锁简单封装

因为是临时对象,在循环结束后会自动调用析构函数销毁。

 互斥量实现原理

  • 经过上面的例子,大家已经意识到单纯的 i++ 或者 ++i 都不是原子的,有可能会有数据一致性问题
  • 为了实现互斥锁操作,大多数体系结构都提供了swap或exchange指令,该指令的作用是把寄存器和内存单元的数据相交换,由于只有一条指令,保证了原子性,即使是多处理器平台,访问内存的 总线周期也有先后,一个处理器上的交换指令执行时另一个处理器的交换指令只能等待总线周期。 

 Linux线程同步

 同步概念与竞态条件

  • 同步:在保证数据安全的前提下,让线程能够按照某种特定的顺序访问临界资源,从而有效避免饥饿问题,叫做同步
  • 竞态条件:因为时序问题,而导致程序异常,我们称之为竞态条件。 

如上图,线程2一直抢到票,其他线程一直抢不到,这时候就需要线程同步 

 条件变量

  • 当一个线程互斥地访问某个变量时,它可能发现在其它线程改变状态之前,它什么也做不了。
  • 例如一个线程访问队列时,发现队列为空,它只能等待,直到其它线程将一个节点添加到队列中。这种情况就需要用到条件变量。 

 举例:有A,B,C三个人,一个盘子。B拿出苹果放到盘子上,另外两人就可以到盘子上拿。为了在放苹果的时候,其他人不能来拿,就要加锁,盘子就是临界区。因为另外两人想拿苹果,就一直申请锁,导致B放不了苹果。此时就需要一个铃铛。A,C两人在外面排队,当B放好苹果后就摇铃铛,此时A和C就会根据排队的顺序依次进去拿苹果。

上面的铃铛就是条件变量,人就是线程。摇铃铛后,可以规定是唤醒一个线程还是唤醒全部。

认识接口 

条件变量是 pthread_cond_t 的数据类型。它的使用跟前面互斥锁一样,可以定义成局部或者全局的。如果是全局或者静态的,可以直接使用 PTHREAD_COND_INITIALIZER 初始化。

如果是局部的,就用pthread_cond_init 函数初始化,使用完了就destroy销毁掉。

线程条件不满足时,线程就要等待,要在指定的条件变量上等待。

cond:要在这个条件变量上等待

等待完成后,就要进行唤醒。

pthread_cond_signal 表示唤醒一个线程。 pthread_cond_broadcast 表示唤醒所有线程。

条件变量接口使用例子:

#include 
#include 
#include 
#include 

const int num = 5;
pthread_mutex_t gmutex = PTHREAD_MUTEX_INITIALIZER;
pthread_cond_t gcond = PTHREAD_COND_INITIALIZER;

void *Wait(void *args)
{
    std::string name = static_cast(args);
    while (true)
    {
        pthread_mutex_lock(&gmutex);

        pthread_cond_wait(&gcond, &gmutex); // 这里就是线程等待的位置
        usleep(10000);
        std::cout << "I am : " << name << std::endl;

        pthread_mutex_unlock(&gmutex);

        // usleep(100000);
    }
}

int main()
{
    pthread_t threads[num];
    for (int i = 0; i < num; i++)
    {
        char *name = new char[1024];
        snprintf(name, 1024, "thread-%d", i + 1);
        pthread_create(threads + i, nullptr, Wait, (void *)name);
        usleep(10000);
    }

    sleep(1);
    // 唤醒其他线程
    while (true)
    {
        // pthread_cond_signal(&gcond);
        pthread_cond_broadcast(&gcond);
        std::cout << "唤醒一个线程...." << std::endl;
        sleep(2);
    }

    for (int i = 0; i < num; i++)
    {
        pthread_join(threads[i], nullptr);
    }

    return 0;
}

运行结果:

 生产者消费者模型

生产者消费者模式就是通过一个容器来解决生产者和消费者的强耦合问题。生产者和消费者彼此之间不直接通讯,而通过阻塞队列来进行通讯,所以生产者生产完数据之后不用等待消费者处理,直接扔给阻塞队列,消费者不找生产者要数据,而是直接从阻塞队列里取,阻塞队列就相当于一个缓冲区,平衡了生产者和消费者的处理能力。这个阻塞队列就是用来给生产者和消费者解耦的。

生产者消费者模型优点:

  • 解耦
  • 支持并发
  • 支持忙闲不均

 为了方便记忆,这里有一个“321”原则:

  1. 一个交易场所(一段内存空间)
  2. 两种角色(生产、消费角色)

  3. 三种关系(生产和生产、消费和消费 、生产和消费)前两种是互斥关系,最后一种是互斥和同步的关系

 基于BlockingQueue的生产者消费者模型

在多线程编程中阻塞队列(Blocking Queue)是一种常用于实现生产者和消费者模型的数据结构。其与普通的队列区别在于,当队列为空时,从队列获取元素的操作将会被阻塞,直到队列中被放入了元素;当队列满时,往队列里存放元素的操作也会被阻塞,直到有元素被从队列中取出

BlockQueue.hpp

#pragma once

#include 
#include 
#include 
#include 

const static int defaultcap = 5;

template 
class BlockQueue
{
private:
    bool IsFull()
    {
        return _block_queue.size() == _max_cap;
    }
    bool IsEmpty()
    {
        return _block_queue.empty();
    }

public:
    BlockQueue(int cap = defaultcap) : _max_cap(cap)
    {
        pthread_mutex_init(&_mutex, nullptr);
        pthread_cond_init(&_p_cond, nullptr);
        pthread_cond_init(&_c_cond, nullptr);
    }
    // 假设:2个消费者
    void Pop(T *out)
    {
        pthread_mutex_lock(&_mutex);
        while (IsEmpty()) // while可以保证代码的鲁棒性(健壮性),不用if,因为如果只有一个生产品
        {                 //,有两个消费者,一次性唤醒两个消费者的话,他们会竞争锁,其中一个拿完东西后,另一个才能重新拿到锁
                          //另一个拿到锁后,不用if的话,就跳过判断了,此时队列是空的,就会异常,所以用while
            // 添加尚未满足,但是线程被异常唤醒的情况,叫做伪唤醒!
            pthread_cond_wait(&_c_cond, &_mutex); // 两个消费者都在这里等待了
        }
        // 1. 没有空 || 2. 被唤醒了
        *out = _block_queue.front();
        _block_queue.pop();
        // if(_block_queue.size() > hight_water)
        //     pthread_cond_signal(&_p_cond);
        pthread_mutex_unlock(&_mutex);
        pthread_cond_signal(&_p_cond);
  
    }
    // 一个生产者
    void Equeue(const T &in)
    {
        pthread_mutex_lock(&_mutex);
        while (IsFull()) 
        {
            // 满了,生产者不能生产,必须等待
            // 可是在临界区里面啊!
            // 被调用的时候:除了让自己继续排队等待,还会自己释放传入的锁
            // 函数返回的时候,不就还在临界区了!
            // 返回时:必须先参与锁的竞争,重新加上锁,该函数才会返回!
            pthread_cond_wait(&_p_cond, &_mutex);
        }
        // 1. 没有满 || 2. 被唤醒了
        _block_queue.push(in); // 生产到阻塞队列
        pthread_mutex_unlock(&_mutex);
        // 让消费者消费
        pthread_cond_signal(&_c_cond);//解锁和唤醒的顺序可以交换,不影响
    }
    ~BlockQueue()
    {
        pthread_mutex_destroy(&_mutex);
        pthread_cond_destroy(&_p_cond);
        pthread_cond_destroy(&_c_cond);
    }

private:
    std::queue _block_queue; // 临界资源
    int _max_cap;
    pthread_mutex_t _mutex;
    pthread_cond_t _p_cond; // 生产者条件变量
    pthread_cond_t _c_cond; // 消费者条件变量

    // int low_water = _max_cap/3
    // int hight_water _max_cap/3*2
};

main.cc

#include "BlockQueue.hpp"
#include "Task.hpp"
#include 
#include 
#include 

void *Consumer(void *args)
{
    BlockQueue *bq = static_cast *>(args);
    while(true)
    {
        // 1. 获取数据
        task_t t;
        bq->Pop(&t);
        // 2. 处理数据
        // t.Excute();
        t();
        // std::cout << "Consumer -> " << t.result()  << std::endl;
    }
}

void *Productor(void *args)
{
    srand(time(nullptr) ^ getpid());
    BlockQueue *bq = static_cast *>(args);
    while(true)
    {
        // 1. 构建数据/任务
        // int x = rand() % 10 + 1; // [1, 10]
        // usleep(x * 1000);
        // int y = rand() % 10 + 1; // [1, 10]
        // Task t(x, y);
        // 2. 生产数据
        bq->Equeue(Download);
        std::cout << "Productor -> Download" << std::endl;

        sleep(1);
    }
}

int main()
{
    BlockQueue *bq = new BlockQueue();
    pthread_t c1,c2, p1,p2,p3;
    pthread_create(&c1, nullptr, Consumer, bq);
    pthread_create(&c2, nullptr, Consumer, bq);
    pthread_create(&p1, nullptr, Productor, bq);
    pthread_create(&p2, nullptr, Productor, bq);
    pthread_create(&p3, nullptr, Productor, bq);

    pthread_join(c1, nullptr);
    pthread_join(c2, nullptr);
    pthread_join(p1, nullptr);
    pthread_join(p2, nullptr);
    pthread_join(p3, nullptr);

    return 0;
}

Task.hpp

#pragma once

#include
#include

// typedef std::function task_t;
using task_t = std::function;

void Download()
{
    std::cout << "我是一个下载的任务" << std::endl;
}


// // 要做加法
// class Task
// {
// public:
//     Task()
//     {
//     }
//     Task(int x, int y) : _x(x), _y(y)
//     {
//     }
//     void Excute()
//     {
//         _result = _x + _y;
//     }
//     void operator ()()
//     {
//         Excute();
//     }
//     std::string debug()
//     {
//         std::string msg = std::to_string(_x) + "+" + std::to_string(_y) + "=?";
//         return msg;
//     }
//     std::string result()
//     {
//         std::string msg = std::to_string(_x) + "+" + std::to_string(_y) + "=" + std::to_string(_result);
//         return msg;
//     }

// private:
//     int _x;
//     int _y;
//     int _result;
// };

多线程生产者消费者模型高效是因为:一个生产者在生产任务的时候,其他生产者在构建任务,一个消费者在获取任务的时候,其他消费者在处理任务。

为什么线程在等待的时候,都是在加锁和解锁之间等待?

答:无论是生产者还是消费者,都必须先检查资源的状态。检查就是要访问,所以检查之前就要加锁,等待必须在临界区里进行等待,因为判断结果是在临界区里的。  

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

搜索文章

Tags

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