您当前的位置:首页 > IT编程 > gnn
| C语言 | Java | VB | VC | python | Android | TensorFlow | C++ | oracle | 学术与代码 | cnn卷积神经网络 | gnn | 图像修复 | Keras | 数据集 | Neo4j | 自然语言处理 | 深度学习 | 医学CAD | 医学影像 | 超参数 | pointnet | pytorch |

自学教程:cuda8.0与cuda10.0并存解决方案

51自学网 2021-01-09 16:40:23
  gnn
这篇教程cuda8.0与cuda10.0并存解决方案写得很实用,希望能帮到您。

cuda8.0与cuda10.0并存解决方案

需要解决问题:两个不同的tensorflow项目,一个项目的tensorflow版本是1.13.1,而另一个是1.1.0.由于低版本的tensorflow不能与高版本的CUDA兼容(未解决前使用的是CUDA10.0),所以需要下载CUDA8.0以便运行tensorflow1.1.0版本的项目。

解决方案:

CUDA Toolkit 8.0 - Feb 2017developer.nvidia.com
  1. 首先在官网下载CUDA8.0 runfile包

2. 下载完成后,检查自己电脑的gcc版本是否过高,CUDA8.0适配的gcc版本是4.8:

如果gcc版本过高可以进行降级:

使用命令安装gcc-4.8:

sudo apt-get install gcc-4.8

安装完后,使用命令查看目前机器中可用的gcc版本:

ls /usr/bin/gcc* 
我的机器中可用的gcc版本有4.8和7

接下来设置默认使用的gcc版本:

sudo update-alternatives --install /usr/bin/gcc gcc /usr/bin/gcc-4.8 88

最后的88为优先级,越大越优先,由于我是第一次设置,所以数字无论多少,gcc-4.8都是最优先的。

现在重新查看gcc版本:

成功

如果需要切换回原来的gcc-7版本,运行下面两个命令:

sudo update-alternatives --remove gcc /usr/bin/gcc-4.8
sudo update-alternatives --install /usr/bin/gcc gcc /usr/bin/gcc-7 88

3. gcc版本降级后,运行命令:

sudo sh cuda_8.0.61_375.26_linux.run

如果之前已经安装过驱动了,在选择安装驱动时,选no

可能会出现配置文件不支持,是否继续的选项,这时可以继续,看最后报错信息。

如果是“Missing recommended library: libGLU.so;Missing recommended library: libXmu.so”之类,根据缺少的库一一安装上就好:

sudo apt-get install freeglut3-dev build-essential libx11-dev libxmu-dev libxi-dev libgl1-mesa-glx libglu1-mesa libglu1-mesa-dev

4. 我做完以上步骤之后,没想到还是报错了:“cannot find Toolkit in /usr/local/cuda-8.0”

在日志文件中找到了错误信息:“Can't locate InstallUtils.pm in @INC (you may need to install the InstallUtils module)(@INC contains: /etc/perl /usr/local/lib/x86_64-linux-gnu/perl/5.26.1 /usr/local/share/perl/5.26.1 /usr/lib/x86_64-linux-gnu/perl5/5.26 /usr/share/perl5 /usr/lib/x86_64-linux-gnu/perl/5.26 /usr/share/perl/5.26 /usr/local/lib/site_perl /usr/lib/x86_64-linux-gnu/perl-base”)

大概意思就是有个文件InstallUtils.pm没有在它该在的文件夹中。而它应该出现的文件夹可能是以下这些:

/etc/perl
/usr/local/lib/x86_64-linux-gnu/perl/5.26.1
/usr/local/share/perl/5.26.1
/usr/lib/x86_64-linux-gnu/perl5/5.26
/usr/share/perl5
/usr/lib/x86_64-linux-gnu/perl/5.26
/usr/share/perl/5.26
/usr/local/lib/site_perl
/usr/lib/x86_64-linux-gnu/perl-base

不同版本的Ubuntu系统安装不同版本的CUDA可能是不一样的,我的Ubuntu版本是18.04,在我的机器中,上面的路径存在的是/usr/share/perl5。所以我现在需要将缺少的文件,移到这个文件夹中。

使用下面命令建立一个空文件夹,然后将runfile文件解压,将runfile文件在安装时缺少的文件复制到上面我找到的目录中:

mkdir cuda-8.0
sudo sh cuda_8.0.61_375.26_linux.run --noexec --target cuda-8.0
sudo cp cuda-8.0/InstallUtils.pm /usr/share/perl5

完成后再次运行runfile文件,可能还会提示“You are attempting to install on an unsupported configuration. Do you wish to continue?”选择yes继续

成功!!!

5. 现在我的机器中既有CUDA10.0也有CUDA8.0,下面我要切换使用的是CUDA8.0

使用以下命令查看系统环境变量配置:

gedit ~/.bashrc

CUDA环境变量如下:

export CUDA_HOME=/usr/local/cuda
export LD_LIBRARY_PATH=/usr/local/cuda/lib64:"$LD_LIBRARY_PATH:/usr/loacl/cuda/lib64:/usr/local/cuda/extras/CUPTI/lib64"
export PATH=/usr/local/cuda/bin:$PATH

实质上切换CUDA版本就是将cuda8.0或者cuda10.0链接到cuda文件上。

在/usr/local/下打开终端,使用如下命令进行切换:

sudo rm -rf cuda
sudo ln -s /usr/local/cuda-8.0/ /usr/local/cuda

第一个命令是移除原本存在的名为cuda的软链接,第二个命令是将cuda8.0链接到一个新的名为cuda的软链接上。

成功!!!

 

cuda官方在线安装包deb安装cannot find Toolkit in /usr/local/cuda-8.0或cuda-9.0
Ubuntu16.04安装CUDA8.0+cuDNN6.0
51自学网,即我要自学网,自学EXCEL、自学PS、自学CAD、自学C语言、自学css3实例,是一个通过网络自主学习工作技能的自学平台,网友喜欢的软件自学网站。
京ICP备13026421号-1