笔记:Docker、Dockerfile基础

假如想象 提交于 2020-02-20 07:51:46

Docker基本概念

镜像:镜像就是一个只读的模板。镜像可以用来创建Docker容器,一个镜像可以创建多个容器

容器:容器是用镜像创建爱你的运行实例,它可以被启动、开始、停止、删除。每个容器都是相互隔离的

镜像与容器的关系类似于对象与类

Docker 面向对象
镜像
容器 容器

仓库:仓库是集中存放镜像文件的场所

仓库(Repository)和仓库注册服务器(Registry)是有区别的。仓库注册服务器上往往存放着多个仓库,每个仓库中又包含多个镜像,每个镜像有不同的标签(tag)。仓库又分别为公开库与私有库,最大的公开库是Docker Hub。国内阿里云、网易云等

Docker安装

#1、检查内核版本,必须是3.10及以上
uname -r

#2、安装docker
yum install docker

#3、输入y确认安装

#4、启动docker
[root@localhost ~]# systemctl start docker

#查看docker版本
[root@localhost ~]# docker -v
Docker version 1.12.6, build 3e8e77d/1.12.6

#5、设置开机自启动docker
[root@localhost ~]# systemctl enable docker
Created symlink from /etc/systemd/system/multi-user.target.wants/docker.service to /usr/lib/systemd/system/docker.service.

#6、停止docker
systemctl stop docker

常用命令

#查看版本
docker version
#查看docker信息
dockerinfo
#帮助  类似于linux中的 man XXX
docker --help

docker images

#查看本地仓库中的镜像#
docker images 
#-a:列出本地所有镜像 -q:只显示镜像id --digests:显示镜像的再要信息  --no-trunc:显示完整镜像信息

docker search

#从Docker Hub仓库中搜索镜像
docker search 镜像名
#-s 收藏数不小于指定值的镜像,例docker search -s 30 tomcat 搜索点赞数大于30的tomcat镜像
#--no-trunc 显示完整的镜像描述,例docker search -s 30 --no-trunc tomcat 搜索点赞数大于30的tomcat镜像并显示详细描述信息
#--antomated 只显示antomated build类型的镜像

docker pull

#下载镜像
docker pull 镜像名称:[tag]
#tag标签省略则默认为latest

docker rmi

#删除镜像
docker rmi 镜像名或id
#-f 强制删除某个镜像 docker rmi -f tomcat:latest 删除tomcat镜像

#一次删除多个镜像
docker rmi -f 镜像名或id 镜像名或id  

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

docker run

#新建并启动容器
docker run [options] image [command][tag]
#options参数说明:
#--name=容器新名字 为容器指定一个名称
#-d 后台运行容器。并返回容器id,也即返回守护式容器
*#-i 以交互模式运行容器,通常与-t同时使用
*#-t 为容器重新分配一个伪输入终端,通常与-i同时使用
#-p 端口映射

docker ps

#列出当前正在运行的容器
docker ps [options]
#-a 列出当前所有正在运行的容器以及历史运行过的
#-l 显示最近创建的容器
#-n 显示最近n个创建的容器
#-q 静默模式,只显示容器编号
#--no-trunc 不截断输出

退出容器的两种方式

#容器停止并退出
exit

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

docker start

#启动容器
docker start 容器名或id

docker restart

#重启容器
docker restart 容器名或id

docker stop

#停止容器
docker stop 容器名或id

docker kill

#强制停止容器
docker kill 容器名或id

docker rm

#删除容器
docker rm 容器名或id #删除已经关闭的容器
docker rm -f 容器名或id #强制删除容器,包括正在运行的和已删除的
docker rm -f $(docker ps -a -q) #删除所有容器
docker rm 

docker logs

#查看容器id
docker logs -f -t --tail 容器id
#-t  : 时间戳
#-f  : 最新的日志打印
#-tail 数字 :  显示最后多少条

docker top

#查看容器内运行的进程
docker top 容器id

docker inspect

#查看容器内的细节
docker inspect 容器id

进入容器

#在容器中打开新终端,并可以启动新进程
docker exec -it 容器id bashShell

#在linux中执行容器(centos容器)中的命令,返回结果到linux中
docker exec -it 容器id ls -l /tmp

#直接进入容器启动命令的终端,不会启动新的进程
docker attach 容器id

docker cp

#从容器拷贝文件到主机上
docker cp 容器id:容器内路径 目的主机路径

容器操作示例

软件镜像(QQ安装程序)---->运行镜像---->产生一个容器(正在运行的软件,运行的QQ)

示例

#1、搜索镜像
[root@localhost ~]# docker search tomcat
#2、拉取镜像
[root@localhost ~]# docker pull tomcat
#3、根据镜像启动容器
docker run --name mytomcat -d tomcat:latest
#4、查看运行中的容器
docker ps  
#5、 停止运行中的容器
docker stop  容器的id
#6、查看所有的容器
docker ps -a
#7、启动容器
docker start 容器id
#8、删除一个容器
 docker rm 容器id
#9、启动一个做了端口映射的tomcat
[root@localhost ~]# docker run -d -p 8888:8080 tomcat
-d:后台运行
-p: 将主机的端口映射到容器的一个端口    主机端口:容器内部的端口

#10、为了演示简单关闭了linux的防火墙
service firewalld status  #查看防火墙状态
service firewalld stop   #关闭防火墙
#11、查看容器的日志
docker logs container-name/container-id

更多命令参看
https://docs.docker.com/engine/reference/commandline/docker/
可以参考每一个镜像的文档

Docker镜像

镜像是一种轻量级、可执行的独立软件包,==用来打包软件运行环境和基于运行环境开发的软件,==它包含运行某个软件所需的所有内容,包括代码,运行时、库、环境变量和配置文件。

docker底层实质为UnioFS(联合文件系统)。

UnioFS(联合文件系统):

UnioFS(联合文件系统)是一种分层、轻量级并且高性能的文件系统,它支持对文件系统的修改作为一次次提交来一层层的叠加,同时可以将不同的目录挂载到同一个虚拟文件系统下。Union文件系统是Docker镜像的基础,镜像可以通过分层来进行继承,其基础镜像(没有父镜像)可以制作各种具体的应用镜像。

特性:一次同时加载多个文件系统,但从外面看起来,只能看到一个文件系统,联合加载会把各层文件系统叠加起来,这样最终的文件系统会包含所有底层的文件和目录。

docker镜像都是只读的,当容器启动时,一个新的可写层被加载到镜像的顶部,这一层通常被称为容器层,容器层之下的都叫镜像层

docker commit

#提交容器到副本,使之称为一个新的镜像
docker commit -m="提交的描述信息" -a="作者" 容器id 要创建的目标镜像名:[标签名]

Docker容器数据卷

命令方式挂载数据卷

docker run -it -v /宿主机目录:/容器目录 [--privileged=true] 镜像名或id
docker run -it -v /myDataVolume:/dataVolumeContainer centos
#[--privileged=true]可以省略。如果不可写则加上[--privileged=true]
#将在宿主机下生成文件夹/myDataVolume,在centos容器中生成文件夹/dataVolumeContainer

docker run -it -v /宿主机目录:/容器目录:ro 镜像名或id
docker run -it -v /myDataVolume:/dataVolumeContainer:ro centos 
#加上ro后再容器中数据卷只可读

docker file添加数据卷

利用命令的方式只能添加一个数据卷,使用docker file 可以一次添加多个数据卷

案例:

1、在根目录下新建mydocker文件夹

2、创建文件,编写doccker file

#volume test
FROM centos
VOLUME ["/dataVolumeContainer1","/dataVolumeContainer2"]
CMD echo "finished,---success1"
CMD /bin/bash

3、docker build生成一个新的镜像文件

#docker build -f /dockerfile所在位置 -t 文件名 .
docker build -f /mydocker/Dockerfile -t  zzr/centos .
#执行成功后docker images可以查看到名为zzr/centos的镜像

4、启动新容器

docker run -it zzr/centos /bin/bash
#进入容器后可以查看到有两个数据卷文件dataVolumeContainer1,dataVolumeContainer2

5、本地数据卷文件

#通过docker inspect 新容器id可以发现,本地数据卷在"/var/lib/docker/volumes/"目录下
{
	"Type": "volume",
	"Name": "8bd18596447998239495f79bc1aa8a2e50f165c491c64432f9dcf30962a38d19",
"Source":"/var/lib/docker/volumes/8bd18596447998239495f79bc1aa8a2e50f165c491c64432f9dcf30962a38d19/_data",
	"Destination": "/dataVolumeContainer1",
	"Driver": "local",
	"Mode": "",
	"RW": true,
	"Propagation": ""
},
{
	"Type": "volume",
	"Name": "c5ff5670a17d6b13a381859a375270741322eb80f014555ee0e497d711b32471",
	"Source":"/var/lib/docker/volumes/c5ff5670a17d6b13a381859a375270741322eb80f014555ee0e497d711b32471/_data",
	"Destination": "/dataVolumeContainer2",
	"Driver": "local",
	"Mode": "",
	"RW": true,
	"Propagation": ""
}

容器间传递共享(–volumes-from)

命名的容器挂载数据卷,其他容器通过挂载这个(父容器)实现数据共享。挂载数据卷的容器称之为数据卷容器。

#首先生成一个centos容器dc01
docker run -it --name dc01 zzr/centos

#然后生成另一个容器dc02,“继承dc01”
docker run -it --name dc02 --volumes-from dc01 zzr/centos
#后续不管怎么继承,删除,只要还有容器,其数据就是共享的。

容器之间配置信息的传递,数据卷的生命周期一直持续到没有容器为止

Dockerfile

Dockerfile是用来构建Docker镜像的构建文件,是由一系列命令和参数构成的脚本。

Dockerfile: Dockerfile定义了进程所需要的一切东西。Dockerfile涉及的内容包括执行代码或者文件、环境变量、依赖包、运行时环境、动态链接库操作系统的发行版、服务进程和内核进程等等。

Docker镜像: 在dockerfile定义一个文件后,docker build时会产生一个Docker镜像,当运行Docker镜像时会真正开始提供服务。

Docker容器: 容器是直接提供服务的。

构建步骤:

1、编写Dockerfile文件
2、docker build
3、docker run

Dockerfile内容基础知识:

1、每条保留字指令都必须为大写字母,且后面要跟随至少一个参数
2、指令按照从上到下,顺序执行
3、#表示注释
4、每条指令都会创建一个新的镜像层,并对镜像进行提交

Dockerfile执行的大致流程:

1、docker从基础镜像运行一个容器
2、执行一条指令并对文件作出修改
3、执行类似docker commit的操作提交一个新的镜像层
4、docker再基于刚提交的新镜像运行一个新的容器
5、执行dockerfile中的吓一条指令,直到所有指令都执行完

Dockerfile体系结构(保留字指令)

FROM :基础镜像,当前镜像是基于那个镜像的

MAINTAINER :镜像维护者的姓名、邮箱地址

RUN :容器构建时需要运行的命令

EXPOSE :当前容器对外暴露的端口号

WORKDIR :指定在创建容器后,终端默认登录进来的工作目录,一个落脚点

ENV :用来在构建镜像过程中设置环境变量

ADD :将宿主机目录下的文件拷贝进镜像,且ADD命令会自动处理url和解压tar压缩包

COPY :类似ADD,拷贝文件到镜像

VOLUME :容器数据卷,用于数据保存和持久化

CMD :指定一个容器启动时需要执行的命令。(dockerfile中可以有多个CMD指令,但只有最后一个生效。CMD会被docker run之后的参数替换)

ENTRYPOINT :指定一个容器启动时需要执行的命令。(ENTRYPOINT的目的和CMD一样,但是CMD会被最后一条替换,ENTRYPOINT则是追加执行)

ONBUILD :当构建一个被继承的Dockerfile时运行命令。父镜像在被子镜像继承后,父镜像的ONBUILD触发

案例:修改centos镜像,改变其登录目录,增加工具包

1、编写dockerfile文件

FROM docker.io/centos #指定基础镜像为centos
MAINTAINER zzr<zzr946@126.com> #作者与作者邮箱
ENV MYPATH /usr/local #环境变量
WORKDIR $MYPATH #进入容器后的落脚点  引用上面定义的环境变量
RUN yum -y install vim #安装后vim工具
RUN yum -y install net-tools #安装
EXPOSE 80 #对外暴露的端口
CMD echo $MYPATH
CMD echo "uccess------OK"
CMD /bin/bash #运次那个容器后进入容器内部

2、docker build 生成新镜像

#docker build -f /dockerfile所在位置 -t 文件名:tag .
docker build -f /Docker/Dockerfile2 -t mycentos:1.0 .

3、docker run运行新镜像

docker run -it mycentos:1.0 /bin/bash

此时进入到容器后,落脚点目录为usr/local

可以使用vim编辑器

Docker安装mysql示例

1、搜索镜像

docker search mysql

2、拉取镜像

docker pull docker.io/mysql

3、运行镜像,得到mysql容器

docker run -p 12345:3306 --name mysql01 
-v /zzruse/mysql/conf:/etc/mysql/conf.d 
-v /zzruse/mysql/logs:/logs -v zzeuse/mysql/data:/var/lib/mysql #挂载数据卷 
-e MYSQL_ROOT_PASSWORD=123456 #指定root用户密码 
-d docker.io/mysql #后台运行

本地镜像推送到阿里云

$ sudo docker login --username=[用户名] registry.cn-hangzhou.aliyuncs.com

$ sudo docker tag [ImageId] registry.cn-hangzhou.aliyuncs.com/[命名空间]/[仓库]:[镜像版本号]

$ sudo docker push registry.cn-hangzhou.aliyuncs.com/[命名空间]/[仓库]:[镜像版本号]
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!