如何通过在 WSL 上使用 AMD ROCm 解锁您的 Windows 电脑的全部潜能

今天,amd 发布了一篇博客,详细介绍了如何在 windows subsystem for linux(wsl)上设置 rocm。使用被 rocm 支持的 amd radeon 显卡的用户,可以通过在 wsl 上使用 rocm 来释放其 windows 电脑的全部潜力。

无论您是在本地加载诸如 stable diffusion 这样的大型模型,还是在探索富有创意的 ai 应用,这一设置都能在您的指尖为您带来前所未有的易用性与强大性能。

我们诚挚地希望您能阅读该博客,并向您的读者或观众介绍在 wsl 上使用受支持的 amd radeon 显卡与 amd rocm 的优势。

您可在此阅读博客

点击此处观看相关视频

以下为博客译文:

在 Windows上通过WSL 使用 ROCm 运行 ComfyUI

如果您拥有一块 AMD ROCm 平台支持的 AMD Radeon 显卡,便可借助适用于 Linux 的 Windows 子系统(WSL)在 Windows PC 上充分释放其强大性能。无论是本地加载 Stable Diffusion 等大型模型,还是探索各类创意型 AI 应用,这一方案都能为您带来前所未有的便捷与强劲算力。本文将为您提供一份详尽的分步指南,介绍如何配置基于 WSL 的 ROCm 环境以运行 ComfyUI,包括驱动安装、依赖管理,以及针对 AMD GPU 优化的 PyTorch 集成(见图 1)。

通过网盘分享的文件:How to install ROCm on Windows
链接: https://pan.baidu.com/s/1_M3jmIUsUgzYBW99vR643g?pwd=2e2i 提取码: 2e2i

图 1:上方视频演示了如何在 Windows 上通过 WSL 使用 ROCm 运行 ComfyUI 。

开始前的准备工作

若要在 Windows 系统中充分发挥 AMD Radeon 显卡与 ROCm 软件的优势,您需先具备以下条件:
一块兼容的 AMD Radeon 显卡
AMD Software:Adrenalin Edition™ 25.6.1 或更高版本
已安装 WSL,并部署 Ubuntu 24.04 或 22.04 容器(见步骤1)

步骤 1:安装 WSL 和 Ubuntu

以下步骤将演示如何在 WSL 环境中安装 Ubuntu 24.04 并配置 ROCm。首先,以管理员身份打开 Windows PowerShell 或命令提示符,输入以下命令:
wsl –install -d
Ubuntu-24.04

如何通过在 WSL 上使用 AMD ROCm 解锁您的 Windows 电脑的全部潜能
图 2:上图展示了您在安装 WSL 和 Ubuntu 时将看到的界面

请创建您的用户账户和密码(见上图 2),这些信息将在后续多个步骤中用到。

步骤 2:安装 AMD 统一驱动包软件源及安装脚本

完成 Ubuntu 的安装后,请依次输入以下命令,为 Ubuntu 24.04 安装相应的安装脚本(见下图 3)。
sudo apt update

wget 

https://repo.radeon.com/amdgpu-install/6.4.2.1/ubuntu/noble/amdgpu-install_6.4.60402-1_all.deb

sudo apt install ./amdgpu-install_6.4.60402-1_all.deb

如何通过在 WSL 上使用 AMD ROCm 解锁您的 Windows 电脑的全部潜能
图 3:上图展示了您在安装 AMD 统一驱动程序包软件源和安装脚本时将看到的界面

步骤 3:安装 ROCm 统一构建

运行以下命令以安装开源图形驱动和 ROCm 软件。请注意查看安装过程中的输出信息,如有警告或错误提示,可能意味着驱动安装未成功。该过程可能需要几分钟才能完成。
amdgpu-install -y –usecase=wsl,rocm –no-dkms
运行以下命令验证安装结果,并确认 GPU 设备是否已被识别为代理(agent):
rocminfo
如图 4 所示,该示例展示了 GPU 设备被系统识别为代理(agent)的情况。

如何通过在 WSL 上使用 AMD ROCm 解锁您的 Windows 电脑的全部潜能
图 4:上图为验证安装结果时您将看到的界面

步骤 4:安装 ComfyUI

在成功安装 ROCm 之后,下一步是创建一个 Python 虚拟环境,以将 ComfyUI 的依赖与系统其他环境隔离,避免与用户现有的其他 Python 项目产生冲突。请依次输入以下命令:
python3 -m venv venv –system-site-packages
source venv/bin/activate

在基于 ROCm 进行机器学习开发时,AMD 建议采用 PIP 安装方式来创建 PyTorch 环境。
请执行以下命令以解压并开始配置。
sudo apt install python3-pip -y

请执行以下命令,以更新 pip 及其 wheel 依赖包。

pip3 install –upgrade pip wheel
请执行以下所有命令,以安装适配 ROCm AMD GPU 的 Torch 和 Torchvision(最新下载链接可参考:https://rocm.docs.amd.com/projects/radeon/en/latest/docs/install/wsl/install-pytorch.html)。
wget

智谱清言 - 免费全能的AI助手 智谱清言 – 免费全能的AI助手

智谱清言 – 免费全能的AI助手

智谱清言 - 免费全能的AI助手 2 查看详情 智谱清言 - 免费全能的AI助手

git76481f7c-cp312-cp312-linux_x86_64.whl>

wget 

wget 

wget 

pip3 uninstall torch torchvision pytorch-triton-rocm

pip3 install
torch-2.6.0+rocm6.4.2.git76481f7c-cp312-cp312-linux_x86_64.whl
torchvision-0.21.0+rocm6.4.2.git4040d51f-cp312-cp312-linux_x86_64.whl
torchaudio-2.6.0+rocm6.4.2.gitd8831425-cp312-cp312-linux_x86_64.whl
pytorch_triton_rocm-3.2.0+rocm6.4.2.git7e948ebf-cp312-cp312-linux_x86_64.whl
更新至兼容的 WSL 运行时库。
location=$(pip show torch | grep Location | awk -F “: ” ‘{print
$2}’)
cd ${location}/torch/lib/
rm libhsa-runtime64.so
完成此步骤后,请验证 PyTorch 是否安装成功。
在确认 PyTorch 安装成功后,请使用以下命令克隆 ComfyUI 仓库:
git clone https://github.com/comfyanonymous/ComfyUI.git
为避免与 ROCm 版本的 PyTorch 软件包发生冲突,请在 requirements.txt 文件中将以下条目注释掉:torch、torchaudio 和 torchvision(见下图 5)。
输入以下命令,注释相关软件包后保存:
cd ComfyUI
sudo nano requirements.txt

如何通过在 WSL 上使用 AMD ROCm 解锁您的 Windows 电脑的全部潜能
图 5:上图为已对 torch、torchaudio 和 torchvision 进行注释处理后的界面。此步骤对于避免冲突至关重要

安装 ComfyUI 所需依赖:
***pip install -r requirements.txt***
将您计划在本地使用的模型(如 Stable Diffusion 3)放入以下目录:
***cd ComfyUI/models/checkpoints***
例如,您可以将sd3_medium_incl_clips.safetensors 模型放入该目录。请注意,下载 SD3 模型前需先登录 Hugging Face 账户。

步骤 5:启动 ComfyUI

要启动 ComfyUI,请先返回仓库的主目录,并运行 main.py。进入主目录后,输入以下命令:
***python3 main.py***
运行完成后,系统会生成一个可在浏览器中打开的链接(见下图 6 和图 7),您即可在本地环境中使用 LLM,全面释放您的创造潜能。

如何通过在 WSL 上使用 AMD ROCm 解锁您的 Windows 电脑的全部潜能
图 6:上图所示为 ComfyUI 的访问链接,点击即可在浏览器中打开

如何通过在 WSL 上使用 AMD ROCm 解锁您的 Windows 电脑的全部潜能
图 7:上图演示了在 Windows 浏览器中使用 ComfyUI 的一种应用场景

初始设置完成后再次启动 ComfyUI

后续再次使用 ComfyUI 时,只需执行以下步骤即可重新启动并运行:
1.打开 WSL
2.输入
source venv/bin/activate
3.进入 ComfyUI 目录
cd ComfyUI
4.输入
python3 main.py
5.复制地址并在浏览器中打开

总结

按照本文提供的步骤操作,您即可在 Windows 系统中通过适用于 Linux 的 Windows 子系统(WSL)使用 ROCm 成功运行 ComfyUI,充分释放 AMD Radeon 显卡的强大算力。此方案可将您的 Windows PC 打造成高性能计算枢纽,不仅能够流畅运行 Stable Diffusion 等大型模型,还能以前所未有的便捷性支持各类创意型 AI 应用。欢迎持续关注我们的技术博客系列,或关注AMD官方微信@ AMD 开发者中心,探索如何让您的系统发挥出全部潜能。

参考资源

如需了解更多技术细节,请参阅以下资源:

安装适用于 WSL 的 ROCm Radeon 软件

在 WSL 中为 Radeon GPU 安装 PyTorch

安装 ComfyUI 及 MIGraphX 扩展

免责声明

第三方内容的使用许可由相应内容所有者直接授予用户,AMD 不对此类内容提供授权。所有链接的第三方内容均以“按原样”提供,不包含任何形式的保证。用户应自主决定是否使用第三方内容,AMD 对任何第三方内容不承担法律责任。用户需独立承担因使用第三方内容而可能产生的全部风险及相关责任。

以上就是如何通过在 WSL 上使用 AMD ROCm 解锁您的 Windows 电脑的全部潜能的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/376469.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月6日 09:49:37
下一篇 2025年11月6日 09:50:23

相关推荐

  • 从Google Spreadsheet URL获取文件名称的Python教程

    本教程详细介绍了如何通过编程方式从Google Spreadsheet的导出URL中提取其文件名称。主要方法是利用HTTP Content-Disposition响应头,通过requests库发送GET请求并解析头部信息。文章还提供了使用urllib.parse.unquote处理编码字符的示例,并…

    好文分享 2025年12月14日
    000
  • 解决Python csv.writer 生成CSV文件中的空白行问题

    本文探讨了Python csv.writer 在生成CSV文件时出现额外空白行的常见问题及其解决方案。默认情况下,csv.writer 使用 rn 作为行终止符,这在某些操作系统或文本编辑器中可能被误解为两个换行符,从而导致每行之间出现空白。通过在 csv.writer 中明确指定 lineterm…

    2025年12月14日
    000
  • 使用 GitHub Actions 运行 Jupyter Notebook 脚本

    本文旨在指导您如何使用 GitHub Actions 运行 Jupyter Notebook 脚本,并安全地管理脚本中的凭据。我们将探讨如何配置 GitHub Actions 的定时任务,如何从 GitHub 仓库运行 Jupyter Notebook 脚本,以及如何利用 GitHub Secret…

    2025年12月14日
    000
  • python如何将字典写入json文件_python字典数据保存为JSON文件教程

    使用json模块的dump()方法可将字典写入JSON文件,配合ensure_ascii=False和encoding=’utf-8’解决中文编码问题;datetime等非序列化对象需通过default函数或自定义JSONEncoder转换;处理大文件时可用ijson库实现流…

    2025年12月14日
    000
  • Python 实战:招聘网站数据分析案例

    Python通过爬虫、清洗与分析招聘数据,助力求职者定位薪资、优化技能并洞察行业趋势,同时帮助企业精准制定招聘策略与薪酬体系。 Python在招聘网站数据分析中,扮演着一个至关重要的角色,它能帮助我们从看似杂乱无章的海量招聘信息中,提炼出有价值的洞察,无论是了解行业趋势、薪资水平,还是分析岗位需求,…

    2025年12月14日
    000
  • python如何将list转换为set_python列表list与集合set的相互转换

    列表转集合可去重并提升查找效率,但会丢失顺序;集合适合唯一性、成员检测和集合运算,列表则适用于需顺序、索引或重复元素的场景。 Python中将列表(list)转换为集合(set)是一个非常常见的操作,主要目的是为了去重和利用集合的高效查找特性。反过来,当你需要对去重后的数据进行索引访问或保持特定顺序…

    2025年12月14日
    000
  • 基于Bearer Token的REST API认证教程

    本文档旨在指导开发者如何在基于AWS API Gateway和Lambda的REST API中实现基于Bearer Token的身份验证。我们将介绍三种不同的实现方式:使用代理集成、自定义集成以及Lambda Authorizer。通过详细的步骤和代码示例,帮助你选择最适合你的应用场景的方案,并确保…

    2025年12月14日
    000
  • 将OpenAI API驱动的ChatGPT集成到HTML网页的完整教程

    本教程详细阐述了如何将基于Python的OpenAI ChatGPT后端与前端HTML网页进行集成。通过构建一个轻量级的Python Web API(如使用Flask框架),前端JavaScript能够向后端发送用户输入,后端处理后调用OpenAI API获取响应,并将结果以JSON格式返回给前端,…

    2025年12月14日
    000
  • 将OpenAI ChatGPT集成到HTML网页的完整指南

    本文旨在指导开发者如何将基于OpenAI API的ChatGPT模型集成到HTML网页中。通过结合Python后端和JavaScript前端,实现用户在网页上与ChatGPT进行实时对话的功能。教程将详细介绍如何搭建后端API、处理前后端通信,以及在HTML页面上展示聊天内容。 1. 架构概述 将C…

    2025年12月14日
    000
  • python lambda函数怎么用_python匿名函数lambda使用教程

    lambda函数是一种简化版的匿名函数,用于实现简单单行功能,语法为lambda arguments: expression,常用于map()、filter()、sorted()等函数中。示例包括定义加法函数add = lambda x, y: x + y,输出8;使用map()将列表元素平方,得到…

    2025年12月14日
    000
  • 获取 GitHub 仓库最后更新时间:使用 PyGithub 的正确方法

    本文旨在帮助开发者使用 PyGithub 库获取 GitHub 仓库的最后更新时间。我们将探讨 repo._updated_at.value 和 repo.pushed_at 的区别,并提供正确的代码示例,以便准确获取仓库的最后一次推送时间,从而实现项目数据的有效更新。 在使用 PyGithub 库…

    2025年12月14日
    000
  • Python怎么将字典写入JSON文件_Python字典转JSON文件存储方法

    Python字典转JSON文件广泛用于数据持久化、跨语言交换和配置管理,通过json.dump()直接写入文件或json.dumps()生成字符串再存储,结合ensure_ascii=False、indent格式化及default参数处理中文、美观输出与非标准类型,兼顾效率与可读性。 Python要…

    2025年12月14日
    000
  • python中怎么用Flask创建一个简单的网页?

    答案:用Flask搭建网页只需安装Flask、创建app.py定义路由和视图函数,运行后即可在浏览器访问;通过@app.route可设置不同URL路径和请求方法,支持动态变量和POST/GET处理;使用Jinja2模板引擎将HTML分离,通过render_template传递数据,提升页面复杂度和可…

    2025年12月14日 好文分享
    000
  • PEFT LoRA适配器与基础模型合并的专业指南

    本教程详细阐述如何将PEFT LoRA适配器与基础模型正确合并,生成一个完整的、可部署的新模型。文章纠正了常见的错误方法,重点介绍了peft库中merge_and_unload功能的正确使用,并强调了单独处理分词器以及解决潜在PEFT版本兼容性问题的重要性,确保模型合并过程的顺利进行。 1. 理解P…

    2025年12月14日
    000
  • Python解释器开发:解析器中无限循环的诊断与修复

    本文深入探讨了Python解释器开发中常见的解析器(parser)无限循环问题。通过分析一个具体的代码案例,揭示了循环变量i未在所有执行路径中正确递增是导致KeyboardInterrupt错误的原因。文章提供了详细的修复方案,并进一步优化了parse函数,使其能够健壮地处理各类令牌,包括打印语句和…

    2025年12月14日
    000
  • PEFT LoRA适配器与基础模型的高效合并策略

    本教程详细介绍了如何将PEFT LoRA适配器与基础模型高效合并,生成一个完全独立的模型。文章指出直接使用transformers.AutoModel加载适配器并手动合并权重是错误的,并提供了使用peft库中merge_and_unload方法的正确流程。此外,教程还强调了处理分词器的重要性,并讨论…

    2025年12月14日
    000
  • Pandas大数据框分批处理与外部API调用优化实践

    本教程旨在解决Pandas处理大型DataFrame时,因内存限制或外部API请求频率过高导致的程序崩溃及性能瓶颈问题。核心策略是通过将大数据集逻辑地划分为小批次进行独立处理,并演示如何高效地执行数据合并、应用自定义函数以及管理外部API调用,最终将分批处理结果统一写入目标文件,从而提升数据处理的稳…

    2025年12月14日
    000
  • PEFT LoRA适配器与基础模型高效合并指南

    本文详细介绍了如何使用Hugging Face的peft库将PEFT LoRA适配器模型与基础模型进行高效且正确地合并,生成一个完全新的、独立的预训练模型。教程涵盖了从加载适配器、执行合并到保存最终模型及处理分词器的完整流程,并提供了避免常见错误和解决版本兼容性问题的专业指导。 PEFT LoRA适…

    2025年12月14日
    000
  • Python解释器开发中的解析器死循环问题及解决方案

    本文深入探讨了Python语言解释器开发中常见的解析器死循环问题,该问题通常源于解析逻辑中索引未正确递增。文章通过分析一个具体的Python解释器代码案例,详细阐述了词法分析器和解析器的交互,并揭示了当解析器未能处理所有令牌类型时,如何导致程序陷入无限循环。最终,提供了修正后的解析器代码,并强调了在…

    2025年12月14日
    000
  • Python Web Scraping技巧:处理同名类标签并精确筛选数据

    本文详细介绍了如何利用Python的requests和BeautifulSoup库进行网页数据抓取,特别是当网页中存在多个具有相同HTML类名的元素时,如何精确筛选出所需信息。文章着重演示了如何通过高级CSS选择器,例如:-soup-contains(),来排除不符合条件的数据(如“在线视频咨询”)…

    2025年12月14日
    000

发表回复

登录后才能评论
关注微信