• Ansible运行原理揭秘:如何用YAML脚本掌控数服务器?

Ansible运行原理揭秘:如何用YAML脚本掌控数服务器?

2025-04-26 17:34:35 0 阅读

1 Ansible基本架构

1.1 Ansible工作模式

Ansible是基于模块工作的,本身没有批量部署的能力,真正具有批量部署能力的是Ansible所运行的模块,Ansible只是提供一种框架。

1.2 Ansible组件

  • Ansible:Ansible核心程序
  • Play books:任务剧本(任务集),编排定义Ansible任务集的配置文件,由Ansible依次执行多个任务,通常是JSON格式的YML文件
  • Host inventory:Ansible管理主机的清单,记录由Ansible管理的主机信息,包括端口、密码、IP等
  • Modules:核心模块,主要操作是通过调用核心模块来完成管理任务
  • CustomModules:自定义模块,完成核心模块无法完成的功能,支持多种语言
  • Connection plugins:基于连接插件连接到各个主机上,即Ansible和Host通信使用,默认是使用SSH
  • Plugins:模块功能的补充,如连接类型插件、循环插件、变量插件等,可借助于插件完成更丰富的功能
  • Playbooks:批量的命令文件
       用户请求发送给Ansible核心模块,Ansible核心模块通过Host inventory模块寻找需要运行的主机,然后通过Connection plugins连接远程的主机,并发送命令。Ansible使用插件来连接每一个被控制端Host,此外,也通过插件来记录日志等信息。

1.3 Ansible生成的主要文件

/etc/ansible
  • /etc/ansible/ansible.cfg :配置文件
  • /etc/ansible/hosts :主机库(host inventory),管理被监控的主机
  • /usr/bin/ansible:主程序
  • /usr/bin/ansible-doc:文档
  • /usr/bin/ansible-playbook:剧本

2 Ansible任务执行模式

2.1 Ansible任务执行模式

Ansible任务执行模式分为2种:
  • ad-hoc模式(点对点模块):使用单个模块,支持批量执行单条命令,相当与在bash中执行一句Shell命
  • playbook模式(剧本模式):Ansible主要的管理方式,通过多个task的集合完成一类功能,可以理解为多个ad-hoc的配置文件

2.2 Ansible任务执行流程

3 Ansible应用

3.1 定义主机列表(Inventory)

        Ansible主要功能在于批量主机操作,为了便捷地使用其中的部分主机,可以在inventory中将主机进行分组命名。默认的inventory file为/etc/ansible/hosts。inventory文件可以有多个,也可以通过Dynamic Inventory来动态生成。
Inventory文件格式:
  • Inventory文件遵循ini文件风格,中括号[]中的字符为组名
  • 可以将同一个主机同时放到不同的组当中
  • 如果主机采用的是非ssh默认端口时,可以在主机名称之后采用冒号加具体端口号来注明
  • 如果主机名遵循相似的命名模式,可以使用列表的形式来表示主机名
  • 主机变量可以在Inventory中定义主机时进行添加,便于在playbook中进行使用
示例:
1.Inventory文件遵循ini文件风格,中括号[]中的字符为组名可以将同一个主机同时放到不同的组当中
[webservers]
node1



[dbservers]
node1

2.如果主机采用的是非ssh默认端口时,可以在主机名称之后采用冒号加具体端口号来注明
[webservers]
node1:2022



[dbservers]
node1

2.如果主机名遵循相似的命名模式,可以使用列表的形式来表示主机名
[webservers]
node[1:3]



[dbservers]
node[1:2]

3.主机变量可以在Inventory中定义主机时进行添加,便于在playbook中进行使用
[webservers]
node1 http_port=80 maxRequestsPerChild=808
node2 http_port=8080 maxRequestsPerChild=909

 Inventory参数:Ansible在基于ssh连接Inventory中指定的远程主机时,可以通过指定参数来指定其交互方式,常用参数如下:

  • ansible_ssh_host:远程主机
  • ansible_ssh_user:指定远程主机ssh端口
  • ansible_ssh_pass:连接远程主机使用的密码
  • ansible_sudo_pass:sudo密码,建议使用--ask-sudo-pass命令
  • ansible_connection:指定连接类型,类型包括:local、ssh、paramiko
  • ansible_shell_type:指定连接对端的shell类型,默认支持sh
  • ansible_ssh_private_key_file:ssh连接使用的私钥
  • ansible_python_interpreter:指定对端使用的python编译器路径
示例:
根据定义的Inventory调用ping检测网络是否可达:
检测Inventory中定义的所有主机:ansible all -m ping

[root@node2 ~]# ansible all -m ping
192.168.10.32 | SUCCESS => {
    "ansible_facts": {
        "discovered_interpreter_python": "/usr/bin/python"
    }, 
    "changed": false, 
    "ping": "pong"
}
192.168.10.30 | SUCCESS => {
    "ansible_facts": {
        "discovered_interpreter_python": "/usr/bin/python"
    }, 
    "changed": false, 
    "ping": "pong"
}
192.168.10.31 | SUCCESS => {
    "ansible_facts": {
        "discovered_interpreter_python": "/usr/bin/python"
    }, 
    "changed": false, 
    "ping": "pong"
}
[root@node2 ~]# 


检测Inventory中定义的dbservers组的主机:ansible dbservers -m ping
[root@node2 ~]# ansible dbservers -m ping
192.168.10.30 | SUCCESS => {
    "ansible_facts": {
        "discovered_interpreter_python": "/usr/bin/python"
    }, 
    "changed": false, 
    "ping": "pong"
}
[root@node2 ~]# 

检测指定单台主机:ansible 192.168.10.30 -m ping
[root@node2 ~]# ansible 192.168.10.30 -m ping
192.168.10.30 | SUCCESS => {
    "ansible_facts": {
        "discovered_interpreter_python": "/usr/bin/python"
    }, 
    "changed": false, 
    "ping": "pong"
}
[root@node2 ~]# 

3.2 基于ad-hoc模式运行

Ansible通过ssh实现目标主机的配置管理、应用部署、任务执行等操作,故而需要事先配置Ansible端能基于秘钥认证的方式连接各被管理节点。

基本语法:
ansible  -m  -a  [options]

解释:
:目标主机或主机组,可以是Inventory中的主机名、IP地址、主机组或关键字(如all)
-m :指定要使用的模块(如ping、shell、copy等)
-a :传递给模块的参数
[options]:可选参数,用于控制Ansible行为

3.2.1 常用选项

模块

描述

-i

指定自定义的Inventory文件

--private-key

指定SSH私钥文件

-u

指定SSH用户

-k

提示输入SSH密码

-K

提示输入become(提权)密码(如sudo密码)

-b

使用become(提权)执行任务(如sudo)

--become-user

指定提权后的用户(默认为root)

-v

输出详细信息(-vvv或-vvvv可增加调试信息)

--check

模拟运行(不实际执行任何更改)

--diff

显示文件的差异(适用于文件相关模块,如copy、template)

--ask-pass

提示输入SSH密码

--limit

限制运行的主机范围(如limit webservers只对webservers组的主机生效)

示例:使用shell模块检查/etc/passwd文件中是否包含 root
ansible all -m shell -a 'grep root /etc/passwd'

[root@node2 ~]# ansible all -m shell -a 'grep root /etc/passwd'
192.168.10.30 | CHANGED | rc=0 >>
root:x:0:0:root:/root:/bin/bash
operator:x:11:0:operator:/root:/sbin/nologin
192.168.10.32 | CHANGED | rc=0 >>
root:x:0:0:root:/root:/bin/bash
operator:x:11:0:operator:/root:/sbin/nologin
192.168.10.31 | CHANGED | rc=0 >>
root:x:0:0:root:/root:/bin/bash
operator:x:11:0:operator:/root:/sbin/nologin
[root@node2 ~]# 

3.2.2 常用模块

选项

解释

ping

目标主机连通性测试

command

在远程主机上执行命令,不支持管道

shell

在目标远程主机上调用shell解释器,支持管道命令

copy

复制文件到目标远程服务器主机上,支持设定内容和修改权限

file

创建文件、链接文件以及删除文件等操作

yum

服务安装

fetch

从远程目标主机复制文件到本地

cron

crontab计划任务管理

service

服务管理

user

用户管理

group

用户组管理

setup

主要是收集信息

script

将本地脚本在目标远端服务器主机上运行

示例:使用file模块在目标远程主机上创建文件
ansible all -m file -a "path=/tmp/tmp.txt state=touch"

[root@node2 ~]# ansible all -m file -a "path=/tmp/tmp.txt state=touch"
192.168.10.31 | CHANGED => {
    "ansible_facts": {
        "discovered_interpreter_python": "/usr/bin/python"
    }, 
    "changed": true, 
    "dest": "/tmp/tmp.txt", 
    "gid": 0, 
    "group": "root", 
    "mode": "0644", 
    "owner": "root", 
    "secontext": "unconfined_u:object_r:user_tmp_t:s0", 
    "size": 0, 
    "state": "file", 
    "uid": 0
}
192.168.10.32 | CHANGED => {
    "ansible_facts": {
        "discovered_interpreter_python": "/usr/bin/python"
    }, 
    "changed": true, 
    "dest": "/tmp/tmp.txt", 
    "gid": 0, 
    "group": "root", 
    "mode": "0644", 
    "owner": "root", 
    "size": 0, 
    "state": "file", 
    "uid": 0
}
192.168.10.30 | CHANGED => {
    "ansible_facts": {
        "discovered_interpreter_python": "/usr/bin/python"
    }, 
    "changed": true, 
    "dest": "/tmp/tmp.txt", 
    "gid": 0, 
    "group": "root", 
    "mode": "0644", 
    "owner": "root", 
    "size": 0, 
    "state": "file", 
    "uid": 0
}

3.3 基于playbook模式执行

Playbook模式是一种通过编写YAML格式的脚本文件(称为 playbook)来定义和执行自动化任务的方式,playbook是由一个或者多个play组成的列表,play主要功能是将事先归并为一组的主机装扮成事先通过task定义好角色,task就是调用的AnsiBle的一个模块(module)。
playbook的组成部分:
  • hosts:用于指定要执行的指定任务的主机组,其可以是一个或者多个由冒号组成的主机组
  • user:指定远程主机上执行任务的用户,也可以自定sudo的用户
  • variable:用于定义playbook运行时使用的变量
  • tasks:用于定义在远程目标主机上执行的任务列表,包括
                    1)name:任务的名称,建议描述任务执行步骤
                    2)module:options:调用Ansible的模块module和传入的参数
  • handler:用于定义task完成后需要调用的任务,包括
                    1)notify:在每个paly的最后触发,调用在handler中定义的操作
                    2)handler:task的列表
playbook示例:
---
- hosts: web  # 目标主机组
  become: yes  # 使用提权(如 sudo)
  tasks:
    - name: Ensure Apache is installed
      yum:
        name: httpd
        state: present

    - name: Ensure Apache is running
      service:
        name: httpd
        state: started

3.3.1 playbook核心组件

1. hosts 
作用:指定目标主机或主机组(在Inventory)中定义
示例:
hosts: webserver
2. tasks 
作用:定义要执行的任务列表
每个任务包含内容:
name:任务描述(可选,推荐使用)
模块名称(如yum、copy、service等)
模块参数

示例:
tasks:
  - name: Ensure Apache is installed
    yum:
      name: httpd
      state: present

3. vars 

作用:定义变量
示例:
vars:
  http_port: 80

4. handlers

作用:定义处理器,通常用于重启服务
示例:
handlers:
  - name: Restart Apache
    service:
      name: httpd
      state: restarted
5.  become
作用:是否使用提权(如sudo)
示例:
become: yes

3.3.2 playbook的执行

ansible-playbook playbook.yml

常用选项:

选项

描述

-i

指定自定义的Inventory文件

--limit

限制运行的主机范围

--check

模拟运行(不实际执行任何更改)

--diff

显示文件的差异(适用于文件相关模块,如copy、template)

--tags

只运行指定标签的任务

--skip-tags

跳过指定标签的任务

-v

输出详细信息(-vvv或-vvvv可增加调试信息)

3.3.3 playbook高级用法

1.条件判断

使用when关键字根据条件执行任务
示例:
tasks:
  - name: Install Apache on CentOS
    yum:
      name: httpd
      state: present
    when: ansible_os_family == "RedHat"

2. 循环

使用loop关键字实现循环
示例:
tasks:
  - name: Ensure users are present
    user:
      name: "{{ item }}"
      state: present
    loop:
      - alice

3. 模版

使用template模块生成动态配置文件
示例:
tasks:
  - name: Configure Apache
    template:
      src: templates/httpd.conf.j2
      dest: /etc/httpd/httpd.conf

4. 角色

将Playbook分解为可重用的角色
示例:
roles:
  - common
  - webserver

3.3.4 案例:安装httpd

1.创建playbook相关目录

[root@node2 ansible]# mkdir apache-playbook
[root@node2 ansible]# cd apache-playbook
[root@node2 ansible]# mkdir files
[root@node2 ansible]# mkdir templates

2.编辑Inventory文件,增加主机组web

[root@node2 ansible]# echo "[web]" >>/etc/ansible/hosts

[root@node2 ansible]# echo "192.168.10.32" >>/etc/ansible/hosts
[root@node2 ansible]# 

3.创建plalybook.yml文件,增加如下内容

---
- hosts: web  # 目标主机组
  become: yes  # 使用提权(如 sudo)
  vars:
    http_port: 80  # 定义 HTTP 端口
    html_content: "Hello, Ansible!"  # 定义 HTML 页面内容

  tasks:
    # 1. 安装 Apache
    - name: Ensure Apache is installed
      yum:
        name: httpd
        state: present

    # 2. 配置 Apache
    - name: Configure Apache
      template:
        src: templates/httpd.conf.j2  # 模板文件
        dest: /etc/httpd/conf/httpd.conf  # 目标配置文件
      notify: Restart Apache  # 触发处理器

    # 3. 部署 HTML 页面
    - name: Deploy HTML page
      copy:
        content: "{{ html_content }}"
        dest: /var/www/html/index.html

    # 4. 启动 Apache 并设置开机自启
    - name: Ensure Apache is running and enabled
      service:
        name: httpd
        state: started
        enabled: yes

  handlers:
    # 定义处理器,用于重启 Apache
    - name: Restart Apache
      service:
        name: httpd
        state: restarted

4.创建模版文件,在templates目录下创建httpd.conf.j2文件,并增加如下内容

# {{ ansible_managed }} - DO NOT EDIT MANUALLY

Listen {{ http_port }}

{ http_port }}>
    DocumentRoot "/var/www/html"
    ServerAdmin webmaster@localhost
    ErrorLog /var/log/httpd/error.log
    CustomLog /var/log/httpd/access.log combined

5.运行playbook

ansible-playbook -i /etc/ansible/hosts playbook.yml
[root@node2 apache-playbook]# ansible-playbook -i /etc/ansible/hosts playbook.yml

PLAY [web] **********************************************************************************************************************************************************************

TASK [Gathering Facts] **********************************************************************************************************************************************************
ok: [192.168.10.32]

TASK [Ensure Apache is installed] ***********************************************************************************************************************************************
ok: [192.168.10.32]

TASK [Configure Apache] *********************************************************************************************************************************************************
ok: [192.168.10.32]

TASK [Deploy HTML page] *********************************************************************************************************************************************************
ok: [192.168.10.32]

TASK [Ensure Apache is running and enabled] *************************************************************************************************************************************
ok: [192.168.10.32]

PLAY RECAP **********************************************************************************************************************************************************************
192.168.10.32              : ok=5    changed=0    unreachable=0    failed=0    skipped=0    rescued=0    ignored=0   

[root@node2 apache-playbook]# 

6.验证结果

[root@node2 apache-playbook]# curl http://192.168.10.30
Hello, Ansible!
[root@node2 apache-playbook]# 

 

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

搜索文章

Tags

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