必须要说容器是一个很牛逼的思想!注意,是思想!也许docker有种种问题,但是不管docker能否茁壮地发展下去,未来这种方式的环境搭建一定会变得越来越流行!

网上有很多这方面的教程,但大多数都不太好。。。。初学者很难上手看的一脸懵逼,而且很多自己都根本没验证过行不行,而且很多问题都没有提到!!因此我自己写一个这方面的教程,以后自己看起来方便,有缘的docker新手看到这篇文章也许能给你一些帮助。


首先是安装docker

我们在centos7上安装docker-ce,也就是社区版。这篇博客里面有centos和ubuntu的安装方式:https://www.linuxidc.com/Linux/2017-12/149576.htm

我在这里再说一遍我的安装过程,注意!如果是root用户连接服务器在做这样的操作,那就不用加sudo了,加了也不识别。。。另外如果需要选择特定的docker版本也可以在那个博客里找到,但我个人觉得没啥必要,装最新版的就好了呗,有问题了再说hhhhh

// 1. 安装必要的一些系统工具
sudo yum install -y yum-utils device-mapper-persistent-data lvm2
// 2. 添加软件源信息
sudo yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
// 3. 更新并安装 Docker-CE
sudo yum makecache fast
sudo yum -y install docker-ce
// 4. 开启Docker服务
sudo service docker start
// 5. 设置开机启动
sudo systemctl docker enable

如果你要装tensorflow-gpu,那么还要装个nvidia-docker2

这个参考nvidia的github就行,为什么我非要下docker-ce版的呢,因为我用docker按照github的方法来做貌似没成功。。。也没深究。网址:https://github.com/NVIDIA/nvidia-docker

一定要注意选择docker-ce那个版本。我这里也写一下。

# If you have nvidia-docker 1.0 installed: we need to remove it and all existing GPU containers
docker volume ls -q -f driver=nvidia-docker | xargs -r -I{} -n1 docker ps -q -a -f volume={} | xargs -r docker rm -f
sudo yum remove nvidia-docker
# Add the package repositories
distribution=$(. /etc/os-release;echo $ID$VERSION_ID)
curl -s -L https://nvidia.github.io/nvidia-docker/$distribution/nvidia-docker.repo | \
sudo tee /etc/yum.repos.d/nvidia-docker.repo
# Install nvidia-docker2 and reload the Docker daemon configuration
sudo yum install -y nvidia-docker2
sudo pkill -SIGHUP dockerd
# Test nvidia-smi with the latest official CUDA image
docker run --runtime=nvidia --rm nvidia/cuda:9.0-base nvidia-smi

安装nvidia驱动(如果你要用tf-gpu)

前面你会发现安装好了之后,docker run –runtime=nvidia –rm nvidia/cuda:9.0-base nvidia-smi这句话没用,那是因为没装nvidia驱动,安装nvidia驱动方法我这里就不说了,比较简单,装好了之后本机上可以nvidia-smi查看显卡使用情况。

下载tensorflow镜像

这里直接看官网https://tensorflow.google.cn/install/docker

有个问题啊。tensorflow/tensorflow:latest或者tensorflow/tensorflow:latest-gpu都是python2.7版本的环境!!!!我们都新时代的人了,用python3吧,不然在中文集上你会很烦的!!https://hub.docker.com/r/tensorflow/tensorflow/tags/这个网站上给出了一些镜像的名称。其实很简单在名字后面加个-py3就行了,就能把python3的环境拉下来了。

启动镜像

我用一个例子来说明吧:

docker run --runtime=nvidia -t -v /home/xxx/docker/tf:/root/tf --name tf_py3 \
tensorflow/tensoflow:latest-py3 bash

–runtime=nvidia 是nvidia-docker2的特点

-v 数据卷  冒号前面是本机目录,冒号后面是docker内目录,目录内文件共享

–name 容器名字,下次可以用名字打开,不用记住那个麻烦的序列

tensorflow/tensoflow:latest-py3  对应镜像,如果要用gpu版的,加个-gpu

bash  说明进入命令行界面!!!这个真的是要划重点了,网上很多centos7搭docker教程都是说,给一个序列,我在浏览器里输什么什么什么,我特么centos7没有图形界面啊!!!!!!!我不知道centos7是不是能用浏览器,貌似也是可以的,但我没有深究这个问题,反正就是很麻烦啊!什么鬼啊!!!加个bash就好了啊!

好了,这样就可以了,开心。

重新启动一个容器,以及字符集问题

每次退出容易用exit。然后docker ps -a 可以看到所有的容器。

输入命令 docker start xxxx

docker attach xxxx

就又进入了。

这里会遇到一个字符集问题!就是不能输入中文也不能识别中文!

输入locale -a 可以查看所有的字符集,发现是有C.UTF-8的。但是输入locale回车,发现LANG是空!就是不能用中文!咋办呢!

我现在有一个解决办法,就是每次启动容器的时候用这句话!

docker start xxxx

docker exec -it xxxx env LANG=C.UTF-8 bash

emmmm不是一个长久的办法!这样修改只是临时修改。要永久修改,需要在创建容器时在dockerfile中设置。但是要重新创建容器啊。。我都在容器里配了一些东西了。。有点烦,先不弄了,留着下次看看!

——–TODO!

就先这样解决问题了,docker还是挺牛逼的!

参考:

https://www.linuxidc.com/Linux/2017-12/149576.htm

https://m.linuxidc.com/Linux/2017-12/149578.htm

https://github.com/NVIDIA/nvidia-docker

https://tensorflow.google.cn/install/docker

centos + docker搭建深度学习环境以及一些问题解决的更多相关文章

  1. 基于Ubuntu+Python+Tensorflow+Jupyter notebook搭建深度学习环境

    基于Ubuntu+Python+Tensorflow+Jupyter notebook搭建深度学习环境 前言一.环境准备环境介绍软件下载VMware下安装UbuntuUbuntu下Anaconda的安 ...

  2. 教你如何用Docker快速搭建深度学习环境

    本教程搭建集 Tensorflow.Keras.Coffe.PyTorch 等深度学习框架于一身的环境,及jupyter. 本教程使用nvidia-docker启动实例,通过本教程可以从一个全新的Ub ...

  3. ubuntu18.04下搭建深度学习环境anaconda2+ cuda9.0+cudnn7.0.5+tensorflow1.7【原创】【学习笔记】

    PC:ubuntu18.04.i5.七彩虹GTX1060显卡.固态硬盘.机械硬盘 作者:庄泽彬(欢迎转载,请注明作者) 说明:记录在ubuntu18.04环境下搭建深度学习的环境,之前安装了cuda9 ...

  4. ubuntu16.04+七彩虹GTX1060的NVIDIA驱动+Cuda8.0+cudnn5.1+tensorflow+keras搭建深度学习环境【学习笔记】【原创】

    平台信息:PC:ubuntu16.04.i5.七彩虹GTX1060显卡 作者:庄泽彬(欢迎转载,请注明作者) 说明:参考了网上的一堆的资料搭建了深度学习的开发环境,下班在宿舍折腾了好几个晚上才搞定,写 ...

  5. centos7 手把手从零搭建深度学习环境 (以TensorFlow2.0为例)

    目录 一. 搭建一套自己的深度学习平台 二. 安装系统 三. 安装NVIDA组件 四. 安装深度学习框架 TensorFlow 五. 配置远程访问 六. 验收 七. 福利(救命稻草

  6. ubuntu 17.04 下搭建深度学习环境

    .目前使用CPU即可,先不需要显卡配置 .使用pip3 安装深度学习框架 .要先安装pip3 #sudo apt install python3-pip https://blog.csdn.net/b ...

  7. 在服务器的docker里 装anacond3深度学习环境的全流程超基础

    ​ 背景: 实验室给我分配了一个服务器 已经装好了docker 和nvidi docker . 现在我的目标是创建我自己的docker 然后在我自己的docker里装上anaconda环境. 我以前从 ...

  8. linux系统下深度学习环境搭建和使用

    作为一个AI工程师,对Linux的一些技能的掌握也能从一定层面反应工程师的资深水平. 要求1:基于SSH的远程访问(本篇文章) 能用一台笔记本电脑,远程登陆一台linux服务器 能随时使用笔记本电脑启 ...

  9. 服务器搭建远程docker深度学习环境

    服务器搭建远程docker深度学习环境 本文大部分内容参考知乎文章 Docker+PyCharm快速搭建机器学习开发环境 搭建过程中出现ssh连接问题可以查看最后的注意事项 Docker Docker ...

随机推荐

  1. MySQL报错argument out of range 1055解决办法

    参考:https://www.cnblogs.com/liangbenstudy/p/10246895.html MySQL 5.7.22查询时候报错 argument out of range 报错 ...

  2. web端自动化——Selenium3+python自动化(3.7版本)-chrome67环境搭建

    前言 目前selenium版本已经升级到3.0了,网上的大部分教程是基于2.0写的,所以在学习前先要弄清楚版本号,这点非常重要.本系列依然以selenium3为基础. 一.selenium简介 Sel ...

  3. 【嵌入式硬件Esp32】ESP32使用visual studio cod界面

     如何下载安装IDE Visual Studio Code大家可以在微软的官网上根据自身的开发平台下载,至于安装方法就是无脑式地按Next就好了,下载地址如下所示: Visual Studio Cod ...

  4. noVNC 安装、配置与使用

    最近项目中使用到了远程终端操控,从各方找到了noVNC这个神奇的家伙,废话不多说,开始介绍它的安装配置与使用. 1. 下载noNVC 好多渠道可以下载到noVNC,可以直接访问noVNC的官方网页ht ...

  5. miniconda3 安装tensorflow

    使用miniconda3进行安装 conda create -n tensorflow conda install tensorflow 输入下面的代码进行测试 import tensorflow a ...

  6. P5200 [USACO19JAN]Sleepy Cow Sorting

    P5200 [USACO19JAN]Sleepy Cow Sorting 题目描述 Farmer John正在尝试将他的N头奶牛(1≤N≤10^5),方便起见编号为1…N,在她们前往牧草地吃早餐之前排 ...

  7. DjangoRestful 递归嵌套序列化器实现

    **** 由于博客园不支持markdown语法,所以推荐以下链接阅读: 原创 https://blog.csdn.net/weixin_42495873/article/details/8943354 ...

  8. python 之 面向对象基础(组合和封装)

    7.4 组合 解决类与类之间代码冗余问题有两种解决方案: 1.继承:描述的是类与类之间,什么是什么的关系 2.组合:描述的是类与类之间的关系,是一种什么有什么的关系 一个类产生的对象,该对象拥有一个属 ...

  9. 面试题之web访问突然延迟问题

    前言 面试官经常会问平时访问正常的网页突然变慢是什么原因引起的,说明下你排查的思路:我认为这种问题很能考察一个人的综合知识面,既能融通的贯彻知识点,也能展看对每个知识点进行详细的考问. 下面我按我自己 ...

  10. Vuex入门、同步异步 存取值

    目的: 1.了解vuex中的各个js文件的用途 2.利用vuex存值 3.利用vuex取值 4.Vuex的异步同步加载问题 1. vuex中各个组件之间传值 1.父子组件 父组件-->子组件,通 ...