Docker 进入容器和交换文件

这篇具有很好参考价值的文章主要介绍了Docker 进入容器和交换文件。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

一、帮助命令

# 显示 Docker 版本信息。
docker version 

# 显示 Docker 系统信息,包括镜像和容器数。
docker info 

# 帮助
docker --help 

# 启动 docker 后台服务
sudo systemctl start docker

# 关闭 docker 后台服务
# 如果提示“Warning: Stopping docker.service, but it can still be activated by: docker.socket”,则执行 systemctl stop docker.socket 即可
sudo systemctl stop docker

# 设置 docker 开机自启动
sudo systemctl enable  docker

# 重启 docker 服务
sudo systemctl restart docker

# 重新加载某个服务的配置文件,使修改的配置文件生效
sudo systemctl daemon-reload

二、镜像命令

1、docker images

# 列出本地主机上所有的镜像
root@localhost ~]# docker images
REPOSITORY    TAG                IMAGE ID       CREATED         SIZE
tomcat        latest             fb5657adc892   19 months ago   680MB
hello-world   latest             feb5d9fea6a5   22 months ago   13.3kB
redis         5.0.9-alpine3.11   3661c84ee9d0   3 years ago     29.8MB


REPOSITORY   # 镜像的仓库源

TAG          # 镜像的标签

IMAGE ID     # 镜像的id

CREATED      # 镜像的创建时间

SIZE         # 镜像的大小


# 同一个仓库源可以有多个 TAG,代表这个仓库源的不同版本,我们使用 REPOSITORY:TAG 定义不同的镜像,如果你不定义镜像的标签版本,docker将默认使用 lastest 镜像!

# 可选项
-a:         #列出本地所有镜像
-q:         #只显示镜像id
--digests:  #显示镜像的摘要信息

[root@localhost ~]# docker images --digests
REPOSITORY    TAG                DIGEST                                                                    IMAGE ID       CREATED         SIZE
tomcat        latest             sha256:9dee185c3b161cdfede1f5e35e8b56ebc9de88ed3a79526939701f3537a52324   fb5657adc892   19 months ago   680MB
hello-world   latest             sha256:2498fce14358aa50ead0cc6c19990fc6ff866ce72aeb5546e1d59caac3d0d60f   feb5d9fea6a5   22 months ago   13.3kB
redis         5.0.9-alpine3.11   sha256:83a3af36d5e57f2901b4783c313720e5fa3ecf0424ba86ad9775e06a9a5e35d0   3661c84ee9d0   3 years ago     29.8MB

[root@localhost ~]# docker images -q
fb5657adc892
feb5d9fea6a5
3661c84ee9d0

[root@localhost ~]# docker images -a
REPOSITORY    TAG                IMAGE ID       CREATED         SIZE
tomcat        latest             fb5657adc892   19 months ago   680MB
hello-world   latest             feb5d9fea6a5   22 months ago   13.3kB
redis         5.0.9-alpine3.11   3661c84ee9d0   3 years ago     29.8MB

2、docker search

# 搜索镜像
[root@localhost ~]# docker search mysql
NAME                            DESCRIPTION                                     STARS     OFFICIAL   AUTOMATED
mysql                           MySQL is a widely used, open-source relation…   14318     [OK]       

# docker search 某个镜像的名称 对应 DockerHub 仓库中的镜像

# 可选项
--filter   # 添加过滤条件 

# 例如,列出收藏数不小于50的镜像
[root@localhost ~]# docker search mysql --filter=stars=50
NAME                          DESCRIPTION                                     STARS     OFFICIAL   AUTOMATED
mysql                         MySQL is a widely used, open-source relation…   14318     [OK]       
mariadb                       MariaDB Server is a high performing open sou…   5466      [OK]  

3、docker pull

# 下载镜像
[root@localhost ~]# docker pull mysql
Using default tag: latest  # 不写tag,默认是latest
latest: Pulling from library/mysql
72a69066d2fe: Pull complete # 分层下载
93619dbc5b36: Pull complete 
99da31dd6142: Pull complete 
626033c43d70: Pull complete 
37d5d7efb64e: Pull complete 
ac563158d721: Pull complete 
d2ba16033dad: Pull complete 
688ba7d5c01a: Pull complete 
00e060b6d11d: Pull complete 
1c04857f594f: Pull complete 
4d7cfa90e6ea: Pull complete 
e0431212d27d: Pull complete 
Digest: sha256:e9027fe4d91c0153429607251656806cc784e914937271037f7738bd5b8e7709 #签名
Status: Downloaded newer image for mysql:latest
docker.io/library/mysql:latest # 真实位置

# 指定版本下载
docker pull mysql:5.7

4、docker rmi

# 删除镜像

docker rmi -f 镜像id                 # 删除单个

docker rmi -f 镜像名:tag 镜像名:tag   # 删除多个

docker rmi -f $(docker images -qa)   # 删除全部

三、容器命令

1、说明:

        有镜像才可以创建容器,我们这里使用 centos 的镜像来测试,就是虚拟一个 centos  

2、新建容器并启动

# 命令
docker run [OPTIONS] IMAGE [COMMAND][ARG...]

# 参数说明
--name="Name"    # 给容器指定一个名字
--rm             # 容器运行完后自动删除,常用于测试
-d               # 后台方式运行容器,并返回容器的id!
-i               # 以交互模式运行容器,通过和 -t 一起使用
-t               # 给容器重新分配一个终端,通常和 -i 一起使用
-P               # 随机端口映射(大写的)
-p               # 指定端口映射(小写的),一般可以有四种写法

    ip:hostPort:containerPort
    ip::containerPort
    hostPort:containerPort (常用)
    containerPort

# 测试
root@localhost ~]# docker images
REPOSITORY   TAG                IMAGE ID       CREATED         SIZE
centos       latest             5d0da3dc9764   22 months ago   231MB

# 使用 centos 进行用交互模式启动容器,在容器内执行 /bin/bash 命令!
[root@localhost ~]# docker run -it centos /bin/bash
[root@edbcb429be0a /]# ls       # 注意地址,已经切换到容器内部了!
bin  dev  etc  home  lib  lib64  lost+found  media  mnt  opt  proc  root  run  sbin  srv  sys  tmp  usr  var
[root@edbcb429be0a /]# exit     # 使用 exit 退出容器
exit
[root@localhost ~]# 

3、列出所有运行的容器

# 命令
docker ps [OPTIONS]

# 常用参数说明
-a              # 列出当前所有正在运行的容器 + 历史运行过的容器
-l              # 显示最近创建的容器
-n=?            # 显示最近 n 个创建的容器
-q              # 静默模式,只显示容器编号。

4、退出容器

exit       # 容器停止退出
ctrl+P+Q   # 容器不停止退出

5、启动停止容器

docker start (容器id or 容器名)       # 启动容器
docker restart (容器id or 容器名)     # 重启容器
docker stop (容器id or 容器名)        # 停止容器
docker kill (容器id or 容器名)        # 强制停止容器

6、删除容器

docker rm 容器id                  # 删除指定容器
docker rm -f $(docker ps -a -q)   # 删除所有容器
docker ps -a -q|xargs docker rm   # 删除所有容器

四、常用的其他命令

1、后台启动容器

# 命令
docker run -d 容器名

# 例子
docker run -d centos # 启动 centos,使用后台方式启动

# 问题: 执行完上面的命令之后,使用 docker ps 查看,发现容器已经退出了!

# 解释:Docker 容器后台运行,就必须有一个前台进程,容器运行的命令如果不是那些一直挂起的命令,就会自动退出。比如,你运行了 nginx 服务,但是 docker 前台没有运行应用,这种情况下,容器启动后,会立即自杀,因为他觉得没有程序了,所以最好的情况是,将你的应用使用前台进程的方式运行启动。

2、查看日志

# 命令
docker logs -f -t --tail 容器id

# 例子:我们启动 centos,并编写一段脚本来测试玩玩!最后查看日志
[root@localhost ~]# docker run -d centos /bin/sh -c "while true;do echo xiehongfa;sleep 1;done"
b35619c3bc816792a41ec1819e2e53f0a9083e704c447a013ccc20cc1adc4400

[root@localhost ~]# docker ps
CONTAINER ID   IMAGE          COMMAND                  CREATED         STATUS         PORTS      NAMES
b35619c3bc81   centos         "/bin/sh -c 'while t…"   5 seconds ago   Up 2 seconds              romantic_franklin

# -t 显示时间戳
# -f 打印最新的日志
# --tail 数字 显示多少条!
[root@localhost ~]# docker logs -tf --tail 10 b35619c3bc81
2023-07-17T07:06:41.838803186Z xiehongfa
2023-07-17T07:06:42.841671087Z xiehongfa
2023-07-17T07:06:43.850473533Z xiehongfa
2023-07-17T07:06:44.854418248Z xiehongfa
2023-07-17T07:06:45.870002130Z xiehongfa
2023-07-17T07:06:46.872969709Z xiehongfa
2023-07-17T07:06:47.886184666Z xiehongfa
2023-07-17T07:06:48.908353181Z xiehongfa
2023-07-17T07:06:49.928598724Z xiehongfa

3、查看容器中运行的进程信息,支持 ps 命令参数。

# 命令
docker top 容器id

# 测试
[root@localhost ~]#  docker top b35619c3bc81
UID                 PID                 PPID                C                   STIME               TTY                 TIME                CMD
root                45743               45724               0                   00:05               ?                   00:00:00            /bin/sh -c while true;do echo xiehongfa;sleep 1;done

4、查看容器/镜像的元数据

# 命令
docker inspect 容器id

# 测试
[root@localhost ~]#  docker inspect b35619c3bc81
[
    {   # 完整的id,上面的容器 id,就是截取的这个 id 前几位!
        "Id": "b35619c3bc816792a41ec1819e2e53f0a9083e704c447a013ccc20cc1adc4400",
        "Created": "2023-07-17T07:05:17.618492301Z",
        "Path": "/bin/sh",
        "Args": [
            "-c",
            "while true;do echo xiehongfa;sleep 1;done"
        ],
        "State": {
            "Status": "running",
            "Running": true,
            "Paused": false,
            "Restarting": false,
            "OOMKilled": false,
            "Dead": false,
            "Pid": 45743,
            "ExitCode": 0,
            "Error": "",
            "StartedAt": "2023-07-17T07:05:19.961478876Z",
            "FinishedAt": "0001-01-01T00:00:00Z"
        },
       // .......................................

5、进入正在运行的容器

# 命令1
docker exec -it 容器id bashShell

# 测试1
[root@localhost ~]# docker ps
CONTAINER ID   IMAGE          COMMAND                  CREATED         STATUS         PORTS      NAMES
b35619c3bc81   centos         "/bin/sh -c 'while t…"   6 minutes ago   Up 6 minutes              romantic_franklin
[root@localhost ~]# docker exec -it b35619c3bc81 /bin/bash
[root@b35619c3bc81 /]# ps -ef
UID         PID   PPID  C STIME TTY          TIME CMD
root          1      0  0 07:05 ?        00:00:00 /bin/sh -c while true;do echo xiehongfa;sleep 1;done
root        447      0  1 07:12 pts/0    00:00:00 /bin/bash
root        471      1  0 07:12 ?        00:00:00 /usr/bin/coreutils --coreutils-prog-shebang=sleep /usr/bin/sleep 1
root        472    447  0 07:12 pts/0    00:00:00 ps -ef

# 命令2
docker attach 容器id

# 测试2
[root@localhost ~]# docker attach b35619c3bc81 
xiehongfa
xiehongfa
xiehongfa
xiehongfa
xiehongfa
xiehongfa
xiehongfa

# 区别
# exec 是在容器中打开新的终端,并且可以启动新的进程
# attach 直接进入容器启动命令的终端,不会启动新的进程

6、从容器内拷贝文件到主机上

# 命令
docker cp 容器id:容器内路径 宿主机路径


# 测试
# 容器内执行,创建一个文件测试
[root@localhost ~]# docker exec -it b35619c3bc81 bash
[root@b35619c3bc81 /]# cd /home/
[root@b35619c3bc81 home]# touch xhf
[root@b35619c3bc81 home]# ls
xhf
[root@b35619c3bc81 home]# exit
exit

# 在 linux 查看,看是否复制成功
[root@localhost ~]# docker cp b35619c3bc81:/home/xhf /home
Successfully copied 1.54kB to /home
[root@localhost ~]# cd /home/
[root@localhost home]# ls
tansun  xhf

四、小节

Docker 进入容器和交换文件文章来源地址https://www.toymoban.com/news/detail-497919.html

五、常用命令总结

# 当前 shell 下 attach 连接指定运行镜像
attach 

# 通过 Dockerfile 定制镜像
build  

# 提交当前容器为新的镜像
commit  

#从容器中拷贝指定文件或者目录到宿主机中
cp 

# 创建一个新的容器,同run,但不启动容器
create  

# 查看 docker 容器变化
diff

# 从 docker 服务获取容器实时事件
events  

# 在已存在的容器上运行命令
exec 

# 导出容器的内容流作为一个 tar 归档文件[对应 import ]
export 

# 展示一个镜像形成历史
history 

# 列出系统当前镜像
images List images

# 从tar包中的内容创建一个新的文件系统映像[对应export]
import 

# 显示系统相关信息
info 

# 查看容器详细信息
inspect 

# kill 指定 docker 容器
kill 

# 从一个 tar 包中加载一个镜像[对应 save]
load 

# 注册或者登陆一个docker 源服务器
login 

# 从当前 Docker registry 退出
logout 

# 输出当前容器日志信息
logs 

# 查看映射端口对应的容器内部源端口
port 

# 暂停容器
pause 

# 列出容器列表
ps 

# 从docker镜像源服务器拉取指定镜像或者库镜像
pull 

# 推送指定镜像或者库镜像至docker源服务器
push 

# 重启运行的容器
restart 

# 移除一个或者多个容器
rm 

# 移除一个或多个镜像[无容器使用该镜像才可删除,否则需删除相关容器才可继续或 -f 强制删除]
rmi 

# 创建一个新的容器并运行一个命令
run 

# 保存一个镜像为一个 tar 包[对应 load]
save 

# 在 docker hub 中搜索镜像
search 

# 启动容器
start 

# 停止容器
stop 

# 给源中镜像打标签
tag 

# 查看容器中运行的进程信息
top 

# 取消暂停容器
unpause 

# 查看 docker 版本号
version 

# 截取容器停止时的退出状态值
wait 

到了这里,关于Docker 进入容器和交换文件的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包赞助服务器费用

相关文章

  • 基于docker-compsoe.yml配置mysql8.0主从 (需要进入主从容器执行命令)

    主my.cnf文件 从my.cnf文件 主要的yml配置 主容器的操作 进入主mysql容器 3306端口的 docker exec -it 容器id /bin/bash 登录mysql mysql -uroot -p 创建主从复制的账号 - 创建用户slave,密码123456 CREATE USER \\\'slave\\\'@\\\'%\\\' IDENTIFIED BY \\\'123456\\\'; 授权主从复制 GRANT REPLICATION SLAVE, REPLICATION CLIENT ON *.* TO \\\'slave\\\'@

    2024年02月16日
    浏览(46)
  • Docker cp命令详解:在Docker容器和主机之间复制文件/文件夹

    Docker cp命令详解:在Docker容器和主机之间复制文件/文件夹

    简介 Docker是一种流行的容器化平台,它允许开发人员在独立、可移植的环境中构建、打包和部署应用程序。在使用Docker时,常常需要在Docker容器和主机之间进行文件的复制和共享。Docker提供了一个名为 docker cp 的命令,可以轻松地在容器和主机之间复制文件和目录。本文将详

    2024年03月23日
    浏览(63)
  • docker cp命令: 主机和Docker容器之间复制文件或目录

    docker cp命令是用于在主机和Docker容器之间复制文件或目录的命令。可以从容器复制文件到主机,也可以从主机复制文件到容器。 使用docker cp命令的基本语法如下: 例如,要将容器内的文件复制到主机上: 要将主机上的文件复制到容器内: 复制目录也是一样的命令 备注 :

    2024年04月29日
    浏览(49)
  • Docker:进入容器(处于后台运行的容器)

    Docker:进入容器(处于后台运行的容器)

    容器启动时如果指定了-d参数,在后台运行容器,或者通过docker start重启已经停止的容器 可以通过以下两种方法进入容器: 1.docker attach 容器ID 注:使用attach进入容器后,如果在容器中执行exit或ctrl+d,会停止容器 2.docker exec -it 容器ID /bin/bash 注:通过这种方式进入容器后,如

    2024年02月11日
    浏览(11)
  • 软件测试|Docker cp命令详解:在Docker容器和主机之间复制文件/文件夹

    软件测试|Docker cp命令详解:在Docker容器和主机之间复制文件/文件夹

    简介 Docker是一种流行的容器化平台,它允许开发人员在独立、可移植的环境中构建、打包和部署应用程序。在使用Docker时,常常需要在Docker容器和主机之间进行文件的复制和共享。Docker提供了一个名为 docker cp 的命令,可以轻松地在容器和主机之间复制文件和目录。本文将详

    2024年02月12日
    浏览(66)
  • 【Docker 】Docker 客户端,容器使用,启动容器,启动已停止运行的容器,停止一个容器,进入容器

    【Docker 】Docker 客户端,容器使用,启动容器,启动已停止运行的容器,停止一个容器,进入容器

    作者简介: 辭七七,目前大一,正在学习C/C++,Java,Python等 作者主页: 七七的个人主页 文章收录专栏: 七七的闲谈 欢迎大家点赞 👍 收藏 ⭐ 加关注哦!💖💖 docker 客户端非常简单 ,我们可以直接输入 docker 命令来查看到 Docker 客户端的所有命令选项。 可以通过命令 dock

    2024年02月11日
    浏览(33)
  • 使用Docker容器配置ssh服务,远程直接进入容器

    最终版 hub仓库 https://hub.docker.com/ 目录 hub仓库 docker命令 镜像 查看所有镜像 运行镜像 容器 查看所有容器 可以在当前终端挂载 停止容器 删除容器s 使用容器 Docker使用镜像配置ssh服务后用ssh登陆 1. 先上dockerhub上pull一个需要的镜像下来,然后run这个镜像生成一个容器。 2. 进入

    2024年02月08日
    浏览(10)
  • Docker使用root用户进入容器

    -u 0 使用该 -u 选项时,您可以使用 root 用户( ID = 0 )而不是提供的默认用户登录Docker容器. root(id = 0)是容器中的默认用户。图像开发人员可以创建其他用户。这些用户可以通过名称访问。传递数字ID时,用户不必在容器中。

    2024年02月12日
    浏览(10)
  • 使用Vscode连接进入docker容器

    使用Vscode连接进入docker容器 在使用Vscode连接远程服务器进行操作时,使用Vscode丰富的插件进行,使用Remote-SSH连接服务器,但是该插件进行连接是不能进入到docker容器内部进行操作。想要直接进入到容器内部进行工作需要另外的方法。 方法一:使用ssh工具进行连接,容器在运

    2024年02月16日
    浏览(10)
  • Docker容器进入的4种方式

    Docker容器进入的4种方式

    在使用Docker创建了容器之后,大家比较关心的就是如何进入该容器了,其实进入Docker容器有好几多种方式,这里我们就讲一下常用的几种进入Docker容器的方法。 进入Docker容器比较常见的几种做法如下: 使用docker attach 使用SSH 使用insenter 使用exec Docker提供了attach命令来进入Do

    2024年02月13日
    浏览(13)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包