最新资讯

  • 【Linux】守护进程:containerd的使用教程

【Linux】守护进程:containerd的使用教程

2025-05-13 21:01:07 3 阅读

这里写目录标题

    • 前言
    • 一. ctr
      • 1.1 ctr CLI
      • 1.2 ctr 调试
    • 二、 创建 container
      • 2.1 进入 NewContainer
      • 2.2 ContainerService().Create


前言

介绍了 kubelet 通过 cri 接口和 containerd 交互的过程,containerd 源码分析:启动注册流程 介绍了 containerd 作为高级容器运行时的启动流程。通过这三篇文章熟悉了 kubelet 和 containerd 的行为,对于 containerd 如何通过 OCI 接口创建容器 container 并没有涉及。

本文将继续介绍 containerd 是如何创建容器 container 的。

一. ctr

在介绍创建容器前,首先简单介绍下 ctr。ctr 是 containerd 的命令行客户端,本文会通过 ctr 进行调试和分析。

1.1 ctr CLI

作为命令行工具 ctr 包括一系列和 containerd 交互的命令。主要命令如下:

COMMANDS:
   plugins, plugin            provides information about containerd plugins
   containers, c, container   manage containers
   images, image, i           manage images
   run                        run a container
   snapshots, snapshot        manage snapshots
   tasks, t, task             manage tasks
   install                    install a new package
   oci                        OCI tools
   shim                       interact with a shim directly
containers|c|container

不同与 Kubernetes 层面的 container,这里 ctr 命令管理的 containers 实际是管理存储在 boltDB 中的 container metadata。

创建 container:

# ctr c create docker.io/library/nginx:alpine nginx1
# ctr c ls
CONTAINER    IMAGE                             RUNTIME
nginx1       docker.io/library/nginx:alpine    io.containerd.runc.v2

通过 boltbrowser 查看 boltDB 存储的 container metadata,container metadata 存储在目录 /var/lib/containerd/io.containerd.metadata.v1.bolt。

tasks|t|task

task 是实际启动容器进程的命令,ctr task start 根据创建的 container 启动容器:

# ctr t start nginx1
/docker-entrypoint.sh: /docker-entrypoint.d/ is not empty, will attempt to perform configuration
/docker-entrypoint.sh: Looking for shell scripts in /docker-entrypoint.d/
...

run

ctr 的 run 命令,实际是 ctr c create 和 ctr t start 命令的组合。

接下来,使用 ctr run 命令做为调试参数分析完整的创建 container 容器的流程。

1.2 ctr 调试

ctr 代码集中在 containerd 项目中,配置 ctr 的调试参数:

{
   "version": "0.2.0",
   "configurations": [
      {
         "name": "ctr",
         "type": "go",
         "request": "launch",
         "mode": "auto",
         "program": "${fileDirname}",
         "args": ["run", "docker.io/library/nginx:alpine", "nginx1"]
      }
   ]
}

调试 ctr:

进入 run.Command 看其中做了什么。

// containerd/cmd/ctr/commands/run/run.go
// Command runs a container
var Command = &cli.Command{
	Name:      "run",
	Usage:     "Run a container",
   ...
   Action: func(context *cli.Context) error {
      ...
      // step1: 创建访问 containerd 的 client
      client, ctx, cancel, err := commands.NewClient(context)
		if err != nil {
			return err
		}
		defer cancel()

      // step2: 创建 container
      container, err := NewContainer(ctx, client, context)
		if err != nil {
			return err
		}
      ...

      opts := tasks.GetNewTaskOpts(context)
		ioOpts := []cio.Opt{cio.WithFIFODir(context.String("fifo-dir"))}
      // step3: 创建 task
		task, err := tasks.NewTask(ctx, client, container, context.String("checkpoint"), con, context.Bool("null-io"), context.String("log-uri"), ioOpts, opts...)
		if err != nil {
			return err
		}

      ...
      // step4: 启动 task
      if err := task.Start(ctx); err != nil {
			return err
		}
      ...
   }
}

在 NewContainer 中根据 client 创建 container。接着根据 container 创建 task,然后启动该 task 来启动容器。

二、 创建 container

2.1 进入 NewContainer

// containerd/cmd/ctr/commands/run/run_unix.go
func NewContainer(ctx gocontext.Context, client *containerd.Client, context *cli.Context) (containerd.Container, error) {
   ...
   return client.NewContainer(ctx, id, cOpts...)
}

// containerd/client/client.go
func (c *Client) NewContainer(ctx context.Context, id string, opts ...NewContainerOpts) (Container, error) {
   ...
   container := containers.Container{
		ID: id,
		Runtime: containers.RuntimeInfo{
			Name: c.runtime,
		},
	}
   ...
   // 调用 containerd 接口创建 container
   r, err := c.ContainerService().Create(ctx, container)
	if err != nil {
		return nil, err
	}
	return containerFromRecord(c, r), nil
}

2.2 ContainerService().Create

// containerd/client/containerstore.go
func (r *remoteContainers) Create(ctx context.Context, container containers.Container) (containers.Container, error) {
	created, err := r.client.Create(ctx, &containersapi.CreateContainerRequest{
		Container: containerToProto(&container),
	})
	if err != nil {
		return containers.Container{}, errdefs.FromGRPC(err)
	}

	return containerFromProto(created.Container), nil
}

// containerd/api/services/containers/v1/containers_grpc.pb.go
func (c *containersClient) Create(ctx context.Context, in *CreateContainerRequest, opts ...grpc.CallOption) (*CreateContainerResponse, error) {
	out := new(CreateContainerResponse)
	err := c.cc.Invoke(ctx, "/containerd.services.containers.v1.Containers/Create", in, out, opts...)
	if err != nil {
		return nil, err
	}
	return out, nil
}

调用 /containerd.services.containers.v1.Containers/Create grpc 接口创建 container。container 并不是容器进程,而是存储在数据库中的 container metadata。

/containerd.services.containers.v1.Containers/Create 是由 containerd 的 io.containerd.grpc.v1.containers 插件提供的服务:

// containerd/plugins/services/service.go
func (s *service) Create(ctx context.Context, req *api.CreateContainerRequest) (*api.CreateContainerResponse, error) {
	return s.local.Create(ctx, req)
}

插件实例调用 local 对象的 Create 方法创建 container。查看 local 对象具体指的什么。

// containerd/plugins/services/service.go
func init() {
	registry.Register(&plugin.Registration{
		Type: plugins.GRPCPlugin,
		ID:   "containers",
		Requires: []plugin.Type{
			plugins.ServicePlugin,
		},
		InitFn: func(ic *plugin.InitContext) (interface{}, error) {
         // plugins.ServicePlugin:io.containerd.service.v1
         // services.ContainersService:containers-service
			i, err := ic.GetByID(plugins.ServicePlugin, services.ContainersService)
			if err != nil {
				return nil, err
			}
			return &service{local: i.(api.ContainersClient)}, nil
		},
	})
}

local 对象是 containerd 的 io.containerd.service.v1.containers-service 插件的实例。查看该实例的 Create 方法。

// containerd/plugins/services/containers/local.go
func (l *local) Create(ctx context.Context, req *api.CreateContainerRequest, _ ...grpc.CallOption) (*api.CreateContainerResponse, error) {
	var resp api.CreateContainerResponse

	if err := l.withStoreUpdate(ctx, func(ctx context.Context) error {
		container := containerFromProto(req.Container)

		created, err := l.Store.Create(ctx, container)
		if err != nil {
			return err
		}

		resp.Container = containerToProto(&created)

		return nil
	}); err != nil {
		return &resp, errdefs.ToGRPC(err)
	}
	...

	return &resp, nil
}

local.Create 调用 local.withStoreUpdate 方法创建 container。

// containerd/plugins/services/containers/local.go
func (l *local) withStoreUpdate(ctx context.Context, fn func(ctx context.Context) error) error {
	return l.db.Update(l.withStore(ctx, fn))
}

local.withStoreUpdate 调用 db 对象的 Update 方法创建 container。

// containerd/plugins/services/containers/local.go
func init() {
	registry.Register(&plugin.Registration{
		...
		InitFn: func(ic *plugin.InitContext) (interface{}, error) {
			m, err := ic.GetSingle(plugins.MetadataPlugin)
			if err != nil {
				return nil, err
			}
			ep, err := ic.GetSingle(plugins.EventPlugin)
			if err != nil {
				return nil, err
			}

			db := m.(*metadata.DB)
			return &local{
				Store:     metadata.NewContainerStore(db),
				db:        db,
				publisher: ep.(events.Publisher),
			}, nil
		},
	})
}

db 对象是 io.containerd.metadata.v1 插件的实例,该插件通过 boltDB 提供 metadata 存储服务。

metadata 插件实际调用的是匿名函数 fn 的内容,在 fn 中通过 l.Store.Create(ctx, container) 将 container 的 metadata 信息注册到 boltDB 数据库中。

创建 container 的过程实际是将 container 信息注册到 boltDB 的过程。

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

搜索文章

Tags

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