腾讯云CentOS 7.6 64位之docker的镜像和容器练习

本文使用的Docker是社区版,版本是19.03.2,这个版本是本文写时的最新版。

首先总结下容器和镜像的概念:

容器是用镜像创建的,一个镜像可以创建多个容器。没有镜像就没有容器,但是没有容器还是可以有镜像。

一般来说,一个容器就是一个应用,把应用在容器中运行称之为应用容器化

删除镜像的时候,如果由这个镜像创建的容器还存在则会删除失败。

容器和镜像的关系就是:容器是镜像的实例化的可运行实体

以下是我的练习内容:

1. 拉取镜像

docker pull centos:latest

或者按照版本拉取:docker pull centos:7.6

2. 查看所有已经拉取的镜像

docker images

3. 通过镜像启动容器并且进入其中

docker container run -it 0f3e07c0138f /bin/bash

0f3e07c0138f是你镜像的ID,通过"docker images"命令查看获得

4. 退出容器返回到主机

使用Ctrl-PQ组合键(这只是退出命令界面而已,不会杀死容器进程。)

5. 查询下当前运行中的容器情况

docker container ls

6. 连接到运行中的容器

docker container exec -it dreamy_cartwright bash

dreamy_cartwright是容器的名字,通过"docker container ls"命令查看获得

7. 销毁容器

停止容器运行:docker container stop dreamy_cartwright

删除容器:docker container rm dreamy_cartwright

查看所有状态的容器(包括停止状态的容器):docker container ls -a

没有查到说明已经被删除了

7.1 删除镜像

删除刚刚拉取的镜像:docker image rm 0f3e07c0138f

0f3e07c0138f是你镜像的ID,通过"docker images"命令查看获得

注意:

只有没有被容器使用的镜像才能被删除

也可直接删除所有没被容器使用的镜像:docker image prune -a

8. 上传并运行一个nodejs工程

上传文件首先需要安装:yum install lrzsz

如果出现是否需要安装请键盘输入Y然后回车

创建目录:mkdir -p /home/demo/nodejs-docker

下载安装SecureCRT,在SecureCRT中连接后输入:cd /home/demo/nodejs-docker

上传文件输入命令:rz

然后双击这个文件夹再点击确定,上传成功后可以使用命令查看:ls -a

安装zip解压缩软件:yum install unzip zip

执行解压命令:unzip psweb-master.zip

删除掉之前的zip文件:rm -f psweb-master.zip

备注:

nodejs工程文件及SecureCRT下载地址:https://pan.baidu.com/s/1NprxpW5LIHySWTijMByx6g 提取码:ju8e

双击SecureCRTPortable.exe可运行SecureCRT。

这个部分其实只有rz这个命令需要用到SecureCRT,其他部分我都用腾讯云自带的WebShell了。

9. 在Docker的容器中运行nodejs-demo

切换到Dockerfile所在的目录:cd /home/demo/nodejs-docker/psweb-master

打包成Docker镜像:docker image build -t test:latest .

然后使用docker image ls命令查看到有test代表就是成功了

运行镜像:docker container run -d --name web1 --publish 8080:8080 test:latest

命令行回到根目录:cd ~

10. 运行一个容器,后台运行,不进入其中

docker container run -d --name webserver -p 80:8080 \

然后再输入:nigelpoulton/pluralsight-docker-ci

-d代表后台运行

11. 删除所有容器和镜像

容器:docker container rm$(docker container ls -aq) -f

镜像:docker image rm $(docker image ls -q) -f

12. 查看容器的配置信息

docker container inspect 容器ID

13. 关于Dockerfile

这个文件包含了对这个应用的描述,并且指导Docker完成构建。

直接看Dockerfile文件里面的英文注释,那个里面写的比较清楚了。

总结下这些关键字代表的含义

FROM:应用运行在什么镜像上

LABEL:这个容器的负责人

RUN:在镜像中执行的命令

COPY:将代码复制到镜像的某个位置中

EXPOSE:记录应用使用的端口号

ENTRYPOINT:容器启动后默认运行的程序

14. docker服务操作

显示服务状态:systemctl status docker.service

列出服务层级和依赖关系:systemctl list-dependencies docker.service

启动服务:systemctl start docker.service

关闭服务:systemctl stop docker.service

重启服务:systemctl restart docker.service

设置服务自启动:systemctl enable docker.service

禁止服务自启动:systemctl disable docker.service

查看服务是否自启动:systemctl is-enabled docker.service

列出系统所有服务的启动情况:systemctl list-units --type=service

列出所有自启动服务:systemctl list-unit-files|grep enabled

一般安装好了默认就是自启动的,然后这个“.service”字符是可以省略的。

15. docker自启动

因为重启系统后docker默认是不会自己启动的,所以需要自己设置。

手动重启docker:systemctl restart docker.service

手动启动容器:docker start 95d869369f92 f6d275d686ed

docker设置为自动启动:systemctl enable docker.service

docker内的容器设置为自启动:docker update --restart=always 95d869369f92 f6d275d686ed

其中95d869369f92 f6d275d686ed是代表两个容器的id,如果只有一个就只需要写一个,多个就继续写多个。

设置完成之后可以测试一下:

重启:reboot

这个时候如果用的WebShell会断开连接,等待一会然后按任意键如果重启完成就可以连上了。

查看容器:docker container ls

这个时候命令运行成功并且能看到你的镜像代表设置自启动成功了。

如果这个命令执行失败代表docker没有设置自动,如果执行成功了但是容器是空的代表容器没有设置自启动(命令后面加-a可以看到所有包括停止运行的容器)。