一文拿捏各种docker命令

前言:

        上一篇讲解了centos,ubantu安装docker,下面就讲解工作种常用docker命令,以及如何使用,命令代表什么含义,下面先理解基础概念。

1.镜像(image):

        镜像是用于创建容器的静态模板或快照,包含了运行某个软件所需的所有内容,如代码、运行时环境、系统工具、系统库以及设置。

通俗理解:例如星巴克,瑞辛咖啡,它们都有一个制作咖啡的“配方”或“模板”。这个配方包含了制作咖啡所需的所有原料和以及步骤,以及如何将它们组合在一起的详细指南。那这个配方就像是docker镜像。它是静态的,不会改变(除非你决定修改配方),并且可以用来制作多个相同口味的咖啡。

2.容器(container):

        容器是从镜像创建的运行实例,是一个独立、隔离的运行单元;容器包含了应用程序及其所有运行时所需的文件系统、环境变量、进程、网络配置等;容器是动态的,可以启动、停止、删除,并且可以对容器进行修改和更新(但这些修改不会影响到镜像本身)。

通俗理解:利用上面镜像的例子,现在有了制作咖啡配方,那我们按照配方上原料和步骤,制作一杯咖啡。那其实这杯咖啡就是从咖啡配方配方(镜像)创建出来的具体实例。它是动态的,可以被享用(运行),也可以被丢弃(删除)。还可以使用同一个配方(镜像)来制作多个相同口味的咖啡(容器),每个咖啡(容器)都是独立的,并且可以根据你的口味进行微调(配置)。

3.仓库(repository):

        仓库就是存放镜像的地方,仓库分为公有仓库和私有仓库。(类似git,svn)。

一:帮助命令

1.显示docker的版本信息

#显示Docker客户端和服务端的版本信息

docker version

17d06ae5747c4b5cb77ae673ef7e213d.png

2.显示docker的系统信息

#显示Docker的系统级信息,包括当前的镜像和容器数量

docker info

546aa3740bb94e42842df3c4e42c24ed.png

3.帮助命令

docker --help

4dc7cce338a24421962f5361358a11bc.png

二:镜像

1.查询镜像

docker search  名称 

例如 docker search java,会搜索所有包含java的镜像。

2.拉取镜像

docker pull  镜像名称

例如 docker pull mysql,会从Docker Hub下载java最新版镜像。

3. 上传镜像仓库

docker push 镜像名称[:tag]

例如,docker push test:v0.0.1,会将本地镜像test:v0.0.1上传到镜像仓库中。 

4.查询所有镜像

dokcer images

e49e90bc9d974cd8835ed7fde8797500.png

5.删除镜像

docker rmi  镜像名称/镜像id

 例如,docker rmi docker-demo:v0.0.1会删除名为镜像名称docker-demo,tag为0.0.1本地镜像。

e03345c4dbb3419381bead077a8e4e9c.png

6.构建镜像(使用Dockerfile创建镜像)

 docker build -t  自定义镜像名称 .

例如:在当前/home/dev/demo目录下将jar打成镜像,目录下需要有docker-demo.jar,Dockerfile文件。下面构建一个名为docker-demo,标签为v0.0.5的镜像。

docker build -t docker-demo:v0.0.5 .

 c31cae4fa0224c44bcd07c43a319a13a.png

6.镜像打压缩包

#将一个或多个Docker镜像保存到一个tar归档文件中。

docker save -o(或者>)  镜像:tag

例如:将一个名为docker-demo,标签为v0.0.5的镜像,保存到一个docker-demo.tar归档文件。

1cd1bc45b2d740fea160b50ab87874af.png

 7.加载压缩包镜像

docker load -i  镜像压缩包.tar

例如:加载一个名为docker-demo,标签为v0.0.5的镜像tar。

bbea34944d74444d8fc29f9a1a65a231.png

三:容器

容器是基于镜像创建出来的,所有需要镜像才可以创建容器。

1.创建容器

例如:基于docker-demo,标签为 v0.0.3镜像,创建 一个名为docker-demo容器。

docker run 

        -d                                  #后台运行

        --name docker-demo    #容器名称

        -p 8001:8001                #容器与虚拟机端口映射

        docker-demo:v0.0.3     #镜像

391cbd9163d34c8092b7191359e57896.png

2.查看容器

#查看所有容器(包含启动的容器与没启动的容器)

docker ps -a

edbcd1d04f2343ebb526d77909d19a02.png

#查看正在运行中的容器

docker ps

bc6f158964f4445291b152b7daff83cf.png

3.启动容器

docker start 容器id/容器名称

例如,docker start docker-demo:v0.0.3,会启动名为docker-demo,标签为 v0.0.3容器。 

984a703d83db456194dc57dff7610c41.png

4.停止容器

docker stop 容器id/容器名称

例如,docker stop docker-demo:v0.0.3,会停止名为docker-demo,标签为 v0.0.3容器。  

d6ca3d19a2794af7a97be749ffcdc155.png

5.重启容器

docker restart 容器id/容器名称

 例如,docker restart docker-demo:v0.0.3,会重启为docker-demo,标签为 v0.0.3容器。  

acccb3ac6a034469ac63cc0960809664.png

6.删除容器

#删除指定的容器,不能删除正在运行的容器

docker rm 容器id

 例如,docker rm docker-demo:v0.0.3,会删除为docker-demo,标签为 v0.0.3容器。

e129d5c271b144f8ad5ef51359aec916.png

#如果要强制删除

docker rm -f  容器id

例如,docker rm -f docker-demo:v0.0.3,会强制删除为docker-demo,标签为 v0.0.3容器。

4eed02481a524efeaf0a50601fe1af5c.png

#删除所有的容器

docker ps -a -q|xargs docker rm 

 这里不演示删除所有的容器了!!!

7.进入容器

#进入容器会开出新的终端

docker exec -it  容器id  /bin/bash

439c1ecb268a41a6b1fd670988ac1555.png

#容器直接退出

exit

72f7218367f64a07a65e94a3713207b0.png

#允许用户附加到正在运行的容器并与其交互

docker attach 容器id  

 ab093e38c9674041a0b8c63bc546ba0a.png

#容器不停止退出 

ctrl +P +Q

使用 Ctrl+P+Q 可以从 docker attach 会话中分离出来,而不会停止容器的运行。而使用 exit 命令或 Ctrl+D 将会停止容器的运行。

8.查看元数据

#获取容器对象(容器、镜像、卷、网络等)的详细信息

docker inspect 镜像id/镜像名称

89f8320ad134400996173d9100b45cbb.png

四:日志

docker logs [Options] 容器id/容器名称


  Options:

  • -f 或 --follow:实时跟踪容器的日志输出,类似于 tail -f
  • -t 或 --timestamps:在日志输出中显示时间戳。
  • --since:显示自指定时间以来的日志,格式为 2023-04-01T12:00:00 或者相对时间(例如 4m 表示 4 分钟前)。
  • --tail:显示日志的最后几行,默认为 all

1.查看日志

docker logs -f  容器id/容器名称

6a4800e6d04a453fbe6ff410faa2dd38.png

2.实时查看10 行日志:

docker logs -f --tail 10 容器id/容器名称

974cc1a0408c468d863429b173602c59.png

3.查看自10 分钟前的日志:

docker logs --since 10m  容器id/容器名称

502032bd997c4066bdb4a82270e8d486.png

4.查看最后 10 行日志:

docker logs --tail 10 容器id/容器名称

0299657ddea440c882a1604b5f697bdb.png

五:拷贝

1.容器中文件拷贝到宿主机

docker cp <容器ID或名称>:<容器内路径>  <宿主机路径>

例如,将名为docker-demo的容器中的/test.txt文件拷贝到宿主机的/data目录下。

演示:进入容器创建test.txt文件

6b93595407604341ac4edce2696bc2c3.png

使用命令

docker cp  docker-demo:/test.txt  /data

6110b558599a43269dc76f1610933c96.png

2.宿主机文件拷贝到容器中

docker cp  <宿主机路径>  <容器ID或名称>:<容器内路径>

例如,将宿主机的/data目录下test1.txt拷贝到名为docker-demo的容器中

演示:宿主机的/data目录下创建test1.txt

556337e488714aee893bdacc4246e108.png

使用命令

docker cp  /data/test1.txt   docker-demo:/

b159299873764f459fa2b807d426defe.png

六:数据卷

1.定义:

        Docker数据卷是一个可用于持久化存储数据的特殊目录或文件。这些数据卷可以绕过容器的文件系统,直接存储在宿主机的文件系统中,或者在某些情况下,也可以存储在远程存储设备上。数据卷的设计目的就是为了解决容器数据的持久化和共享问题。

  • 持久性:数据卷的内容在容器重启后仍然存在,不会因为容器的删除而丢失。如数据库、日志系统等,可以使用数据卷来保存数据。
  • 共享性:多个容器可以挂载同一个数据卷,实现数据的共享和通信。
  • 独立于容器生命周期:数据卷的生命周期独立于容器的生命周期,即使容器被删除,数据卷也会保留下来。
  • 高效性:数据卷直接在宿主机的文件系统中存储,因此访问速度较快,且不会占用容器的存储空间。
  • 数据备份和恢复:通过将数据卷备份到远程存储或另一个容器中,可以实现数据的备份和恢复操作。
  • 数据迁移:使用数据卷可以方便地将容器的数据迁移到另一个环境或主机上,而无需重新构建或复制整个容器。

注意事项

  1. 数据一致性:当多个容器挂载同一个数据卷时,需要确保数据的一致性,避免数据冲突。
  2. 权限问题:在挂载数据卷时,需要注意容器和宿主机之间的权限问题,确保容器能够正确访问数据卷。
  3. 备份和恢复:定期备份数据卷中的数据,以防止数据丢失或损坏。

2.创建数据卷

docker volume create  数据卷名称

例如:创建数据卷名为my-volume 

14b1f5a4f0784256b225f3c94c33d239.png

3.查看数据卷

docker volume ls

0eb095c9667f4a26b271aa321651603c.png

4.挂载数据卷

在创建容器时,可以使用-v--mount选项将数据卷挂载到容器的指定目录上。

例如:创建一个mariadb数据库容器

#创建容器,并挂载数据卷 -v
docker run  
        --restart=always 
        -d  
        --name mariadb-volume   
        -v /home/mariadb/mariadb.cnf:/etc/mysql/mariadb.cnf  
        -v /home/mariadb/data:/var/lib/mysql
        -v /home/mariadb/log:/var/log
        -p 3306:3306 
        -e MYSQL_ROOT_PASSWORD=123456  
        mariadb
 

#解释

--restart=always  表示始终运行的服务

-d                        表示后台运行

--name                表示容器名称

-v                        表示挂载

-p                        表示容器端口与宿主机绑定

335d46b8761740749008bca377916657.png

宿主机与容器挂载之后:(持久化)数据就不怕丢失了

4066410aab464bcaa2449a1cc4d52058.png

5.删除数据卷

#注意:如果数据卷正在被容器使用,则无法删除)。

docker volume rm  数据卷名称

七:网络

        Docker 网络是 Docker 容器之间进行通信的桥梁,也是容器与外部网络进行交互的通道。Docker 提供了多种网络模式来满足不同的网络需求。

  • 1. 默认网络模式(bridge):这是 Docker 的默认网络模式。Docker 安装时会创建一个名为 docker0 的虚拟网桥,并为每个容器分配一个唯一的 IP 地址。

3a489f153f584998a3dcd573183fd8c9.png

  • 2. 主机模式(host):在这种模式下,容器直接使用宿主机的网络命名空间,与宿主机共享 IP 地址和端口。

  • 3. 自定义网络:Docker 允许用户创建自定义网络,以便在一个隔离的网络环境中连接多个容器。

1.查看所有网络

docker network ls

4f9243c22de84878960fed775f5a6155.png

2.自定义创建网络

docker network create 网络别名  

例如,docker network create test_net会创建一个名为test_net的新网络。 

19f6774714df4ec893647d574d3acc73.png

a89f137721db459688c09c94e829f240.png

3.删除指定的网络

docker network rm 网络别名

例如,docker network rm test_net会删除名为test_net的网络 。(容器正在使用,不能删除)

2ea5d6bb6af14bc6a71f610e5d583cef.png

4.查看网络的详细信息

 docker network inspect 网络别名

例如,docker network inspect test_net会查看名为test_net的网络的详细信息。 

 3b3454f6cc4647308b7ef2205ab7f128.png

5.删除所有未使用的网络

docker network prune 网络别名

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

码农小丘

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值