热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

多版本CUDA共存与即时切换方案

本文探讨了在同一台机器上安装并管理多个CUDA版本的方法,以适应不同软件或项目的需求。特别是在使用旧版PyTorch等依赖特定CUDA版本的软件时,该方法尤为实用。

多版本CUDA共存与即时切换方案

背景介绍:在进行某些实验时,可能遇到需要使用较旧版本的PyTorch或其他软件的情况,这些软件可能只支持特定版本的CUDA。因此,探索如何在同一台机器上安装并即时切换多个CUDA版本变得尤为重要。本文将记录这一过程,并分享一些注意事项。

提示:若可以通过修改代码来达到兼容目的,则尽量避免更改环境设置,因为环境配置往往较为复杂,且可能需要管理员权限,存在一定的安全风险。

准备工作及资源获取

  • 检查操作系统信息:使用命令cat /proc/version
  • 确定所需安装的CUDA版本。
  • 确定需配合使用的PyTorch版本。
  • 访问CUDA官方网站获取下载链接。
  • PyTorch的安装可以通过Anaconda环境管理器使用pip或conda命令完成,也可提前从官网下载相应版本。

新CUDA版本的安装

前提条件:假设您的系统中已安装了一个CUDA版本。如果尚未安装CUDA,请参考其他教程先行安装。本文主要针对已有CUDA环境下新增版本的情况。

  • 重要提示:安装新CUDA版本不会覆盖现有版本。为了实现全局范围内的版本切换,通常需要修改/usr/local目录下的CUDA符号链接。然而,考虑到服务器可能有多个用户同时使用,建议通过个人用户配置文件(如.bashrc)或在shell会话中临时指定CUDA版本来实现版本切换,以减少对其他用户的影响。

安装步骤

  • 在下载好的CUDA安装包所在目录,以root权限运行安装脚本(如需增加执行权限,可使用chmod +x cudaxxx.run)。
  • 阅读并接受许可协议。
  • 选择安装组件时,仅勾选“ToolKit”和“Documentation”,忽略驱动程序安装(已有CUDA版本的情况下)。
  • 在安装选项中,取消创建符号链接的选项,以免影响全局CUDA版本设置。同时,可根据需要调整安装路径。
  • 完成上述配置后,继续安装过程直至结束。
  • 安装完成后,通过nvcc -V检查当前CUDA版本是否仍为旧版本,确保未被新版本覆盖。

即时切换CUDA版本

当前,系统中应已存在两个CUDA版本,但默认使用的仍是最初安装的那个版本。接下来,我们将介绍如何实现即时版本切换,同时不影响其他用户。

  • 基本原理:通过临时修改当前用户的环境变量,使终端指向新的CUDA位置,从而实现版本切换。此操作仅限于当前终端会话,不会影响其他用户或终端。

切换步骤

  • 使用echo $PATHprintenv | grep cuda查看当前CUDA相关环境变量。
  • 通过export命令动态修改环境变量,例如:export CUDA_HOME=/usr/local/cuda-10.2; export PATH=$CUDA_HOME/bin:$PATH; export LD_LIBRARY_PATH=$CUDA_HOME/lib64:$LD_LIBRARY_PATH
  • 验证CUDA版本是否已成功切换至目标版本。
  • 为简化操作,可将上述命令封装成shell脚本,并通过source script.sh方式执行,确保环境变量在当前shell会话中生效。

参考资料

更多详细信息请参阅:CSDN博客1CSDN博客2


推荐阅读
  • 微软Exchange服务器遭遇2022年版“千年虫”漏洞
    微软Exchange服务器在新年伊始遭遇了一个类似于‘千年虫’的日期处理漏洞,导致邮件传输受阻。该问题主要影响配置了FIP-FS恶意软件引擎的Exchange 2016和2019版本。 ... [详细]
  • 360SRC安全应急响应:从漏洞提交到修复的全过程
    本文详细介绍了360SRC平台处理一起关键安全事件的过程,涵盖从漏洞提交、验证、排查到最终修复的各个环节。通过这一案例,展示了360在安全应急响应方面的专业能力和严谨态度。 ... [详细]
  • 本文介绍如何在现有网络中部署基于Linux系统的透明防火墙(网桥模式),以实现灵活的时间段控制、流量限制等功能。通过详细的步骤和配置说明,确保内部网络的安全性和稳定性。 ... [详细]
  • 在Python开发过程中,随着项目数量的增加,不同项目依赖于不同版本的库,容易引发依赖冲突。为了避免这些问题,并保持开发环境的整洁,可以使用Virtualenv和Virtualenvwrapper来创建和管理多个隔离的Python虚拟环境。 ... [详细]
  • UNP 第9章:主机名与地址转换
    本章探讨了用于在主机名和数值地址之间进行转换的函数,如gethostbyname和gethostbyaddr。此外,还介绍了getservbyname和getservbyport函数,用于在服务器名和端口号之间进行转换。 ... [详细]
  • XNA 3.0 游戏编程:从 XML 文件加载数据
    本文介绍如何在 XNA 3.0 游戏项目中从 XML 文件加载数据。我们将探讨如何将 XML 数据序列化为二进制文件,并通过内容管道加载到游戏中。此外,还会涉及自定义类型读取器和写入器的实现。 ... [详细]
  • 本文深入探讨了Linux系统中网卡绑定(bonding)的七种工作模式。网卡绑定技术通过将多个物理网卡组合成一个逻辑网卡,实现网络冗余、带宽聚合和负载均衡,在生产环境中广泛应用。文章详细介绍了每种模式的特点、适用场景及配置方法。 ... [详细]
  • 掌握远程执行Linux脚本和命令的技巧
    本文将详细介绍如何利用Python的Paramiko库实现远程执行Linux脚本和命令,帮助读者快速掌握这一实用技能。通过具体的示例和详尽的解释,让初学者也能轻松上手。 ... [详细]
  • 使用Python在SAE上开发新浪微博应用的初步探索
    最近重新审视了新浪云平台(SAE)提供的服务,发现其已支持Python开发。本文将详细介绍如何利用Django框架构建一个简单的新浪微博应用,并分享开发过程中的关键步骤。 ... [详细]
  • Navicat Premium 15 安装指南及数据库连接配置
    本文详细介绍 Navicat Premium 15 的安装步骤及其对多种数据库(如 MySQL 和 Oracle)的支持,帮助用户顺利完成软件的安装与激活。 ... [详细]
  • Linux 系统启动故障排除指南:MBR 和 GRUB 问题
    本文详细介绍了 Linux 系统启动过程中常见的 MBR 扇区和 GRUB 引导程序故障及其解决方案,涵盖从备份、模拟故障到恢复的具体步骤。 ... [详细]
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • 本文详细介绍了如何在Linux系统上安装和配置Smokeping,以实现对网络链路质量的实时监控。通过详细的步骤和必要的依赖包安装,确保用户能够顺利完成部署并优化其网络性能监控。 ... [详细]
  • CentOS7源码编译安装MySQL5.6
    2019独角兽企业重金招聘Python工程师标准一、先在cmake官网下个最新的cmake源码包cmake官网:https:www.cmake.org如此时最新 ... [详细]
  • 本文详细介绍如何使用Samba软件配置CIFS文件共享服务,涵盖安装、配置、权限管理及多用户挂载等关键步骤。通过具体示例和命令行操作,帮助读者快速搭建并优化Samba服务器。 ... [详细]
author-avatar
少年奇趣视频
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有