CentOS中Docker简单命令

371 阅读4分钟

前言

本篇将讲述Docker的一些简单命令

一、Docker简单命令

systemctl命令是系统服务管理器指令

  1. 启动Docker
systemctl start docker
  1. 停止docker
systemctl stop docker
  1. 重启Docker
systemctl restart docker
  1. 查看Docker状态
systemctl status docker
  1. 开机启动
systemctl enable docker
  1. 查看Docker概要信息
docker info

二、镜像相关命令

1. 查看镜像

[root@localhost docker]# docker images
REPOSITORY          TAG                 IMAGE ID            CREATED             SIZE
acktsw/centos       latest              9d4fa8bebcc8        10 months ago       284MB

REPOSITORY:镜像名称

TAG:镜像标签

IMAGE ID:镜像ID

CREATED:镜像的创建日期(不是获取该镜像的日期)

SIZE:镜像大小

这些镜像都是存储在Docker宿主机的/var/lib/docker目录下

2. 搜索镜像

如果你需要从网络中查找需要的镜像,可以通过以下命令搜索

docker search 镜像名称

示例

Docker-base01.png

NAME:仓库名称

DESCRIPTION:镜像描述

STARS:用户评价,反应一个镜像的受欢迎程度

OFFICIAL:是否官方

AUTOMATED:自动构建,表示该镜像由Docker Hub自动构建流程创建的

3. 拉取镜像

拉取镜像就是从中央仓库中下载镜像到本地

docker pull 镜像名称

示例,下载CentOS7镜像

[root@localhost docker]# docker pull centos:7

4. 删除镜像

按镜像ID删除镜像

docker rmi 镜像ID

删除所有镜像

docker rmi `docker images -q`

三、容器相关命令

1. 查看正在运行的容器

docker ps

2. 查看所有容器

docker ps -a

3. 查看最后一次运行的容器

docker ps –l

4. 查看停止的容器

docker ps -f status=exited

四、创建与启动容器

创建容器常用的参数说明:

创建容器命令:docker run

-i:表示运行容器

-t:表示容器启动后会进入其命令行。加入这两个参数后,容器创建就能登录进去。即分配一个伪终端。

--name :为创建的容器命名。

-v:表示目录映射关系(前者是宿主机目录,后者是映射到宿主机上的目录),可以使用多个-v做多个目录或文件映射。注意:最好做目录映射,在宿主机上做修改,然后共享到容器上。

-d:在run后面加上-d参数,则会创建一个守护式容器在后台运行(这样创建容器后不会自动登录容器,如果只加-i -t两个参数,创建后就会自动进去容器)。

-p:表示端口映射,前者是宿主机端口,后者是容器内的映射端口。可以使用多个-p做多个端口映射

(1)交互式方式创建容器

docker run -it --name=容器名称 镜像名称:标签 /bin/bash

这时我们通过ps命令查看,发现可以看到启动的容器,状态为启动状态

退出当前容器

exit

(2)守护式方式创建容器:

docker run -di --name=容器名称 镜像名称:标签

登录守护式容器方式:

docker exec -it 容器名称 (或者容器ID)  /bin/bash

4.1 停止和启动容器

停止容器:

docker stop 容器名称(或者容器ID)

启动容器:

docker start 容器名称(或者容器ID)

4.2 文件拷贝

如果我们需要将文件拷贝到容器内可以使用cp命令

docker cp 需要拷贝的文件或目录 容器名称:容器目录

也可以将文件从容器内拷贝出来

docker cp 容器名称:容器目录 需要拷贝的文件或目录

4.3 目录挂载

我们可以在创建容器的时候,将宿主机的目录与容器内的目录进行映射,这样我们就可以通过修改宿主机某个目录的文件从而去影响容器。

创建容器 添加-v参数 后边为 宿主机目录:容器目录,例如:

docker run -di -v /usr/local/myhtml:/usr/local/myhtml --name=mycentos3 centos:7

示例

[root@localhost ~]# docker run -di -v /usr/local/myhtml:/usr/local/myhtml --name=mycentos acktsw/centos

查看容器是否创建成功

[root@localhost ~]# docker ps
CONTAINER ID        IMAGE               COMMAND             CREATED             STATUS              PORTS               NAMES
a912a6624d27        acktsw/centos       "/bin/bash"         10 seconds ago      Up 6 seconds                            mycentos

如果你共享的是多级的目录,可能会出现权限不足的提示。

这是因为CentOS7中的安全模块selinux把权限禁掉了,我们需要添加参数 --privileged=true 来解决挂载的目录没有权限的问题

进入容器内部命令

[root@localhost ~]# docker exec-it mycentos(容器名称) /bin/bash(目录)

当宿主机上的目录被修改时,容器目录中的目录会随着同时被修改

4.4 查看容器IP地址

我们可以通过以下命令查看容器运行的各种数据

docker inspect 容器名称(容器ID) 

也可以直接执行下面的命令直接输出IP地址

docker inspect --format='{{.NetworkSettings.IPAddress}}' 容器名称(容器ID)

4.5 删除容器

删除指定的容器:

docker rm 容器名称(容器ID)