摘要:正确的拷贝方式从主机向容器中拷贝数据时,其实采用的是一种通道的方式。返回的是完整的容器。进入容器,查看文件。宿主机向容器拷贝数据成功。
操作系统
[root@Optimus /]# uname -a Linux Optimus 2.6.32-504.el6.x86_64 #1 SMP Wed Oct 15 04:27:16 UTC 2014 x86_64 x86_64 x86_64 GNU/Linux [root@Optimus /]# cat /etc/issue CentOS release 6.6 (Final) Kernel on an m
docker版本
[root@Optimus /]# docker version Client version: 1.7.1 Client API version: 1.19 Go version (client): go1.4.2 Git commit (client): 786b29d/1.7.1 OS/Arch (client): linux/amd64 Server version: 1.7.1 Server API version: 1.19 Go version (server): go1.4.2 Git commit (server): 786b29d/1.7.1 OS/Arch (server): linux/amd64
docker容器
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES fc289f421957 insaneworks/centos "/bin/bash" 47 hours ago Up 47 hours master
下载java7的rpm包
选择的是jdk-7u75-linux-x64.rpm
放到宿主机的/usr/java/目录下
[root@Optimus /]# cd /usr/java [root@Optimus java]# ls jdk-7u75-linux-x64.rpm
从宿主机向docker容器中拷贝数据
1) 失败的拷贝方式
从docker容器中向主机拷贝文件 docker cp containerID:container_path host_path
从主机复制到容器docker cp host_path containerID:container_path
我尝试用以上方式传送文件至docker容器中时会报错
[root@Optimus java]# docker cp jdk-7u75-linux-x64.rpm master:/mnt/ Error: Path not specified
报错提示一直都是Error: Path not specified。
2) 正确的拷贝方式
从主机向docker容器中拷贝数据时,其实采用的是一种通道的方式。
首先,要用docker inspect方法获得容器的完整ID
[root@Optimus java]# docker inspect -f "{{.Id}}" master fc289f421957df7d03146ab54030aa648ec78118d00d3063cdeb8966b6c223f4
这里的master可以是container name也可以是短的container ID。返回的fc289f421957df7d03146ab54030aa648ec78118d00d3063cdeb8966b6c223f4是完整的容器ID。
然后,使用通道拷贝数据
[root@Optimus java]# cp /usr/java/jdk-7u75-linux-x64.rpm /var/lib/docker/aufs/mnt/fc289f421957df7d03146ab54030aa648ec78118d00d3063cdeb8966b6c223f4/root/ cp: cannot create regular file `/var/lib/docker/aufs/mnt/fc289f421957df7d03146ab54030aa648ec78118d00d3063cdeb8966b6c223f4/root/": No such file or directory
报错No such file or directory
进入到/var/lib/docker/目录下,确实没有/aufs这个目录。
[root@Optimus /]# cd /var/lib/docker [root@Optimus docker]# ls containers devicemapper graph init linkgraph.db repositories-devicemapper tmp trust vfs volumes
在docker容器中可以看到有以下目录
[root@Optimus containers]# docker exec -it master /bin/bash [root@master /]# ls bin boot dev etc home lib lib64 media mnt opt proc root sbin selinux srv sys tmp usr var
查找一下docker容器相关的目录,fc289f421957df7d03146是容器的ID号。
[root@Optimus containers]# find / -name fc289f421957df7d03146ab54030aa648ec78118d00d3063cdeb8966b6c223f4 /var/run/docker/execdriver/native/fc289f421957df7d03146ab54030aa648ec78118d00d3063cdeb8966b6c223f4 /var/lib/docker/devicemapper/metadata/fc289f421957df7d03146ab54030aa648ec78118d00d3063cdeb8966b6c223f4 /var/lib/docker/devicemapper/mnt/fc289f421957df7d03146ab54030aa648ec78118d00d3063cdeb8966b6c223f4 ...
发现目录/var/lib/docker/devicemapper/mnt/fc289f421957df7d03146ab54030aa648ec78118d00d3063cdeb8966b6c223f4 。
因此,在docker中,其实是映射到/var/lib/docker/devicemapper/mnt/fc289f421957df7d03146ab54030aa648ec78118d00d3063cdeb8966b6c223f4/这个文件夹中的。这个文件下面就是docker中的根目录里面的内容,然后我们就可以按照我们想要的内容随便进行拷贝。
开始拷贝。拷贝到master容器中的mnt目录下。(为什么要加/rootfs/这个目录我也不记得什么鬼了。)
[root@Optimus /]# cp /usr/java/jdk-7u75-linux-x64.rpm /var/lib/docker/devicemapper/mnt/fc289f421957df7d03146ab54030aa648ec78118d00d3063cdeb8966b6c223f4/rootfs/mnt
进入容器,查看文件。宿主机向docker容器拷贝数据成功。
[root@Optimus /]# docker exec -it master /bin/bash [root@master /]# ls bin boot dev etc home lib lib64 media mnt opt proc root sbin selinux srv sys tmp usr var [root@master /]# cd mnt [root@master mnt]# ls jdk-7u75-linux-x64.rpm
安装java
添加可执行权限。
[root@master mnt]# chmod +x jdk-7u75-linux-x64.rpm [root@master mnt]# ls jdk-7u75-linux-x64.rpm
安装。
[root@master mnt]# rpm -ivh jdk-7u75-linux-x64.rpm Preparing... ########################################### [100%] 1:jdk ########################################### [100%] Unpacking JAR files... rt.jar... jsse.jar... charsets.jar... tools.jar... localedata.jar... jfxrt.jar...
配置环境变量:
编辑profile文件
vim /etc/profile
在profile文件最后追加入如下内容:
export JAVA_HOME=/usr/java/jdk1.7.0_75 export CLASSPATH=.:$JAVA_HOME/jre/lib/rt.jar:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar export PATH=$PATH:$JAVA_HOME/bin #以下是Hadoop配置 export HADOOP_HOME=/mnt/hadoop-2.8.2 export PATH=$PATH:$JAVA_HOME/bin:$HADOOP_HOME/bin
保存并退出。
执行如下
#source /etc/profile
java版本
[root@Optimus /]# java -version java version "1.6.0_38" Java(TM) SE Runtime Environment (build 1.6.0_38-b05) Java HotSpot(TM) 64-Bit Server VM (build 20.13-b02, mixed mode)
参考:http://blog.csdn.net/sonnet12...
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/27099.html
摘要:正确的拷贝方式从主机向容器中拷贝数据时,其实采用的是一种通道的方式。返回的是完整的容器。进入容器,查看文件。宿主机向容器拷贝数据成功。 操作系统 [root@Optimus /]# uname -a Linux Optimus 2.6.32-504.el6.x86_64 #1 SMP Wed Oct 15 04:27:16 UTC 2014 x86_64 x86_64 x86_64 G...
摘要:是源码,要编译才能用。的是给位机器用的,想在位机器上用只能用编译的。解压配置环境变量在和中添加环境变量添加环境变量修改修改修改文件修改在文件中添加镜像启动集群进入到每个节点执行每个节点配置查看地址配置启动查看参考 docker安装 安装 yum install -y epel-releas yum install docker-io 加入开机启动 chkconfig docker on...
摘要:该命令代表启动,并且设置启动名称和端口号,并将主机当前目录下的目录挂载到容器的下的目录中,这样以后修改只需要修改该目录下的相关文件即可。 CentOS 7 下安装 Docker 摘自 菜鸟教程 Docker 要求 CentOS 系统的内核版本高于 3.10 通过 uname -r 命令查看你当前的内核版本 [root@runoob ~]# uname -r 移除旧的版本 [root@...
阅读 1337·2023-04-25 15:21
阅读 2670·2021-11-24 10:23
阅读 3396·2021-10-11 10:59
阅读 3241·2021-09-03 10:28
阅读 1730·2019-08-26 13:45
阅读 2319·2019-08-26 12:11
阅读 920·2019-08-26 12:00
阅读 1705·2019-08-26 10:44