ubuntu 14.04安装cuda

说明:nvidia的cuda对于新手来说安装是挺费劲的,一不小心就出现登录死循环或者各种冲突。最近学习tensorflow,进行显卡的支持,遇到必须装上它,摸索了2天,重装4次软件,重装系统1次,最后终于成功安装,期间主要遇到的拦路虎是安装成功后出现登录死循环。下面是我的安装步骤。强调官方的文档(NVIDIA官方文档)帮助很大,但是缺少细节。虚拟机不执行cuda

安装环境

OS: Ubuntu 14.04

ARCH: X86_64

GPU: nvidia Geforce gt 550m


  • 安装前检查

  • 检查显卡是否被支持

$ lspci | grep -i nvidia

01:00.0 VGA compatible controller: NVIDIA Corporation GF108M [GeForce GT 550M] (rev a1)

可以去查看官方网站你的显卡支持与否,本人的是支持nvidia Geforce gt 550m,支持

  • 检查操作系统版本是否被支持[不知道怎么检验,Ubuntu 64位是支持的,具体网站

$uname -m && cat /etc/*release

x86_64
disTRIB_ID=Ubuntu
disTRIB_RELEASE=14.04
disTRIB_CODENAME=trusty
disTRIB_DESCRIPTION="Ubuntu 14.04.4 LTS"
NAME="Ubuntu"
VERSION="14.04.4 LTS,Trusty Tahr"
ID=ubuntu
ID_LIKE=debian
PRETTY_NAME="Ubuntu 14.04.4 LTS"
VERSION_ID="14.04"
HOME_URL="http://www.ubuntu.com/"
SUPPORT_URL="http://help.ubuntu.com/"
BUG_REPORT_URL="http://bugs.launchpad.net/ubuntu/"

  • 检查是否安装gcc

    $ gcc --version
    gcc (Ubuntu 4.8.4-2ubuntu1~14.04.3) 4.8.4
    copyright (C) 2013 Free Software Foundation,Inc.
    This is free software; see the source for copying conditions. There is NO
    warranty; not even for MERCHANTABILITY or fitness FOR A PARTIculaR PURPOSE.
  • 检查是否安装了内核的头文件和开发包,按照下面的方式安装,输出太长,略

    $ sudo apt-get install linux-headers-$(uname -r)
  • 选择runfile安装

我们使用runfile文件安装,建议不要用deb安装,否则会出现各种冲突错误。下面的步骤请一定小心。浏览器下载runfile文件,地址 选择你自己的版本下载,大概有1.4G左右,也可以用下面的命令下载

$wget https://developer.nvidia.com/compute/cuda/8.0/Prod2/local_installers/cuda_8.0.61_375.26_linux-run ;;下载cuda runfile文件

$lsmod | grep nouveau ;;查看系统自带的驱动是否禁用,如果有输出,说明没有禁用

nouveau 1368064 1
ttm 94208 1 nouveau
drm_kms_helper 126976 2 i915,nouveau
drm 360448 9 ttm,i915,drm_kms_helper,nouveau
i2c_algo_bit 16384 2 i915,nouveau
mxm_wmi 16384 1 nouveau
wmi 20480 2 mxm_wmi,nouveau

video 36864 3 i915,ideapad_laptop,nouveau


$vi /etc/modprobe.d/blacklist-nouveau.conf ;;新建一个文件,内容如下

blacklist nouveau
options nouveau modeset=0

$sudo update-initramfs -u

$cd /lib/modules/4.2.0-27-generic/kernel/drivers/gpu/drm/nouveau ;;将里面的nouveau.ko nouveau.ko.org(可能没有)移除(注意备份)

$sudo update-initramfs -u

$sudo reboot


启动到登录界面时,Ctrl+Alt+F1进入纯文本模式,输入用户名和密码登录

$lsmod | grep nouveau ;;再次确认是否禁用成功

$sudo service lightdm stop ;;关闭图形界面

$cd /home/xzy/ ;;进入存放下载好的runfile文件的地方

$sudo sh cuda_8.0.61_375.26_linux.run ;;执行安装

安装过程中,先会让你阅读协议,按q,输入accept,接下来会让你选择性的安装,除了OpenGL选no (许多博客都说什么openGL要选yes,但经过我的实践,在cuda 8.0这项必须选择no,不然安装结束后会进入登录死循环),其余全部选yes,涉及路径的默认回车。安装结束后,开启图形界面服务,Ctrl+Alt+F7切换到登录界面

$sudo service lightdm start ;;启动图形界面服务

接下来,登录界面输入密码

  • 如果成功,检查安装

$sudo apt-get install mesa-utils ;;检查驱动的软件包
$glxinfo | grep rendering

direct rendering: Yes ;;说明驱动成功安装

$vi ~/.bashrc ;;修改环境变量,加入

export PATH=/usr/local/cuda/bin:$PATH
export LD_LIBRARY_PATH=/usr/local/cuda/lib64:$LD_LIBRARY_PATH

$source ~/.bashrc

$nvcc -V ;;检查cuda是否安装成功,你也可以编译官方给的例子来检验,由于时间关系,编译例子省略。

nvcc: NVIDIA (R) Cuda compiler driver
copyright (c) 2005-2016 NVIDIA Corporation
Built on Tue_Jan_10_13:22:03_CST_2017
Cuda compilation tools,release 8.0,V8.0.61



登录成功之后,你会发现屏幕的分辨率不正常了,系统设置里也没法正常设置,按下面的操作就可以解决了

退出图形界面,按ctrl+alt+F1进入命令行终端。

$sudo mv /etc/X11/xorg.conf /etc/X11/xorg.conf.backup

$sudo touch /etc/X11/xorg.conf

$sudo reboot
  • 如果失败,卸载cuda

不然就会出现登录死循环。如果你不幸进入登录死循环或者其他错误,你需要卸载重装cuda的,可以使用下面的命令来卸载,并分析出错的原因,再重装

$sudo /usr/local/cuda-X.Y/bin/uninstall_cuda_X.Y.pl ;;卸载cuda toolkit ,X.Y为你安装的cuda版本

$sudo /usr/bin/nvidia-uninstal ;;卸载驱动


$vi /home/xzy/.xsession-errors ;;这里面有发生错误时候的信息,检查是否有帮助


  • 参考文献

cuda官方文档 http://developer.download.nvidia.com/compute/cuda/7.5/Prod/docs/sidebar/CUDA_Installation_Guide_Linux.pdf

cuda详细安装教程http://blog.csdn.net/masa_fish/article/details/51882183

NVIDIA官方文件下载 https://developer.nvidia.com/cuda-downloads

ubuntu 14.04安装cuda8.0的更多相关文章

  1. android – 符合Nvidia Tegra profiler 2.0的移动设备

    解决方法通常任何基于Tegra4和K1的设备都可以工作,但我会推荐Nvidia的Shield/Note用于你的工作,不仅是他们退出便宜,而且他们的机器人留下了很多香草使它更容易使用.还有(可用的)更新策略的优点.

  2. PyTorch中的CUDA的操作方法

    这篇文章主要介绍了PyTorch中的CUDA的操作方法,CUDA是NVIDIA推出的异构计算平台,PyTorch中有专门的模块torch.cuda来设置和运行CUDA相关操作,更多相关介绍,需要的朋友可以查看下面文章内容

  3. 是否可以在另一个GPU(2 GPU系统)中处理数据

    我的算法需要对每个相机的数据进行长期处理,因此每个相机都需要访问相同的GPU内存问题在一个GPU中处理4个摄像头可能会导致内存不足。所以,我认为一个GPU只能处理两个摄像头。但在第一时间,如果cam3在GPU0处被处理,则cam3数据不能在GPU1处处理。我想将cam3数据从GPU0复制到GPU1,但它并没有那么小,所以看起来效率很低。是否可以在GPU1上使用GPU0数据进行处理而无需内存?我在CUDA方面很短,所以如果有好的关键词来解决这个问题,请告诉我。

  4. 如何编写CUDA内核来加速python代码

    几周来,我一直在学习python作为我的第一种编程语言。我决定用Numba编写一个乐透模拟。该代码在我的CPU上每秒大约250k次迭代时运行得很好。我真的很想看看它是如何在我的英伟达GPU上运行的,但我有点力不从心。如果有人能帮我一把,我将非常感激。我想我应该能够运行float16,因为数字并不复杂。此外,@vectorize似乎很重要。但是,老实说,我在踩水。

  5. 为什么cuGraphAddMemCopyNode已经获得了两个上下文,却需要额外的上下文?

    考虑CUDA图形API函数在此描述。它采用的CUDA_MEMCPY3D结构是一组非常广泛的参数。实际上,它包含两个上下文句柄字段:srcContext和dstContext,用于定义源和目标内存区域或数组的上下文。然而,该函数需要额外的第三个上下文句柄。但是,这意味着什么?节点是一个图,它通过具有上下文的流启动。除此之外,为什么这很重要?两个端点上下文应该足以让CUDA驱动程序执行复制。虽然大多数节点插入API函数都没有?

  6. windows – 未检测到支持CUDA的设备

    我是CUDA编程的新手,我完全陷入困境.当我尝试运行提供的deviceQuery实用程序或其中一个示例应用程序时,我收到以下错误:我使用的是Windows7,64位.我安装了VisualStudio2012,然后安装了CUDA5.064位.我的显卡是NVIDIAGeForceGTS250.今天我去了NVIDIA网站并重新安装了该卡的最新驱动程序.除了“确保安装了正在运行的驱动程序”之外,我在Win

  7. windows – 安装Tensorflow的问题 – 不是CUDA / CuDNN问题

    我最近开始进入Tensorflow,但我遇到了安装问题.每次我尝试导入它时,我都会收到以下错误我查看了与我有同样问题的其他堆栈溢出帖子,他们建议从NVIDIA获取CUDA库.问题是,我既没有NVIDIA显卡也没有GPU版本的张量流,所以我不认为这是问题所在.还有一些建议可以确保安装VisualStudio的Microsoft可再发行组件.如果这是一个基于系统变量的问题,我很感激帮助改变系统变量,因为我是新手.谢谢!

  8. 如何在Windows上模拟CUDA

    有没有什么方法可以从没有NVIDIA显卡的电脑上测试CUDA样品和代码?

  9. Windows – 编译没有Visual Studio的CUDA – “在路径中找不到编译器cl.exe”

    我刚刚在CUDA开始了一个小项目.我需要知道如下:是否可以编译CUDA代码而不使用/购买MicrosoftVisualStudio?使用Nvcc.exe我得到错误“找不到编译器cl.exe在路径”.我试图为NetBeans安装一个CUDAplugin,但它不起作用.(使用当前版本的NetBeans)平台:Windows7提前致谢.更新如评论中所述,Windows7之后的SDK版本不包括构建工具.如

  10. 从EC2上的Ubuntu安装中删除默认的“ubuntu”用户

    我正在玩AmazonsEC2新的免费套餐计划,并注意到默认的ubuntu安装附带了一个用户ubuntu,它预先配置为使用您从AWS提供的密钥.我想做的一件事是添加一个新用户并删除默认的“ubuntu”用户.根据我使用其他VPS的经验,您只能在全新安装上使用root用户.我是否应该删除默认的ubuntu用户?

随机推荐

  1. crontab发送一个月份的电子邮件

    ubuntu14.04邮件服务器:Postfixroot收到来自crontab的十几封电子邮件.这些邮件包含PHP警告.>我已经解决了这些警告的原因.>我已修复每个cronjobs不发送电子邮件(输出发送到>/dev/null2>&1)>我删除了之前的所有电子邮件/var/mail/root/var/spool/mail/root但我仍然每小时收到十几封电子邮件.这些电子邮件来自cronjobs,

  2. 模拟两个ubuntu服务器计算机之间的慢速连接

    我想模拟以下场景:假设我有4台ubuntu服务器机器A,B,C和D.我想在机器A和机器C之间减少20%的网络带宽,在A和B之间减少10%.使用网络模拟/限制工具来做到这一点?

  3. ubuntu-12.04 – 如何在ubuntu 12.04中卸载从源安装的redis?

    我从源代码在Ubuntu12.04上安装了redis-server.但在某些时候它无法完全安装,最后一次makeinstallcmd失败.然后我刚刚通过apt包安装.现在我很困惑哪个安装正在运行哪个conf文件?实际上我想卸载/删除通过源安装的所有内容,只是想安装一个包.转到源代码树并尝试以下命令:如果这不起作用,您可以列出软件自行安装所需的步骤:

  4. ubuntu – “apt-get source”无法找到包但“apt-get install”和“apt-get cache”可以找到它

    我正在尝试下载软件包的源代码,但是当我运行时它无法找到.但是当我运行apt-cache搜索squid3时,它会找到它.它也适用于apt-getinstallsquid3.我使用的是Ubuntu11.04服务器,这是我的/etc/apt/sources.list我已经多次更新了.我尝试了很多不同的debs,并没有发现任何其他地方的错误.这里的问题是你的二进制包(deb)与你的源包(deb-src)不

  5. ubuntu – 有没有办法检测nginx何时完成正常关闭?

    &&touchrestarted),因为即使Nginx没有完成其关闭,touch命令也会立即执行.有没有好办法呢?这样的事情怎么样?因此,pgrep将查找任何Nginx进程,而while循环将让它坐在那里直到它们全部消失.你可以改变一些有用的东西,比如睡1;/etc/init.d/Nginx停止,以便它会休眠一秒钟,然后尝试使用init.d脚本停止Nginx.你也可以在某处放置一个计数器,这样你就可以在需要太长时间时发出轰击信号.

  6. ubuntu – 如何将所有外发电子邮件从postfix重定向到单个地址进行测试

    我正在为基于Web的应用程序设置测试服务器,该应用程序发送一些电子邮件通知.有时候测试是使用真实的客户数据进行的,因此我需要保证服务器在我们测试时无法向真实客户发送电子邮件.我想要的是配置postfix,以便它接收任何外发电子邮件并将其重定向到一个电子邮件地址,而不是传递到真正的目的地.我正在运行ubuntu服务器9.10.先感谢您设置本地用户以接收所有被困邮件:你需要在main.cf中添加:然后

  7. ubuntu – vagrant无法连接到虚拟框

    当我使用基本的Vagrantfile,只配置了两条线:我看到我的虚拟框打开,但是我的流氓日志多次显示此行直到超时:然后,超时后的一段时间,虚拟框框终于要求我登录,但是太久了!所以我用流氓/流氓记录.然后在我的物理机器上,如果我“流氓ssh”.没有事情发生,直到:怎么了?

  8. ubuntu – Nginx – 转发HTTP AUTH – 用户?

    我和Nginx和Jenkins有些麻烦.我尝试使用Nginx作为Jenkins实例的反向代理,使用HTTP基本身份验证.它到目前为止工作,但我不知道如何传递带有AUTH用户名的标头?}尝试将此指令添加到您的位置块

  9. Debian / Ubuntu – 删除后如何恢复/ var / cache / apt结构?

    我在ubuntu服务器上的空间不足,所以我做了这个命令以节省空间但是现在在尝试使用apt时,我会收到以下错误:等等显然我删除了一些目录结构.有没有办法做apt-getrebuild-var-tree或类似的?

  10. 检查ubuntu上安装的rubygems版本?

    如何查看我的ubuntu盒子上安装的rubygems版本?只是一个想法,列出已安装的软件包和grep为ruby或宝石或其他:)dpkg–get-selections

返回
顶部