最新资讯

  • [DevOps]使用github-action工具部署docker容器(实现提交代码一键推送部署到服务器)

[DevOps]使用github-action工具部署docker容器(实现提交代码一键推送部署到服务器)

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

前提:云服务器、docker 账号、GitHub 账号

CI/CD 主要有三种实现方式:

  • 直接命令行部署:通过脚本直接部署到服务器
  • 服务器工具部署:使用阿里云等服务器提供的部署工具
  • GitHub Actions 自动化部署:基于代码提交自动触发部署

1. 命令行直接部署

项目结构

  • env 文件: 存放服务器端口、账号等配置信息
  • deploy 脚本: 编写主要部署逻辑
  • docker 文件: Docker 容器配置
  • nginx 配置: Web 服务器配置文件

部署脚本示例

Docker Compose 配置文件

docker-compose.yml

version: "3"
services:
  mainpage:
    image: nginx:stable-alpine
    container_name: mainpage-nginx
    restart: always
    ports:
      - "80:80"
    volumes:
      # Nginx 配置
      - ./nginx.conf:/etc/nginx/conf.d/default.conf:ro
      # 0MainPage 构建产物
      - /root/project/0MainPage/dist:/usr/share/nginx/html:ro
Nginx 配置文件

nginx.conf

server {
    listen       80;
    server_name  localhost;

    # MIME 类型配置
    include       /etc/nginx/mime.types;
    default_type  application/octet-stream;

    # 安全头配置
    add_header X-Frame-Options "SAMEORIGIN" always;
    add_header X-Content-Type-Options "nosniff" always;
    add_header X-XSS-Protection "1; mode=block" always;
    add_header Referrer-Policy "strict-origin-when-cross-origin" always;

    # 开启 gzip 压缩
    gzip on;
    gzip_min_length 1k;
    gzip_comp_level 6;
    gzip_types text/plain application/javascript application/x-javascript text/css application/xml text/javascript application/x-httpd-php image/jpeg image/gif image/png application/json;
    gzip_vary on;
    gzip_disable "MSIE [1-6].";

    # 静态资源缓存配置 - JS文件
    location ~* .js$ {
        root /usr/share/nginx/html;
        add_header Content-Type "application/javascript; charset=utf-8";
        expires 1y;
        add_header Cache-Control "public, immutable";
        access_log off;
    }

    # 静态资源缓存配置 - CSS文件
    location ~* .css$ {
        root /usr/share/nginx/html;
        add_header Content-Type "text/css; charset=utf-8";
        expires 1y;
        add_header Cache-Control "public, immutable";
        access_log off;
    }

    # 静态资源缓存配置 - 图片和字体文件
    location ~* .(png|jpg|jpeg|gif|ico|svg|woff|woff2|ttf|eot)$ {
        root /usr/share/nginx/html;
        expires 1y;
        add_header Cache-Control "public, immutable";
        access_log off;
    }

    # HTML文件不缓存
    location ~* .html$ {
        root /usr/share/nginx/html;
        add_header Cache-Control "no-cache, no-store, must-revalidate";
        add_header Pragma "no-cache";
        add_header Expires "0";
    }

    # 0MainPage - 主页项目(根路径)
    location / {
        root   /usr/share/nginx/html;
        index  index.html index.htm;
        try_files $uri $uri/ /index.html;
    }

    error_page   500 502 503 504  /50x.html;
    location = /50x.html {
        root   /usr/share/nginx/html;
    }
}
PowerShell 部署脚本

deploy.ps1

# Deploy script for 0MainPage project
Write-Host "[Deploy] Starting 0MainPage deployment process..." -ForegroundColor Green

# Load environment variables from .env file

$envFile = Join-Path $PSScriptRoot ".env-0mainpage"
if (Test-Path $envFile) {
    Write-Host "[Config] Loading environment variables from .env file..." -ForegroundColor Yellow
    Get-Content $envFile | ForEach-Object {
        if ($_.Trim() -match "^([^#][^=]+)=(.*)$") {
            $name = $matches[1].Trim()
            $value = $matches[2].Trim()
            [Environment]::SetEnvironmentVariable($name, $value, "Process")
        }
    }
} else {
    Write-Host "[Warning] .env file not found, using default values" -ForegroundColor Yellow
}

# Server configuration from environment variables

$serverHost = if ($env:SERVER_HOST) { $env:SERVER_HOST } else { "" }
$serverUser = if ($env:SERVER_USER) { $env:SERVER_USER } else { "" }
$serverPassword = $env:SERVER_PASSWORD
$serverPath = if ($env:SERVER_0MAINPAGE_PATH) { $env:SERVER_0MAINPAGE_PATH } else { "/root/project/0MainPage/dist" }
$serverConfigPath = if ($env:SERVER_CONFIG_PATH) { $env:SERVER_CONFIG_PATH } else { "/root/project/CD/0MainPage" }
$projectPath = if ($env:LOCAL_0MAINPAGE_PATH) { $env:LOCAL_0MAINPAGE_PATH } else { "C:UserswhatDesktopmy-projectMainPage" }

if (-not $serverPassword) {
    Write-Host "[Error] SERVER_PASSWORD not found in environment variables" -ForegroundColor Red
    exit 1
}

Write-Host "[Config] Server: $serverHost" -ForegroundColor Yellow
Write-Host "[Config] Target: 0MainPage (Port 80)" -ForegroundColor Yellow
Write-Host "[Config] Project Path: $projectPath" -ForegroundColor Yellow

# Check and navigate to 0MainPage

if (!(Test-Path $projectPath)) {
    Write-Host "[Error] 0MainPage directory not found at: $projectPath" -ForegroundColor Red
    exit 1
}

$currentPath = Get-Location
Set-Location $projectPath
Write-Host "[Info] Changed to project directory: $projectPath" -ForegroundColor Yellow

try { # 1. Install dependencies if needed
    if (!(Test-Path "node_modules")) {
        Write-Host "[Step1] Installing dependencies..." -ForegroundColor Cyan
        npm install
        if ($LASTEXITCODE -ne 0) {
            throw "Dependencies installation failed with exit code $LASTEXITCODE"
        }
    }

    # 2. Build project
    Write-Host "[Step2] Building 0MainPage project..." -ForegroundColor Cyan
    npm run build
    if ($LASTEXITCODE -ne 0) {
        throw "Build command failed with exit code $LASTEXITCODE"
    }

    if (!(Test-Path "dist")) {
        Write-Host "[Error] Build failed, dist directory not found" -ForegroundColor Red
        exit 1
    }

    # 3. Create server directory if not exists
    Write-Host "[Step3] Preparing server directory..." -ForegroundColor Cyan
    $plinkExists = Get-Command plink -ErrorAction SilentlyContinue
    if ($plinkExists) {
        try {
            $plinkCommand = "echo y | plink -pw '$serverPassword' ${serverUser}@${serverHost} 'mkdir -p ${serverPath} && mkdir -p ${serverConfigPath}'"
            Write-Host "[Execute] Creating directories on server..." -ForegroundColor Gray
            Invoke-Expression $plinkCommand
        } catch {
            Write-Host "[Warning] Directory creation failed: $_" -ForegroundColor Yellow
        }
    }

    # 4. Upload dist to server
    Write-Host "[Step4] Uploading 0MainPage dist to server..." -ForegroundColor Cyan
    $pscpExists = Get-Command pscp -ErrorAction SilentlyContinue
    if ($pscpExists) {
        try {
            $pscpCommand = "echo y | pscp -pw '$serverPassword' -r dist/* ${serverUser}@${serverHost}:${serverPath}/"
            Write-Host "[Execute] Uploading files..." -ForegroundColor Gray
            Invoke-Expression $pscpCommand
        } catch {
            throw "File transfer failed: $_"
        }
    }

    # 5. Upload config files
    Write-Host "[Step5] Uploading 0MainPage config files..." -ForegroundColor Cyan
    $configPath = $PSScriptRoot
    if (Test-Path $configPath) {
        if ($pscpExists) {
            $pscpConfigCommand = "pscp -pw '$serverPassword' ${configPath}/docker-compose.yml ${configPath}/nginx.conf ${serverUser}@${serverHost}:${serverConfigPath}/"
            Write-Host "[Execute] Uploading config files..." -ForegroundColor Gray
            Invoke-Expression $pscpConfigCommand
        }
    }

    # 6. Stop existing container
    Write-Host "[Step6] Stopping existing 0MainPage container..." -ForegroundColor Cyan
    try {
        if ($plinkExists) {
            $plinkCommand = "plink -batch -pw '$serverPassword' ${serverUser}@${serverHost} 'cd ${serverConfigPath} && docker stop mainpage-nginx || true && docker rm mainpage-nginx || true'"
            Write-Host "[Execute] Stopping existing container..." -ForegroundColor Gray
            Invoke-Expression $plinkCommand
        }
    } catch {
        Write-Host "[Info] No existing container to stop" -ForegroundColor Yellow
    }

    # 7. Start 0MainPage container
    Write-Host "[Step7] Starting 0MainPage container..." -ForegroundColor Cyan
    try {
        if ($plinkExists) {
            $plinkCommand = "plink -batch -pw '$serverPassword' ${serverUser}@${serverHost} 'cd ${serverConfigPath} && docker compose up -d'"
            Write-Host "[Execute] Starting container..." -ForegroundColor Gray
            Invoke-Expression $plinkCommand
        }
    } catch {
        Write-Host "[Error] Container start failed: $_" -ForegroundColor Red
        throw
    }

    # 8. Verify deployment
    Write-Host "[Step8] Verifying 0MainPage deployment..." -ForegroundColor Cyan
    try {
        if ($plinkExists) {
            $plinkVerifyCommand = "plink -batch -pw '$serverPassword' ${serverUser}@${serverHost} 'docker ps | grep mainpage-nginx'"
            Write-Host "[Execute] Verifying container..." -ForegroundColor Gray
            Invoke-Expression $plinkVerifyCommand
        }
    } catch {
        Write-Host "[Warning] Verification failed: $_" -ForegroundColor Yellow
    }

    Write-Host "[Done] 0MainPage deployment successful!" -ForegroundColor Green
    Write-Host "[Access] http://$serverHost" -ForegroundColor Yellow

} catch {
    Write-Host "[Error] Deployment failed: $_" -ForegroundColor Red
    exit 1
} finally {
    Set-Location $currentPath
}

2. 服务器工具部署

使用阿里云、腾讯云等云服务商提供的部署工具,具体配置根据服务商文档进行设置。

3. GitHub Actions 自动化部署(推荐)

提供两种部署模式:

  • 主分支自动部署:提交代码到主分支时自动触发部署
  • 标签部署:根据 Git Tag 来触发部署

Dockerfile 配置

# 构建阶段
FROM node:20-alpine as build-stage

WORKDIR /app

# 复制 package 文件
COPY package*.json ./
COPY pnpm-lock.yaml ./

# 安装 pnpm 并安装依赖
RUN npm install -g pnpm
RUN pnpm install

# 复制源代码(排除 node_modules)
COPY src ./src
COPY public ./public
COPY index.html ./
COPY vite.config.ts ./
COPY tsconfig.json ./
COPY tsconfig.app.json ./
COPY tsconfig.node.json ./

# 构建应用
RUN pnpm run build

# 生产阶段
FROM nginx:stable-alpine as production-stage

# 复制自定义 nginx 配置
COPY nginx.conf /etc/nginx/conf.d/default.conf

# 复制构建产物
COPY --from=build-stage /app/dist /usr/share/nginx/html

# 暴露端口
EXPOSE 80

CMD ["nginx", "-g", "daemon off;"]

GitHub Actions 配置文件

name: Publish Image

on:
  push:
    branches: ["master"]
    paths-ignore:
      - ".gitignore"
      - "README.md"
      - ".vscode/**"
  pull_request:
    branches: ["master"]

jobs:
  build:
    runs-on: ubuntu-latest
    steps:
      - uses: actions/checkout@v4

      - uses: docker/login-action@v3
        with:
          registry: ghcr.io
          username: ${{ github.actor }}
          password: ${{ secrets.GITHUB_TOKEN }}

      - uses: actions/setup-node@v4
        with:
          node-version: "20"

      - uses: actions/cache@v4
        id: cache
        with:
          path: node_modules
          key: ${{ runner.os }}-node-${{ hashFiles('package-lock.json') }}
          restore-keys: |
            ${{ runner.os }}-node-

      - name: Install dependencies
        if: steps.cache.outputs.cache-hit != 'true'
        run: npm install

      - name: Build
        run: npm run build

      - name: Build and push Docker image
        run: |
          docker build . --file Dockerfile --tag ghcr.io/${{ github.repository_owner }}/0mainpage:latest
          docker push ghcr.io/${{ github.repository_owner }}/0mainpage:latest

      - name: Deploy to server
        uses: appleboy/ssh-action@v1.0.0
        with:
          host: ${{ secrets.SERVER_HOST }}
          username: ${{ secrets.SERVER_USER }}
          password: ${{ secrets.SERVER_PASSWORD }}
          port: ${{ secrets.SERVER_PORT || '22' }}
          timeout: 30s
          command_timeout: 10m
          debug: true
          script: |
            docker stop mainpage-nginx || true
            docker rm mainpage-nginx || true
            docker login -u ${{ github.actor }} -p ${{ secrets.GITHUB_TOKEN }} https://ghcr.io
            docker pull ghcr.io/${{ github.repository_owner }}/0mainpage:latest
            docker run -dp 80:80 --restart=always --name mainpage-nginx ghcr.io/${{ github.repository_owner }}/0mainpage:latest

GitHub 仓库配置

需要在 GitHub 仓库的 Settings > Secrets and variables > Actions 中配置以下环境变量:

  • SERVER_HOST: 服务器地址
  • SERVER_USER: 服务器用户名
  • SERVER_PASSWORD: 服务器密码
  • SERVER_PORT: SSH 端口(默认 22)

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

搜索文章

Tags

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