最新资讯

  • 新手必看!手把手教你在无界面 Linux 服务器上运行 DrissionPage

新手必看!手把手教你在无界面 Linux 服务器上运行 DrissionPage

2026-01-29 00:30:41 栏目:最新资讯 3 阅读

新手必看!手把手教你在无界面 Linux 服务器上运行 DrissionPage

一、引言:为什么要在无界面 Linux 服务器上用 DrissionPage?

在自动化办公、网页数据采集、UI 自动化测试等场景中,DrissionPage 是一款极具优势的 Python 工具——它融合了 Selenium 和 Requests 的核心能力,既支持模拟浏览器渲染动态页面,又能像 Requests 一样高效发送 HTTP 请求,还能自动处理 Cookie 同步、验证码识别(需配合插件)等复杂问题,对新手友好度远超传统工具。

而无界面 Linux 服务器(如 Ubuntu Server、CentOS)则是企业级自动化任务的常用载体:它资源占用低(无需运行图形界面)、稳定性强(可 7x24 小时不间断运行)、部署成本低(云服务器最低配置即可满足需求)。将 DrissionPage 部署在无界面 Linux 服务器上,能实现“脚本后台运行、结果自动存储、远程随时管理”的需求,比如定时爬取行业数据、自动生成日报、监控网页更新等。

但对新手而言,“无界面 Linux”+“浏览器自动化”的组合容易踩坑:比如不知道如何安装浏览器驱动、不理解“无头模式”配置、遇到依赖缺失报错时无从下手。本文将从“服务器准备”到“脚本部署上线”,用超详细的步骤和代码示例,帮你零门槛搞定整个流程,每个操作都附带“命令解释”和“错误解决方法”,确保你能跟着做、做必成。

二、准备工作:你需要这些工具和环境

在开始操作前,我们先理清需要准备的“硬件”和“软件”——新手不用慌,大部分工具都是免费的,且配置步骤非常简单。

2.1 核心工具清单

工具/环境作用说明推荐选择新手友好度
无界面 Linux 服务器运行 DrissionPage 脚本的“主机”阿里云轻量应用服务器(Ubuntu 22.04)★★★★★
SSH 连接工具远程控制 Linux 服务器(输入命令、传文件)FinalShell(Windows/Mac)★★★★★
本地电脑编写脚本、通过 SSH 连接服务器Windows 10/11 或 MacOS——
Python 环境执行 DrissionPage 脚本的基础Python 3.8~3.11(推荐 3.10)★★★★☆
浏览器+驱动DrissionPage 模拟浏览器的依赖Chrome + ChromeDriver★★★★☆

2.2 服务器购买与初始化(以阿里云为例)

如果你还没有 Linux 服务器,推荐选择 阿里云轻量应用服务器(新手优惠价低至 99 元/年),步骤如下:

  1. 打开阿里云官网(https://www.aliyun.com/),注册并登录账号;
  2. 搜索“轻量应用服务器”,进入购买页面,按以下参数配置:
    • 地域:选择离你最近的地区(如“华东 1-上海”),延迟更低;
    • 操作系统:Ubuntu 22.04 LTS 64位(LTS 版本长期支持,稳定性强,适合新手);
    • 实例规格:入门选择“1核2G”即可(运行 DrissionPage 足够,后续可升级);
    • 存储:默认 40G 云盘(无需修改);
    • 购买时长:按需求选择(新手建议先买 1 个月试手);
  3. 支付完成后,进入“轻量应用服务器控制台”,找到你的服务器,记录 公网 IP 地址(后续连接需要);
  4. 初始化登录密码:点击“远程连接”→“设置密码”,设置一个复杂密码(包含大小写字母、数字、符号),记住这个密码(SSH 连接时用)。

2.3 SSH 工具安装与服务器连接(以 FinalShell 为例)

FinalShell 是免费的 SSH 工具,支持可视化文件传输(不用记复杂的 scp 命令),新手必用:

  1. 下载 FinalShell:进入官网(https://www.hostbuf.com/),根据本地电脑系统(Windows/Mac)下载对应版本;
  2. 安装 FinalShell:双击安装包,按默认步骤下一步即可(Windows 需注意勾选“添加到桌面快捷方式”);
  3. 连接服务器:
    • 打开 FinalShell,点击左上角“文件夹”图标→“新建连接”→“SSH 连接”;
    • 填写连接信息:
      • 名称:自定义(如“我的 Linux 服务器”);
      • 主机:输入服务器的“公网 IP 地址”(从阿里云控制台复制);
      • 端口:默认 22(Linux SSH 标准端口,无需修改);
      • 用户名:Ubuntu 默认用户名是 ubuntu(CentOS 是 root,注意区分);
      • 密码:输入你在阿里云设置的服务器登录密码;
    • 点击“确定”,然后双击左侧列表中的连接,首次连接会提示“是否信任主机”,点击“信任”,稍等 1-2 秒,即可成功连接(下方黑色窗口是命令行,右侧是文件管理器)。

2.4 基础 Linux 命令预习(新手必记)

后续操作需要在命令行输入 Linux 命令,先记住这几个核心命令,后续会反复用到:

  • ls:查看当前目录下的文件/文件夹(类似 Windows 的“查看文件列表”);
  • cd 路径:切换目录(如 cd /home/ubuntu 切换到 ubuntu 用户的主目录);
  • sudo 命令:以管理员权限执行命令(很多操作需要权限,比如安装软件,输入后会提示输密码,输密码时不会显示,输完按回车即可);
  • apt update:更新 Ubuntu 的软件源列表(安装软件前先执行,确保能下载到最新版本);
  • apt install 软件名:安装软件(如 apt install python3 安装 Python3);
  • python3 --version:查看 Python3 版本(验证是否安装成功);
  • pip3 --version:查看 pip3 版本(pip 是 Python 的包管理工具,用来装 DrissionPage)。

三、环境搭建:从 0 到 1 配置 Linux 服务器

这是最关键的一步——我们需要在无界面 Linux 上安装 Python3Chrome 浏览器(无头版)ChromeDriver 驱动,以及 DrissionPage 本身。每个环节都有“避坑指南”,一定要按步骤来。

3.1 第一步:安装 Python3 和 pip3

Ubuntu 22.04 自带 Python3,但可能没有安装 pip3,需要手动补充:

  1. 打开 FinalShell 的命令行窗口,先更新软件源(确保安装不报错):

    sudo apt update
    

    执行后会显示一堆更新信息,等待 10-30 秒(取决于网络速度),最后显示“完成”即可。

  2. 安装 Python3 和 pip3(如果已安装,会提示“已最新”):

    sudo apt install python3 python3-pip -y
    

    解释:-y 表示“所有确认项都选 yes”,不用手动按 y 确认;这条命令会同时安装 Python3 和 pip3。

  3. 验证安装是否成功:

    python3 --version  # 查看 Python 版本,应显示 3.10.x(如 3.10.12)
    pip3 --version     # 查看 pip 版本,应显示 22.x 或更高(如 22.0.2)
    

    如果两条命令都能显示版本号,说明 Python 环境没问题;如果提示“command not found”,重新执行步骤 2(可能是网络问题导致安装中断)。

3.2 第二步:安装 Chrome 浏览器(无头版)

无界面 Linux 不能运行带图形的 Chrome,所以需要安装“无头版 Chrome”(即 chromium-browser,Ubuntu 官方维护的开源版本,与 Chrome 功能一致,支持无头模式):

  1. 安装 chromium-browser 和依赖库(解决“缺失 lib 库”报错):

    sudo apt install chromium-browser chromium-chromedriver -y
    

    解释:这条命令会同时安装“无头 Chrome”和“对应版本的 ChromeDriver”,避免后续手动匹配驱动版本(新手最容易踩的坑就是“浏览器和驱动版本不匹配”,这条命令直接帮你搞定)。

  2. 验证 Chrome 是否安装成功:

    chromium-browser --version  # 查看浏览器版本,如 112.0.5615.49
    chromedriver --version      # 查看驱动版本,应与浏览器版本一致(如 112.0.5615.49)
    

    关键:浏览器版本和驱动版本必须完全一致(至少前几位一致,如 112.0.5615),如果不一致,后续运行 DrissionPage 会报错。

  3. 测试无头模式是否可用:
    执行以下命令,让 Chrome 在无头模式下打开百度(无界面环境下不会弹出浏览器窗口):

    chromium-browser --headless=new --no-sandbox --disable-dev-shm-usage https://www.baidu.com
    

    解释:

    • --headless=new:启用新的无头模式(比旧模式更稳定,支持所有 Chrome 功能);
    • --no-sandbox:关闭沙箱模式(Linux 无界面环境必须加,否则会报错);
    • --disable-dev-shm-usage:禁用共享内存(避免小内存服务器出现“内存不足”报错);
      执行后如果没有报错,等待 5 秒按 Ctrl+C 退出,说明无头模式可用。

3.3 第三步:安装 DrissionPage

DrissionPage 是 Python 库,用 pip3 安装即可,步骤超简单:

  1. 直接用 pip3 安装最新版本:

    pip3 install drissionpage -i https://pypi.tuna.tsinghua.edu.cn/simple
    

    解释:-i https://pypi.tuna.tsinghua.edu.cn/simple 是使用清华镜像源,下载速度比默认源快 10 倍(避免因网络慢导致安装失败)。

  2. 验证安装是否成功:
    进入 Python 交互模式,导入 DrissionPage 并查看版本:

    python3  # 进入 Python 交互模式(命令行显示 >>> 表示进入成功)
    from drissionpage import __version__  # 导入版本模块
    print(__version__)  # 打印版本号,应显示 4.x 或更高(如 4.1.2)
    exit()  # 退出 Python 交互模式,回到 Linux 命令行
    

    如果没有报错且能显示版本号,说明 DrissionPage 安装成功;如果提示“ModuleNotFoundError: No module named ‘drissionpage’”,重新执行步骤 1(可能是镜像源问题,换用阿里云镜像源:-i https://mirrors.aliyun.com/pypi/simple/)。

四、核心操作:编写第一个 DrissionPage 脚本(无界面运行)

环境搭好后,我们来写一个“无界面运行”的脚本——功能是:用 DrissionPage 打开百度,搜索“DrissionPage”,获取搜索结果的标题和链接,最后将结果保存到本地文件。

4.1 步骤 1:在服务器上创建脚本文件

我们用 FinalShell 的“可视化文件管理器”创建脚本,不用记 vim 命令(新手用 vim 容易误操作):

  1. 在 FinalShell 右侧的文件管理器中,进入 /home/ubuntu 目录(ubuntu 用户的主目录,权限足够,适合存脚本);
  2. 右键点击空白处→“新建文件”,文件名输入 baidu_search.py(后缀 .py 表示 Python 脚本);
  3. 双击打开 baidu_search.py 文件,进入编辑模式(和记事本一样,直接输入代码)。

4.2 步骤 2:编写脚本代码(附带详细注释)

将以下代码复制到 baidu_search.py 中,每个步骤都有注释,新手能看懂每一行的作用:

# 1. 导入 DrissionPage 的核心类(Chromium 用于控制浏览器,Session 用于发送 HTTP 请求,这里用 Chromium)
from drissionpage import Chromium
# 导入 time 模块(用于加延迟,避免操作太快被反爬)
import time

# 2. 配置 Chrome 无头模式参数(关键:无界面运行必须加这些参数)
chrome_options = {
    # 启用无头模式(无界面运行)
    "headless": True,
    # 关闭沙箱模式(Linux 无界面环境必填,否则报错)
    "no_sandbox": True,
    # 禁用共享内存(小内存服务器必填,避免内存不足)
    "disable_dev_shm_usage": True,
    # 禁用 GPU 加速(无界面环境不需要 GPU,禁用后更稳定)
    "disable_gpu": True,
    # 设置浏览器窗口大小(可选,部分网站需要固定大小才能正常渲染)
    "window_size": (1920, 1080)
}

# 3. 创建 Chromium 浏览器对象(传入无头模式参数)
# 注意:Linux 上 Chromium 的可执行文件路径是 "/usr/bin/chromium-browser",需要指定 executable_path
browser = Chromium(
    executable_path="/usr/bin/chromium-browser",
    options=chrome_options
)

try:
    # 4. 打开百度首页
    browser.get("https://www.baidu.com")
    # 加 2 秒延迟,等待页面加载完成(动态页面需要等 JS 渲染)
    time.sleep(2)
    print("成功打开百度首页")

    # 5. 定位搜索框并输入关键词(DrissionPage 定位元素超简单,支持 ID、XPATH、CSS 等)
    # 百度搜索框的 ID 是 "kw",用 "id=kw" 直接定位
    search_box = browser.ele("id=kw")
    # 输入关键词 "DrissionPage"
    search_box.input("DrissionPage")
    print("成功在搜索框输入关键词")

    # 6. 定位搜索按钮并点击(百度搜索按钮的 ID 是 "su")
    search_btn = browser.ele("id=su")
    search_btn.click()
    # 加 3 秒延迟,等待搜索结果加载完成
    time.sleep(3)
    print("成功点击搜索按钮,等待结果加载")

    # 7. 提取搜索结果(百度搜索结果的标题和链接在 class 为 "result-op c-container xpath-log new-pmd" 的div中)
    # 用 "class=result-op" 定位所有搜索结果(elems 返回列表,包含所有匹配的元素)
    result_list = browser.elems("class=result-op")
    # 创建一个列表存储结果
    output_data = []
    # 遍历结果列表,提取标题和链接
    for i, result in enumerate(result_list, start=1):
        # 提取标题(标题在 result 下的 h3 标签中,用 "tag=h3" 定位)
        title = result.ele("tag=h3").text if result.ele("tag=h3") else "无标题"
        # 提取链接(链接在 result 下的 a 标签中,用 "tag=a" 定位,获取 href 属性)
        link = result.ele("tag=a").get_attr("href") if result.ele("tag=a") else "无链接"
        # 将结果添加到列表中,格式为 "第 N 条:标题 - 链接"
        output_data.append(f"第 {i} 条:{title} - {link}")
        # 在命令行打印结果(方便实时查看)
        print(f"第 {i} 条:{title} - {link}")

    # 8. 将结果保存到本地文件(保存到 /home/ubuntu 目录下,文件名为 baidu_result.txt)
    with open("/home/ubuntu/baidu_result.txt", "w", encoding="utf-8") as f:
        # 将列表中的内容用换行符连接,写入文件
        f.write("
".join(output_data))
    print(f"
成功将 {len(output_data)} 条搜索结果保存到 baidu_result.txt")

except Exception as e:
    # 捕获所有异常,打印错误信息(方便排查问题)
    print(f"脚本运行出错:{str(e)}")

finally:
    # 无论脚本是否报错,都关闭浏览器(避免占用服务器资源)
    browser.quit()
    print("浏览器已关闭")

4.3 步骤 3:运行脚本(无界面模式)

回到 FinalShell 的命令行窗口,执行以下命令运行脚本:

python3 /home/ubuntu/baidu_search.py

运行过程中,命令行会实时打印日志(如“成功打开百度首页”“成功输入关键词”),等待 10-20 秒(取决于网络速度),最后显示“浏览器已关闭”,说明脚本运行完成。

4.4 步骤 4:查看运行结果

  1. 查看命令行输出:如果没有报错,会显示“成功将 N 条搜索结果保存到 baidu_result.txt”,并列出每条结果的标题和链接;
  2. 查看保存的文件:在 FinalShell 右侧的文件管理器中,进入 /home/ubuntu 目录,会看到新增的 baidu_result.txt 文件,双击打开即可查看所有搜索结果(中文不会乱码,因为脚本中指定了 encoding="utf-8")。

4.5 常见报错与解决方法(新手必看)

如果运行脚本时出现报错,不用慌,按以下方法排查:

报错信息示例原因分析解决方法
chromedriver executable needs to be in PATH未指定 Chrome 可执行文件路径脚本中 Chromium() 必须加 executable_path="/usr/bin/chromium-browser"
Failed to create sandbox未关闭沙箱模式chrome_options 中添加 "no_sandbox": True
DevToolsActivePort file doesn't exist共享内存不足或未禁用 GPU"disable_dev_shm_usage": True"disable_gpu": True
元素定位不到(如 ele not found)页面加载未完成,或元素选择器错误1. 增加 time.sleep() 延迟(如从 2 秒改为 5 秒);2. 检查元素选择器是否正确(用 Chrome 开发者工具复制)
中文乱码保存文件时未指定编码打开文件时加 encoding="utf-8"(如 open("xxx.txt", "w", encoding="utf-8")

五、进阶操作:让脚本“后台运行+定时执行”

新手学会“手动运行脚本”后,下一步是实现“脚本后台运行(关闭 SSH 也不停止)”和“定时执行(比如每天 8 点自动运行)”——这才是服务器部署的核心价值。

5.1 后台运行脚本(nohup 命令)

默认情况下,用 python3 脚本.py 运行脚本时,关闭 FinalShell(SSH 连接断开)后,脚本会停止。用 nohup 命令可以让脚本在后台持续运行,步骤如下:

  1. 执行以下命令,后台运行 baidu_search.py,并将日志输出到 script_log.txt

    nohup python3 /home/ubuntu/baidu_search.py > /home/ubuntu/script_log.txt 2>&1 &
    

    命令解释:

    • nohup:忽略挂断信号(关闭 SSH 后脚本继续运行);
    • > /home/ubuntu/script_log.txt:将脚本的打印信息(print 内容)保存到 script_log.txt
    • 2>&1:将错误信息也保存到 script_log.txt(方便排查报错);
    • 最后一个 &:让脚本在后台运行(命令行可以继续输入其他命令)。
  2. 查看脚本是否在运行:

    ps aux | grep python3  # 查看所有 Python3 进程
    

    执行后会显示所有 Python3 进程,如果能看到 /home/ubuntu/baidu_search.py,说明脚本正在后台运行。

  3. 查看运行日志(实时查看脚本输出):

    tail -f /home/ubuntu/script_log.txt
    

    解释:tail -f 会实时显示日志文件的最新内容,按 Ctrl+C 可以退出查看。

  4. 停止后台运行的脚本:
    如果需要手动停止脚本,先查进程 ID(PID):

    ps aux | grep python3  # 找到脚本对应的 PID(第二列数字)
    kill -9 PID  # 替换 PID 为实际数字,如 kill -9 12345
    

    例如:如果进程信息是 ubuntu 12345 0.0 0.0 12345 6789 pts/0 S+ 10:00 0:00 python3 /home/ubuntu/baidu_search.py,则 PID 是 12345,执行 kill -9 12345 即可停止脚本。

5.2 定时执行脚本(crontab 命令)

如果需要脚本“每天固定时间运行”(如每天 8 点爬取数据),用 Linux 自带的 crontab 定时任务即可,步骤如下:

  1. 编辑 crontab 定时任务列表:

    crontab -e
    

    首次执行会提示选择编辑器,新手推荐选 nano(输入 1 然后按回车)——nano 编辑器操作简单:按 Ctrl+O 保存,按 Ctrl+X 退出。

  2. 添加定时任务:
    在 nano 编辑器中,按 End 键跳到最后一行,添加以下内容:

    0 8 * * * /usr/bin/python3 /home/ubuntu/baidu_search.py >> /home/ubuntu/daily_log.txt 2>&1
    

    命令解释:

    • 0 8 * * *:定时规则,代表“每天 8 点 0 分执行”(格式:分 时 日 月 周,* 表示“任意”);
      • 举例:30 9 * * 1-5 表示“每周一到周五 9 点 30 分执行”;0 */2 * * * 表示“每 2 小时执行一次”;
    • /usr/bin/python3:Python3 的绝对路径(用 which python3 命令可查看,一般是这个路径);
    • /home/ubuntu/baidu_search.py:脚本的绝对路径;
    • >> /home/ubuntu/daily_log.txt:将每次运行的日志追加到 daily_log.txt>> 是追加,> 是覆盖);
    • 2>&1:错误信息也追加到日志文件。
  3. 保存并退出 nano 编辑器:

    • Ctrl+O(字母 O,不是 0),然后按回车(确认保存路径);
    • Ctrl+X 退出编辑器。
  4. 查看 crontab 任务是否生效:

    crontab -l  # 列出当前所有定时任务
    

    如果能看到刚才添加的任务,说明配置成功。

  5. 检查定时任务日志(排查未执行问题):
    如果到了时间脚本没执行,查看 crontab 日志:

    sudo grep CRON /var/log/syslog
    

    日志中会显示“任务是否执行”“执行结果”,比如 CRON[12345]: (ubuntu) CMD (/usr/bin/python3 /home/ubuntu/baidu_search.py >> ...) 表示任务已执行;如果有报错,会显示错误原因(如路径错误、权限不足)。

    常见定时任务失败原因:

    • 路径错误:Python 路径或脚本路径不是绝对路径(必须用 /usr/bin/python3,不能用 python3);
    • 权限不足:脚本或日志文件没有写入权限,执行 chmod 755 /home/ubuntu/baidu_search.py 给脚本加权限;
    • 环境变量问题:crontab 执行时环境变量与手动执行不同,脚本中所有路径必须用绝对路径(如保存文件不能用 baidu_result.txt,必须用 /home/ubuntu/baidu_result.txt)。

六、实战案例:用 DrissionPage 爬取动态网页数据(无界面)

前面的案例是“静态搜索”,现在我们来实战一个“动态网页爬取”——爬取“豆瓣电影 Top250”(https://movie.douban.com/top250),这个网页是动态加载的(需要点击“下一页”或滚动加载),传统 Requests 无法爬取,DrissionPage 可以轻松搞定。

6.1 案例脚本:爬取豆瓣电影 Top250 数据

创建 douban_top250.py 脚本,代码如下(附带详细注释):

from drissionpage import Chromium
import time
import csv  # 用于将数据保存为 CSV 文件(方便用 Excel 打开)

# 配置无头模式参数(和之前一致)
chrome_options = {
    "headless": True,
    "no_sandbox": True,
    "disable_dev_shm_usage": True,
    "disable_gpu": True,
    "window_size": (1920, 1080)
}

# 创建浏览器对象
browser = Chromium(
    executable_path="/usr/bin/chromium-browser",
    options=chrome_options
)

# 存储所有电影数据的列表
movies_data = []

try:
    # 豆瓣 Top250 第一页 URL
    base_url = "https://movie.douban.com/top250?start={}&filter="
    # 爬取 10 页(共 250 部电影),start 参数从 0、25、50...225
    for page in range(10):
        start = page * 25
        url = base_url.format(start)
        print(f"开始爬取第 {page+1} 页:{url}")
        
        # 打开当前页
        browser.get(url)
        time.sleep(3)  # 等待页面加载
        
        # 定位当前页所有电影项(每个电影项的 class 是 "item")
        movie_items = browser.elems("class=item")
        
        # 遍历每个电影项,提取数据
        for item in movie_items:
            # 1. 排名(在 class 为 "pic" 的 div 下的 em 标签中)
            rank = item.ele("class=pic").ele("tag=em").text
            # 2. 电影名称(在 class 为 "hd" 的 div 下的 a 标签中,取第一个 span 的文本)
            title = item.ele("class=hd").ele("tag=a").elems("tag=span")[0].text
            # 3. 导演和演员(在 class 为 "bd" 的 div 下的 p 标签中,取第一行文本)
            info = item.ele("class=bd").ele("tag=p").text.split("
")[0].strip()
            # 4. 评分(在 class 为 "star" 的 div 下的 class 为 "rating_num" 的 span 中)
            score = item.ele("class=star").ele("class=rating_num").text
            # 5. 评价人数(在 class 为 "star" 的 div 下的最后一个 span 中,提取数字)
            comment_num = item.ele("class=star").elems("tag=span")[-1].text.replace("人评价", "")
            # 6. 简介(在 class 为 "inq" 的 span 中,没有则显示 "无简介")
            quote = item.ele("class=inq").text if item.ele("class=inq") else "无简介"
            
            # 将当前电影数据添加到列表
            movies_data.append([rank, title, info, score, comment_num, quote])
            print(f"已爬取:第 {rank} 名 - {title}(评分:{score})")
        
        print(f"第 {page+1} 页爬取完成,累计爬取 {len(movies_data)} 部电影
")
    
    # 将数据保存为 CSV 文件(Excel 可直接打开)
    csv_path = "/home/ubuntu/douban_top250.csv"
    with open(csv_path, "w", encoding="utf-8-sig", newline="") as f:
        # 创建 CSV 写入器
        writer = csv.writer(f)
        # 写入表头(第一行)
        writer.writerow(["排名", "电影名称", "导演/演员", "评分", "评价人数", "简介"])
        # 写入所有电影数据
        writer.writerows(movies_data)
    
    print(f"豆瓣电影 Top250 爬取完成!共 {len(movies_data)} 部电影,数据已保存到 {csv_path}")

except Exception as e:
    print(f"爬取过程出错:{str(e)}")

finally:
    browser.quit()
    print("浏览器已关闭")

6.2 运行脚本与查看结果

  1. 后台运行脚本并保存日志:
    nohup python3 /home/ubuntu/douban_top250.py > /home/ubuntu/douban_log.txt 2>&1 &
    
  2. 实时查看爬取进度:
    tail -f /home/ubuntu/douban_log.txt
    
    会看到“开始爬取第 1 页”“已爬取:第 1 名 - 肖申克的救赎(评分:9.7)”等日志,爬取 10 页约需 1-2 分钟。
  3. 查看结果文件:
    爬取完成后,在 /home/ubuntu 目录下会生成 douban_top250.csv 文件,右键点击该文件→“下载”,下载到本地后用 Excel 打开,即可看到结构化的电影数据(排名、名称、评分等一目了然)。

七、常见问题汇总(新手避坑指南)

在无界面 Linux 上运行 DrissionPage 时,新手容易遇到各种小问题,这里汇总了 10 个高频问题及解决方案,帮你快速排查:

7.1 环境类问题

  1. 问题:执行 chromium-browser --version 提示“command not found”
    原因:Chrome 未安装或安装失败
    解决:重新执行 sudo apt install chromium-browser chromium-chromedriver -y,并检查网络是否正常。

  2. 问题:安装 DrissionPage 时提示“pip3: command not found”
    原因:pip3 未安装
    解决:执行 sudo apt install python3-pip -y 安装 pip3。

  3. 问题:脚本中指定 executable_path="/usr/bin/chromium-browser" 但报错“文件不存在”
    原因:Chrome 安装路径不对(不同 Linux 发行版路径可能不同)
    解决:执行 which chromium-browser 查看实际路径,将脚本中的路径替换为查询结果。

7.2 脚本运行类问题

  1. 问题:运行脚本时提示“元素定位不到(ele not found)”
    原因:1. 页面加载未完成;2. 元素选择器错误;3. 网页有反爬机制(如验证码、登录)
    解决

    • 增加 time.sleep() 延迟(如从 2 秒改为 5 秒);
    • 用 Chrome 开发者工具重新复制元素选择器(步骤:本地 Chrome 打开网页→F12 打开开发者工具→选中元素→右键→Copy→Copy selector);
    • 如果网页需要登录,用 DrissionPage 的 set_cookies() 方法导入登录后的 Cookie(后续章节会讲)。
  2. 问题:脚本运行时提示“内存不足(Out of memory)”
    原因:服务器内存太小(如 1G 内存),Chrome 占用内存较高
    解决

    • 升级服务器内存(至少 2G);
    • chrome_options 中添加 "disable-extensions": True(禁用浏览器扩展,减少内存占用);
    • Session 模式替代 Chromium 模式(如果网页不需要动态渲染,Session 模式内存占用仅为 Chromium 的 1/10,后续章节会讲)。
  3. 问题:中文保存到文件后乱码
    原因:未指定编码格式,Linux 默认编码是 ASCII,不支持中文
    解决:打开文件时必须加 encoding="utf-8"(保存 CSV 文件用 encoding="utf-8-sig",Excel 打开不会乱码)。

7.3 后台与定时任务类问题

  1. 问题:用 nohup 后台运行脚本,关闭 SSH 后脚本停止
    原因:nohup 命令格式错误,或脚本中用了相对路径
    解决

    • 重新执行 nohup 命令(确保格式正确:nohup python3 绝对路径 > 日志绝对路径 2>&1 &);
    • 脚本中所有文件路径必须用绝对路径(如 /home/ubuntu/result.txt,不能用 result.txt)。
  2. 问题:crontab 定时任务到时间不执行
    原因:1. 路径不是绝对路径;2. 权限不足;3. 环境变量问题
    解决

    • 检查 Python 路径和脚本路径是否为绝对路径(用 which python3 确认 Python 路径);
    • 给脚本加权限:chmod 755 /home/ubuntu/脚本.py
    • 在定时任务中指定环境变量:在 crontab -e 中添加 PATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin(放在定时任务行前面)。
  3. 问题:crontab 执行脚本报错“ModuleNotFoundError: No module named ‘drissionpage’”
    原因:crontab 执行时用的 pip 环境与手动执行不同,DrissionPage 安装在用户目录下,crontab 无法找到
    解决

    • 用绝对路径的 pip3 安装 DrissionPage:/usr/bin/pip3 install drissionpage
    • 定时任务中用绝对路径的 Python3 执行脚本(如 /usr/bin/python3 /home/ubuntu/脚本.py)。
  4. 问题:后台运行脚本时,日志文件很大,占满服务器空间
    原因:脚本长期运行,日志不断追加
    解决

    • 定期清理日志(执行 rm /home/ubuntu/script_log.txt 删除旧日志);
    • 在脚本中添加“日志轮转”逻辑(如只保留最近 7 天的日志);
    • logrotate 工具自动管理日志(适合长期运行的脚本)。

八、总结与后续学习方向

通过本文的步骤,你已经掌握了“在无界面 Linux 服务器上运行 DrissionPage”的核心流程:从服务器购买、环境搭建,到脚本编写、后台运行、定时执行,甚至实战了动态网页爬取。现在你可以将这个流程应用到自己的需求中,比如:

  • 定时爬取行业数据,生成 Excel 报表;
  • 监控目标网页更新,有新内容时发送邮件提醒;
  • 自动化填写表单、提交数据(如每日打卡、报表上报)。

后续学习方向

  1. DrissionPage 高级功能:学习 Session 模式(高效爬取静态网页,内存占用低)、Cookie 同步(登录后保持会话)、iframe 切换(处理嵌套页面)、验证码识别(配合 ddddocr 库)等;
  2. Linux 进阶操作:学习 shell 脚本(批量管理多个 DrissionPage 脚本)、logrotate(日志轮转)、systemd(设置脚本开机自启)等;
  3. 反爬与合规:爬取数据时遵守网站 robots.txt 规则,避免频繁请求(添加随机延迟、使用代理 IP),不爬取敏感数据;
  4. 结果可视化:将爬取的数据用 matplotlibpyecharts 生成图表,更直观地展示分析结果。

推荐资源

  • DrissionPage 官方文档:https://gitee.com/g1879/DrissionPage(最权威的教程,包含所有功能示例);
  • Ubuntu 官方文档:https://ubuntu.com/server/docs(学习 Linux 基础操作);
  • FinalShell 教程:https://www.hostbuf.com/t/988.html(掌握文件传输、进程管理等技巧)。

只要跟着本文的步骤实践,再结合官方文档探索高级功能,你很快就能从“新手”成长为“能独立部署 Linux 自动化脚本”的高手。遇到问题时不要慌,先查看日志找报错原因,再对照本文的“常见问题汇总”排查,大部分问题都能快速解决!

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

搜索文章

Tags

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