docker概述-安装-常用命令

Docker概述

Docker为什么出现?

  • 大家经常做一款产品:需要开发–上线,它是有两套环境的,分别是开发环境和运维环境是十分麻烦的。

  • 出现问题:

    • 我在我的电脑上可以运行
    • 版本更新,导致服务不可用
    • 环境配置配置十分麻烦(费时费力)
    • 环境不能跨平台
  • 解决问题:

    • 发布项目的时候(jar包+(环境))即项目带上环境打包
    • java — apk — 发布 (应用商店) — 张三使用apk — 安装可用
    • java — jar(环境) — 打包项目带上环境(镜像) — (docker仓库:商店)— 下载我们发布的镜像 — 直接运行即可
  • Docker的思想来源于集装箱,核心思想是隔离,再也不用担心多个应用端口冲突等问题,就是把应用打包成集装箱,每个箱子都是相互隔离的,通过隔离机制,可以将服务器利用到极致。

Docker的历史

​ 在2010年,几个搞IT的年轻人,在美国成立了一家公司dotCloud,做一些pass的云计算服务,LXC有关的容器技术,他们将自己的技术:容器化技术,命名就是Docker,Docker刚诞生的时候,没有引起行业的注意,很难拿活下去,他们突然脑子里冒出一个词,开源

​ 2013年,公司一个创始人将Docker开源,越来越多的人发现了Docker的优点,所以Docker火了,开源之后每个月都会更新一个版本。

​ 2014年4月9日,Docker1.0发布。

​ Docker为什么这么火呢?因为十分轻巧,在容器技术出来之前,我们用的都是虚拟机技术。在window中安装一个vmware,通过这个软件我们可以虚拟出来一台或者多台电脑,非常的笨重。虚拟机属于虚拟化技术,Docker容器技术,也是一种虚拟化技术。

虚拟机Docker
linux centos原生镜像(一个电脑)隔离镜像(最核心的环境 +jdk +mysql等)
需要开启多个虚拟机运行镜像就可以了
几GB,启动一般需要几分钟几MB,秒级启动

Docker是基于Go语言开发的

官方文档

https://docs.docker.com/ Docker的文档是超级纤细的

仓库地址

https://hub.docker.com/

Docker能干吗

之前的虚拟机技术与现在的容器化技术对比

在这里插入图片描述

  • 虚拟机的技术缺点:
    • 资源占用多
    • 冗余步骤多
    • 启动很慢
比较Docker和虚拟机的不同:
  • 传统虚拟机,虚拟机出一套硬件,运行一个完整的操作系统,然后在这个系统上安装和运行软件
  • 容器内的应用直接运行在宿主机的内容,容器是没有自己的内核的,也没有虚拟我们的硬件,所以就轻便了。
  • 每个容器间是相互隔离,每个容器都有一个属于自己的文件系统,互不影响。
DevOps(开发、运维)
  • 应用更快速的交付和部署

    • 传统:一堆的帮助文档,安装程序
    • Docker:打包镜像发布测试,一键运行
  • 更便捷的升级和扩容

    • 使用了Docker之后,我们部署应用就和搭积木一样
    • 比如将项目打包为一个镜像,扩展 服务器A出现问题,直接在服务器B上一键运行,就被扩展起来了,一个服务器上可以运行多个容器,容器之间也可以进行交互。
  • 更简单的系统运维

    • 在容器化之后,我们的开发,测试环境都是高度一致的
  • 更高效的计算机资源利用

    • 1核2g的服务器可以运行很多tomcat
    • Docker是内核级别的虚拟化,可以在一个物理机上运行很多的容器实例,服务器性能可以被压榨到极致。

Docker安装

Docker的基本组成

在这里插入图片描述

镜像(image):

​ docker镜像就好比是一个模板,可以通过这个模板来创建容器服务,比如说我们有一个tomcat镜像,我们要把这个tomcat服务启动起来,我们需要先把tomcat镜像运行起来才可以启动,通过这个镜像可以创建多个容器,最终服务运行或者项目运行就是在容器中的。

容器(container):

​ docker利用容器技术,独立运行一个或者一个组应用,通过镜像来创建。又启动,停止,删除,基本命令。目前可以把这个容器理解为就是一个简易版的linux系统。

仓库(repository):

​ 仓库就是存放镜像的地方,仓库分为公有的仓库和私有的仓库。

​ 国内:Docker Hub(仓库默认是国外的)所以可以通过maven配置镜像加速。

安装Docker

环境准备

  • 需要一点点的linux基础
  • centos7
  • 使用xshell连接远程服务器
环境查看
#系统内核是3.10 以上的
[root@iZf8zff8w858odmgrunrpoZ /]# uname -r
3.10.0-862.14.4.el7.x86_64
#系统版本
[root@iZf8zff8w858odmgrunrpoZ /]# cat /etc/os-release
NAME="CentOS Linux"
VERSION="7 (Core)"
ID="centos"
ID_LIKE="rhel fedora"
VERSION_ID="7"
PRETTY_NAME="CentOS Linux 7 (Core)"
ANSI_COLOR="0;31"
CPE_NAME="cpe:/o:centos:centos:7"
HOME_URL="https://www.centos.org/"
BUG_REPORT_URL="https://bugs.centos.org/"

CENTOS_MANTISBT_PROJECT="CentOS-7"
CENTOS_MANTISBT_PROJECT_VERSION="7"
REDHAT_SUPPORT_PRODUCT="centos"
REDHAT_SUPPORT_PRODUCT_VERSION="7"

安装Docker

帮助文档:
1.#卸载旧的版本
sudo yum remove docker \
                  docker-client \
                  docker-client-latest \
                  docker-common \
                  docker-latest \
                  docker-latest-logrotate \
                  docker-logrotate \
                  docker-engine

在这里插入图片描述

2.#需要的安装包
sudo yum install -y yum-utils
3.#设置镜像的仓库
sudo yum-config-manager \
    --add-repo \
    https://download.docker.com/linux/centos/docker-ce.repo  #默认是国外的,十分慢
#阿里云镜像,快
sudo yum-config-manager \
    --add-repo \
    http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
4.#更新yum软件包索引
yum makecache fast

5.#安装docker   docker-ce:社区    ee:企业
sudo yum install docker-ce docker-ce-cli containerd.io

6.#启动docker
sudo systemctl start docker

7.#使用下面命令查看docker版本,以及是否安装成功
docker version

在这里插入图片描述

8.#hello-world
sudo docker run hello-world

在这里插入图片描述

9.#查看下载的这个helloworld镜像
docker images

在这里插入图片描述

了解:卸载docker
#卸载依赖
sudo yum remove docker-ce docker-ce-cli containerd.io
#删除docker资源    /var/lib/docker(docker的默认工作路径)
sudo rm -rf /var/lib/docker
sudo rm -rf /var/lib/containerd

阿里云镜像加速

1.登录阿里云,找到容器服务(容器镜像服务)

2.找到镜像加速

3.配置使用

sudo mkdir -p /etc/docker
#编译配置文件
#把镜像加速器的配置粘贴过来
#服务重启
sudo systemctl daemon-reload
#重启docker
sudo systemctl restart docker

回顾helloword流程

在这里插入图片描述
在这里插入图片描述

底层原理

Docker是怎么工作的?

​ Docker是一个Client-Server结构的系统,Docker的守护进程运行在主机上,通过Socket从客户端访问。

​ Docker-Server接收到Docker-Client的指令,就会去执行这个命令。

在这里插入图片描述


Docker为什么比VM快?

1.Docker有着比虚拟机更少的抽象层

2.docker利用的是宿主机的内核,vm需要的是Guest OS。

在这里插入图片描述

所以说,新建一个容器的时候,docker不需要像虚拟机一样重新加载一个操作系统内核,避免引导,虚拟机是加载Guest OS,分钟级别的,而docker是利用宿主机的操作系统,省略了这个复杂的系统,是秒级的。

Docker的常用命令

帮助命令

docker version 		 #显示docker版本信息
docker info			 #显示docker的系统信息,包括镜像和容器的数量
docker 命令 --help	#帮助命令
帮助文档的地址:

https://docs.docker.com/engine/reference/

镜像命令

docker images 查看所有本地主机上的镜像
[root@iZf8zff8w858odmgrunrpoZ /]# docker images
REPOSITORY    TAG       IMAGE ID       CREATED        SIZE
hello-world   latest    d1165f221234   5 months ago   13.3kB

#解释
REPOSITORY   镜像的仓库源
TAG			 镜像的标签
IMAGE ID     镜像的id
CREATED 	 镜像的创建时间
SIZE		 镜像的大小
[root@iZf8zff8w858odmgrunrpoZ /]# docker images --help
#可选项
  -a, --all             #列出所有镜像
  -q, --quiet           #只显示镜像的id
docker search 搜索镜像
[root@iZf8zff8w858odmgrunrpoZ /]# docker search mysql
NAME     DESCRIPTION                                     STARS   OFFICIAL AUTOMATED
mysql    MySQL is a widely used, open-source relation…   11299   [OK]       
mariadb  MariaDB Server is a high performing open sou…   4292    [OK]       

#可选项,通过收藏来过滤
docker search --help
--filter=STARS=3000    #搜索出来的镜像就是STRARS大于3000的 

[root@iZf8zff8w858odmgrunrpoZ /]# docker search mysql  --filter=STARS=3000
NAME      DESCRIPTION                                     STARS     OFFICIAL   AUTOMATED
mysql     MySQL is a widely used, open-source relation…   11299     [OK]       
mariadb   MariaDB Server is a high performing open sou…   4292      [OK]       
docker pull 下载镜像
#下载镜像  docker pull 镜像名[:tag]
[root@iZf8zff8w858odmgrunrpoZ /]# docker pull mysql
Using default tag: latest       #如果不写tag,默认就是 latest
latest: Pulling from library/mysql
e1acddbe380c: Pull complete 	#分层下载:docker image的核心
bed879327370: Pull complete 
03285f80bafd: Pull complete 
ccc17412a00a: Pull complete 
1f556ecc09d1: Pull complete 
adc5528e468d: Pull complete 
1afc286d5d53: Pull complete 
6c724a59adff: Pull complete 
0f2345f8b0a3: Pull complete 
c8461a25b23b: Pull complete 
3adb49279bed: Pull complete 
77f22cd6c363: Pull complete 
Digest: sha256:d45561a65aba6edac77be36e0a53f0c1fba67b951cb728348522b671ad63f926 #签名
Status: Downloaded newer image for mysql:latest
docker.io/library/mysql:latest   #真实地址

#等价
docker pull mysql
docker pull docker.io/library/mysql:latest

#指定版本下载
[root@iZf8zff8w858odmgrunrpoZ /]# docker pull mysql:5.7
5.7: Pulling from library/mysql
e1acddbe380c: Already exists 
bed879327370: Already exists 
03285f80bafd: Already exists 
ccc17412a00a: Already exists 
1f556ecc09d1: Already exists 
adc5528e468d: Already exists 
1afc286d5d53: Already exists 
4d2d9261e3ad: Pull complete 
ac609d7b31f8: Pull complete 
53ee1339bc3a: Pull complete 
b0c0a831a707: Pull complete 
Digest: sha256:7cf2e7d7ff876f93c8601406a5aa17484e6623875e64e7acc71432ad8e0a3d7e
Status: Downloaded newer image for mysql:5.7
docker.io/library/mysql:5.7

[root@iZf8zff8w858odmgrunrpoZ /]# docker images
REPOSITORY    TAG       IMAGE ID       CREATED        SIZE
mysql         5.7       6c20ffa54f86   3 days ago     448MB
mysql         latest    5a4e492065c7   3 days ago     514MB
hello-world   latest    d1165f221234   5 months ago   13.3kB
docker rmi 删除镜像
docker rmi -f 镜像id     				#删除指定的容器
docker rmi -f $(docker images -aq)   #删除全部容器
docker rmi -f 镜像id 镜像id 镜像id  	 #删除多个容器

容器命令

说明:我们有了镜像才可以创建容器,linux,下载一个centos镜像来测试学习

docker pull centos

在这里插入图片描述

新建容器并启动
docker run [可选参数] image

#参数说明
--name="Name"    容器名字 tomcat01 tomcat02区分容器
-d               后台发送运行
-i,-t            使用交互方式运行,进入容器查看内容
-p               指定容器端口  -p 8080:8080
	-p ip:主机端口:容器端口
	-p 主机端口:容器端口 (常用的)
	-p 容器端口
	容器端口
-P               随即指定端口

#测试
docker images

#docker run -it centos /bin/bash   启动,并进入容器
[root@iZf8zff8w858odmgrunrpoZ /]# docker run -it centos /bin/bash
[root@c8e435dc75b2 /]# 这边的主机名就是镜像id,ls查看容器内的centos,基础版本,很多命令是不完善的
[root@c8e435dc75b2 /]# ls
bin  dev  etc  home  lib  lib64  lost+found  media  mnt  opt  proc  root  run  sbin  srv  sys  tmp  usr  var

#exit  退出
[root@c8e435dc75b2 /]# exit
exit
[root@iZf8zff8w858odmgrunrpoZ /]# ls
bin   dev  home  lib64       media  opt   root  sbin  sys  usr
boot  etc  lib   lost+found  mnt    proc  run   srv   tmp  var
列出所有运行的容器
docker ps 命令
	 #列出当前正在运行的容器
-a   #列出当前正在运行的容器+历史运行过的容器
-n=? #列出最近创建的容器    docker ps -a -n=1
-p   #只显示容器的编号      docker ps -aq
退出容器
exit   #直接容器停止并退出
Ctrl + 	P + Q   #容器不停止但退出
[root@iZf8zff8w858odmgrunrpoZ /]# docker run -it centos /bin/bash
[root@7d71f193e4bb /]# [root@iZf8zff8w858odmgrunrpoZ /]# docker ps
CONTAINER ID  IMAGE  COMMAND     CREATED        STATUS    PORTS  NAMES
7d71f193e4bb  centos "/bin/bash" 31 seconds ago Up 30 seconds    lucid_villani
删除容器
docker rm 容器id					#删除指定容器,不能删除正在运行的容器,如果要强制删除 rm -f
docker rm -f $(docker ps -aq)    #删除所有容器
docker -a -q|xargs docker rm     #删除所有容器
启动和停止容器的操作
docker start 容器id       #启动容器
docker restart 容器id		#重启容器
docker stop 容器id		#停止当前正在运行的容器
docker kill 容器id		#强制停止当前容器

在这里插入图片描述

常用其他命令

后台启动容器
#docker run -d 镜像名
docker run -d centos

#问题:docker ps发现centos停止了

#常见的坑:docker容器使用后台运行,就必须要有一个前要进程,docker发现没有应用,就会自动给停止
#nginx,容器启动后,发现自己没有提供服务,就会立刻停止,就是没有程序了
查看日志
docker logs -f -t --tail 10  6c72454c9440  #查看容器里的10条日志
docker logs -f -t --tail 条数   
#容器里面没有日志
#自己编写一段脚本 "while true;do echo renyuhua;sleep 1;done"
docker run -d centos /bin/sh -c "while true;do echo renyuhua;sleep 1;done"

#docker ps
CONTAINER ID        IMAGE        
NAMEScd88b907df44 	centos

#显示日志
-f			    #显示日志
-t				#显示时间戳
--tail number	#显示日志条数
查看容器中进程信息ps
#docker top 容器id
[root@iZf8zff8w858odmgrunrpoZ ~]# docker top cd88b907df44

在这里插入图片描述

查看镜像元数据
#docker inspect --help
#docker inspect 容器id

[root@iZf8zff8w858odmgrunrpoZ ~]# docker inspect cd88b907df44
[
    {
        "Id": "cd88b907df44105710a775dfdd79e0d4185239554c57db514aca814cfe146c36",
        "Created": "2021-08-21T08:02:48.369649845Z",
        "Path": "/bin/sh",
        "Args": [
            "-c",
            "while true;do echo renyuhua;sleep 1;done"
        ],
        "State": {
            "Status": "running",
            "Running": true,
            "Paused": false,
            "Restarting": false,
            "OOMKilled": false,
            "Dead": false,
            "Pid": 6922,
            "ExitCode": 0,
            "Error": "",
            "StartedAt": "2021-08-21T08:02:48.624801133Z",
            "FinishedAt": "0001-01-01T00:00:00Z"
        },
        "Image": "sha256:300e315adb2f96afe5f0b2780b87f28ae95231fe3bdd1e16b9ba606307728f55",
        "ResolvConfPath": "/var/lib/docker/containers/cd88b907df44105710a775dfdd79e0d4185239554c57db514aca814cfe146c36/resolv.conf",
        "HostnamePath": "/var/lib/docker/containers/cd88b907df44105710a775dfdd79e0d4185239554c57db514aca814cfe146c36/hostname",
        "HostsPath": "/var/lib/docker/containers/cd88b907df44105710a775dfdd79e0d4185239554c57db514aca814cfe146c36/hosts",
        "LogPath": "/var/lib/docker/containers/cd88b907df44105710a775dfdd79e0d4185239554c57db514aca814cfe146c36/cd88b907df44105710a775dfdd79e0d4185239554c57db514aca814cfe146c36-json.log",
        "Name": "/youthful_archimedes",
        "RestartCount": 0,
        "Driver": "overlay2",
        "Platform": "linux",
        "MountLabel": "",
        "ProcessLabel": "",
        "AppArmorProfile": "",
        "ExecIDs": null,
        "HostConfig": {
            "Binds": null,
            "ContainerIDFile": "",
            "LogConfig": {
                "Type": "json-file",
                "Config": {}
            },
            "NetworkMode": "default",
            "PortBindings": {},
            "RestartPolicy": {
                "Name": "no",
                "MaximumRetryCount": 0
            },
            "AutoRemove": false,
            "VolumeDriver": "",
            "VolumesFrom": null,
            "CapAdd": null,
            "CapDrop": null,
            "CgroupnsMode": "host",
            "Dns": [],
            "DnsOptions": [],
            "DnsSearch": [],
            "ExtraHosts": null,
            "GroupAdd": null,
            "IpcMode": "private",
            "Cgroup": "",
            "Links": null,
            "OomScoreAdj": 0,
            "PidMode": "",
            "Privileged": false,
            "PublishAllPorts": false,
            "ReadonlyRootfs": false,
            "SecurityOpt": null,
            "UTSMode": "",
            "UsernsMode": "",
            "ShmSize": 67108864,
            "Runtime": "runc",
            "ConsoleSize": [
                0,
                0
            ],
            "Isolation": "",
            "CpuShares": 0,
            "Memory": 0,
            "NanoCpus": 0,
            "CgroupParent": "",
            "BlkioWeight": 0,
            "BlkioWeightDevice": [],
            "BlkioDeviceReadBps": null,
            "BlkioDeviceWriteBps": null,
            "BlkioDeviceReadIOps": null,
            "BlkioDeviceWriteIOps": null,
            "CpuPeriod": 0,
            "CpuQuota": 0,
            "CpuRealtimePeriod": 0,
            "CpuRealtimeRuntime": 0,
            "CpusetCpus": "",
            "CpusetMems": "",
            "Devices": [],
            "DeviceCgroupRules": null,
            "DeviceRequests": null,
            "KernelMemory": 0,
            "KernelMemoryTCP": 0,
            "MemoryReservation": 0,
            "MemorySwap": 0,
            "MemorySwappiness": null,
            "OomKillDisable": false,
            "PidsLimit": null,
            "Ulimits": null,
            "CpuCount": 0,
            "CpuPercent": 0,
            "IOMaximumIOps": 0,
            "IOMaximumBandwidth": 0,
            "MaskedPaths": [
                "/proc/asound",
                "/proc/acpi",
                "/proc/kcore",
                "/proc/keys",
                "/proc/latency_stats",
                "/proc/timer_list",
                "/proc/timer_stats",
                "/proc/sched_debug",
                "/proc/scsi",
                "/sys/firmware"
            ],
            "ReadonlyPaths": [
                "/proc/bus",
                "/proc/fs",
                "/proc/irq",
                "/proc/sys",
                "/proc/sysrq-trigger"
            ]
        },
        "GraphDriver": {
            "Data": {
                "LowerDir": "/var/lib/docker/overlay2/3cdc3940fa0e9e4ddfd55a0ef2e8659540cd3dacd9c3507b87de97e4128e89ee-init/diff:/var/lib/docker/overlay2/43dfcd7f5aedf0b8a646051554745f4af12b8aa9d56dd0d7fd4d1750511aa094/diff",                
                "MergedDir": "/var/lib/docker/overlay2/3cdc3940fa0e9e4ddfd55a0ef2e8659540cd3dacd9c3507b87de97e4128e89ee/merged",
                "UpperDir": "/var/lib/docker/overlay2/3cdc3940fa0e9e4ddfd55a0ef2e8659540cd3dacd9c3507b87de97e4128e89ee/diff",
                "WorkDir": "/var/lib/docker/overlay2/3cdc3940fa0e9e4ddfd55a0ef2e8659540cd3dacd9c3507b87de97e4128e89ee/work"
            },
            "Name": "overlay2"
        },
        "Mounts": [],
        "Config": {
            "Hostname": "cd88b907df44",
            "Domainname": "",
            "User": "",
            "AttachStdin": false,
            "AttachStdout": false,
            "AttachStderr": false,
            "Tty": false,
            "OpenStdin": false,
            "StdinOnce": false,
            "Env": [
                "PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin"
            ],
            "Cmd": [
                "/bin/sh",
                "-c",
                "while true;do echo kuangshen;sleep 1;done"
            ],
            "Image": "centos",
            "Volumes": null,
            "WorkingDir": "",
            "Entrypoint": null,
            "OnBuild": null,
            "Labels": {
                "org.label-schema.build-date": "20201204",
                "org.label-schema.license": "GPLv2",
                "org.label-schema.name": "CentOS Base Image",
                "org.label-schema.schema-version": "1.0",
                "org.label-schema.vendor": "CentOS"
            }
        },
        "NetworkSettings": {
            "Bridge": "",
            "SandboxID": "0d552419d791ef03df7d1ed102de582c4b7e63b17f0dee5c7c5619faaeb5c051",
            "HairpinMode": false,
            "LinkLocalIPv6Address": "",
            "LinkLocalIPv6PrefixLen": 0,
            "Ports": {},
            "SandboxKey": "/var/run/docker/netns/0d552419d791",
            "SecondaryIPAddresses": null,
            "SecondaryIPv6Addresses": null,
            "EndpointID": "7be3a20aba64ba313dc13dfed7d4d020addb5fa3c12589ff86ff6e965afa27f9",
            "Gateway": "172.17.0.1",
            "GlobalIPv6Address": "",
            "GlobalIPv6PrefixLen": 0,
            "IPAddress": "172.17.0.2",
            "IPPrefixLen": 16,
            "IPv6Gateway": "",
            "MacAddress": "02:42:ac:11:00:02",
            "Networks": {
                "bridge": {
                    "IPAMConfig": null,
                    "Links": null,
                    "Aliases": null,
                    "NetworkID": "28233dc42fbca70edea53bd0a30e694792e54dfd7c64252d7cfa7982cbe0987b",
                    "EndpointID": "7be3a20aba64ba313dc13dfed7d4d020addb5fa3c12589ff86ff6e965afa27f9",
                    "Gateway": "172.17.0.1",
                    "IPAddress": "172.17.0.2",
                    "IPPrefixLen": 16,
                    "IPv6Gateway": "",
                    "GlobalIPv6Address": "",
                    "GlobalIPv6PrefixLen": 0,
                    "MacAddress": "02:42:ac:11:00:02",
                    "DriverOpts": null
                }
            }
        }
    }
]

进入当前正在运行的容器
#我们通常容器都是使用后台发送运行的,需要进入容器,修改一些配置

#方式1.命令 -it交互进行
docker exec -it 容器id bashShell
#测试
[root@iZf8zff8w858odmgrunrpoZ ~]# docker exec -it cd88b907df44 /bin/bash
[root@cd88b907df44 /]# ls
bin  dev  etc  home  lib  lib64  lost+found  media  mnt  opt  proc  root  run  sbin  srv  sys  tmp  usr  var

#方式2
docker attach 容器id
#测试
[root@iZf8zff8w858odmgrunrpoZ ~]# docker attach cd88b907df44
renyuhua
renyuhua
正在执行当前的代码.....

#docker exec       	#进入容器后开启一个新的终端,可以在里面操作(常用)
#docker attach		#进入容器正在执行的终端,不会启动新的进程
从容器内拷贝文件到主机上
#docker cp 容器id:容器内路径       目的主机路径

#查看当前主机目录下
[root@iZf8zff8w858odmgrunrpoZ ~]# docker images
REPOSITORY   TAG       IMAGE ID       CREATED        SIZE
centos       latest    300e315adb2f   8 months ago   209MB
[root@iZf8zff8w858odmgrunrpoZ ~]# docker run -it centos /bin/bash
[root@ead12bfcbf66 /]# [root@iZf8zff8w858odmgrunrpoZ ~]# docker ps
CONTAINER ID   IMAGE     COMMAND       CREATED          STATUS          PORTS     NAMES
ead12bfcbf66   centos    "/bin/bash"   24 seconds ago   Up 23 seconds             elegant_nash
[root@iZf8zff8w858odmgrunrpoZ ~]# cd /home
[root@iZf8zff8w858odmgrunrpoZ home]# ls
[root@iZf8zff8w858odmgrunrpoZ home]# touch ren.java
[root@iZf8zff8w858odmgrunrpoZ home]# ls
ren.java
[root@iZf8zff8w858odmgrunrpoZ home]# docker ps
CONTAINER ID IMAGE  COMMAND     CREATED            STATUS            PORTS NAMES
ead12bfcbf66 centos "/bin/bash" About a minute ago Up About a minute elegant_nash

#进入docker容器
[root@iZf8zff8w858odmgrunrpoZ home]# docker attach ead12bfcbf66
[root@ead12bfcbf66 /]# cd /home
[root@ead12bfcbf66 home]# ls
#在容器内新建文件
[root@ead12bfcbf66 home]# touch hua.java
[root@ead12bfcbf66 home]# ls
hua.java
[root@ead12bfcbf66 home]# exit
exit

#将文件拷贝出来到主机上
[root@iZf8zff8w858odmgrunrpoZ home]# docker cp ead12bfcbf66:/home/hua.java /home
[root@iZf8zff8w858odmgrunrpoZ home]# cd home
-bash: cd: home: No such file or directory
[root@iZf8zff8w858odmgrunrpoZ home]# cd /home
[root@iZf8zff8w858odmgrunrpoZ home]# ls
hua.java  ren.java
[root@iZf8zff8w858odmgrunrpoZ home]# 

#拷贝是一个手动过程,未来我们使用 -v 卷的技术来实现
小结

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值