操做系統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 GNU/Linux [root@Optimus /]# cat /etc/issue CentOS release 6.6 (Final) Kernel \r on an \m
docker版本java
[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容器linux
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES fc289f421957 insaneworks/centos "/bin/bash" 47 hours ago Up 47 hours master
下載java7的rpm包docker
選擇的是jdk-7u75-linux-x64.rpm
vim
放到宿主機的/usr/java/
目錄下centos
[root@Optimus /]# cd /usr/java [root@Optimus java]# ls jdk-7u75-linux-x64.rpm
從宿主機向docker容器中拷貝數據bash
1) 失敗的拷貝方式oracle
從docker容器中向主機拷貝文件 docker cp containerID:container_path host_path
app
從主機複製到容器docker cp host_path containerID:container_path
oop
我嘗試用以上方式傳送文件至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)