博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
【03】循序渐进学 docker:基础命令
阅读量:6260 次
发布时间:2019-06-22

本文共 3200 字,大约阅读时间需要 10 分钟。

写在前面的话

 

之前谈了啥是 docker 和怎么安装 docker,这里就谈谈 docker 命令的使用,当然,这里的使用可能只是局限于 docker 的增删查改。

另外需要注意的是,为了图片的美观,接下来的截图有些图片可能是经过我处理过的,只保留了重要的内容,所有如果你发现和我的结果不一致,也不需要担心,是那个意思就行。

 

 

镜像命令

 

【1】万物起源于 Hello world,运行第一个容器:

docker run hello-world

输出如图:

这是一个类似于 demo 容器,docker 先会在本地查找对应的镜像,如果镜像存在,则直接运行,如果镜像不存在,则去 docker hub 上面下载镜像,然后再运行~

 

【2】搜索镜像:这里以 nginx 镜像为例

docker search nginx

输出如图:

我们可以看到,名字为顶层,没有用户名区隔的项目一般都是官方的,从后面的 OFFICIAL 也可看出来,第一个是 Nginx 官方的镜像,用户自己制作上传的镜像都是以 用户或者组织名称/项目名称 这样命名的~

当然,我们也可以去 docker hub 上面查看搜索有哪些镜像:

https://hub.docker.com/

搜索结果如图:

点进去可以在 TAGS 选项中查看需要的版本:

 

【3】下载镜像:我们这里以下载 CentOS 的镜像为例

docker pull centos

自动从 docker hub 上面去下载最新版本的 CentOS 镜像,当然,既然可以在 dcoker hub 上面看到这么多版本,就意味着可以选中其他版本,比如下载 nginx 的 1.14-alpine 版本:

docker pull nginx:1.14-alpine

只需加个冒号,在后面加版本名称即可:

从下载过程可以看出 docker 镜像的明显特征:镜像分层,然后复用,最大可能节省资源占用~

同时,在这里可以谈谈另外一个概念:在老版本的 docker 中,命令是没做区分的,比如下载镜像就是直接 docker pull,但新版本中,慢慢的这些都被规范了起来~

也希望大家跟着规范起来,通过 docker --help 查看,可以看到命令为了几类,其中很重要一类就是管理命令:

我们一开始需要记住的主要包括:image,container,network,volume

新的命令方式为:

docker image pull busybox

 

【4】查看镜像:

# 旧方法docker images# 新方法docker image ls

结果如图:

donker 镜像都很小,CentOS 的镜像也才 202M。

 

【5】删除镜像:

# 旧方法docker rmi nginx:1.14-alpine# 新方法docker image rm nginx:1.14-alpine

结果如图:

 

【6】查看镜像详细信息:

docker image inspect busybox

返回一个 json 数据,具体内容都在里面,感兴趣的可以看下。

 

【7】查看镜像占用的磁盘:

docker system df

结果如图:

 

 

容器命令

 

【1】查看现在运行的容器:

# 查看正在运行的容器docker container ps# 查看所有容器docker container ps -a# 另外一种查看方式docker container ls# 另一种查看所有容器docker container ls -a

结果如图:

 

【2】带参数创建容器:

docker container create -it --name b1 busybox

--name:指定容器名称,这里以 busybox 镜像创建一个名为 b1 的容器。

-i:指的是交互式操作,--interactive 的简写。

-t:--tty 的缩写,代表打开一个终端。

效果如图: 

返回一串随机生成的 ID,这个 ID 是容器的唯一标识,可以通过上面的命令可以查看该容器:

可以看到此时 b1 容器的状态是 create 状态,其中 CONTAINER ID 就是刚返回的 ID 的前部分。

由此可知:创建容器有两种方式,一是 docker run 创建,另一个就是 docker container create 创建。

另外,还有一些常见的参数:

--rm,指该容器停止以后自动删除。

--restart,重启规则,配置参数:

on-failure:容器停止时报错了则重启,但是重启 docker 不会重启。

unless-stopped:容器停止,如果没有报错就重启,重启 docker 一般会跟着重启。

always:无论如何至于停止就重启。

 

【3】启动,关闭,暂停,继续运行容器:

# 启动容器docker container start b1# 停止容器docker container stop b1# 暂停容器docker container pause b1# 继续运行docker container unpause b1

如图所示:

注意,因为给容器命名了,所以可以直接通过容器名进行操作,只要能唯一标识这个容器就行。

 

【4】进入容器内部:

进入容器一般有两种方法,第一种:

docker container attach b1

结果如图:

值得注意的是,这种方法在退出容器的时候需要使用:按住 Ctrl,再按 p,再按 q

如果直接 exit 则会导致在退出容器以后,容器也停止退出。

第二种方法:

docker container exec -it b1 /bin/sh

这种方法可以直接 exit 退出容器,且保持继续运行。

当然,在创建容器的时候,也跟了参数 -it,这意味着在最后加上 /bin/sh 是可以在容器创建完成以后直接进入容器的:

docker run -it --name b2 busybox /bin/sh

结果如图:

但是这种方式有个问题,那就是我们以 /bin/sh 替代原本容器种运行的进程,那么在我们 exit 以后,就相当于退出了 sh 进程,这样导致的结果就是容器也跟着停止了。

为了便于管理,在每个容器之中一般只允许一个进程也就是业务进程运行。所以容器落实到最后更像一个服务在运行。

 

【5】删除容器:

# 旧方法docker rm b2# 新方法docker container rm b2

直接 rm 就删除了,当然,一般 docker 命令后面如果不接 container 命令也能直接对容器进行操作,但如之前所说,一切都是为了规范。

 

【6】查看容器详情:

docker container inspect b1

其中有几个参数很重要,包括 IP 地址,数据保留在宿主机中的位置等等。

 

【7】查看容器的日志:

docker container logs b1

 

【8】 批量操作容器:这里就不具体演示了,大家知道就行,格式就这样

# 删除所有容器docker container rm $(docker container ls -aq)# 删除所有 redis 镜像docker image rm $(docker image ls -aq redis)# 删除所有在 mongo:3.2 之前的镜像docker image rm $(docker image ls -aq -f before=mongo:3.2)

 

 

小结 

 

以上是目前得记住的基础命令,至于其他命令,会在后面的章节进行单独的讲解,那时候将会是更深层次的应用,如果你觉得还不错,可以先点 推荐 试试~ 

转载于:https://www.cnblogs.com/Dy1an/p/10599263.html

你可能感兴趣的文章
最佳在线图表软件
查看>>
Work with Alexa : 智能设备连接到Alexa
查看>>
[sublime系列文章] sublime text 3构建系统
查看>>
995. Minimum Number of K Consecutive Bit Flips
查看>>
for-loop 与 json.Unmarshal 性能分析概要
查看>>
C++中new的三种使用方法说明
查看>>
爬虫进阶 -- 神级程序员:让你的爬虫就像人类的用户行为!
查看>>
Python中_new_方法详解及使用
查看>>
flutter安装开发环境-问题记录
查看>>
mp4文件如何转换为webm格式
查看>>
如何在线创建数据流图(DFD)?
查看>>
腾讯—最新iOS面试题总结
查看>>
CGI,FASTCGI,PHP-CGI,PHP-FPM 概念
查看>>
DApp引荐机制正式上线 | IOST开发者赏金计划
查看>>
【剑指offer】9.二进制中1的个数
查看>>
GIF动画解析RNN,LSTM,GRU
查看>>
前端:开发规范
查看>>
《剑指offer》11.链表中倒数第k个节点
查看>>
老旧话题:重新看看当年感觉很难的session
查看>>
python设计模式-外观模式
查看>>