docker简介
1.docker是基于go语言实现
主要目标是对对应组件的封装、分发、部署、运行等生命周期的管理,使应用程序及其运行环境能够做到“一次封装,到处运行”
2.docker为了解决运行环境和配置问题的软件容器,方便做持续集成并有助于整体发布的容器虚拟化技术
3.docker能干些什么?
- 虚拟机技术
简单理解可以在一种操作系统里面运行另外一种操作系统,比如windows中运行linux系统,常见的是vmware;缺点:占用资源,启动慢,安装步骤繁琐。 - 容器虚拟化技术
docker既是一种容器虚拟化技术,docker本身是一个容器运行载体或称之为管理引擎,我们把应用程序和配置依赖打包好形成一个可交付的运行环境,这个打包好的运行环境就是镜像文件,只有通过这个镜像文件才能生成docker容器。docker 根据 image 镜像文件生成容器实例。同一个image文件可以生成多个同时运行的容器实例。 - docker 架构
docker使用
docker 初体验
新建并启动一个docker容器,使用 docker run
命令即可
docker run -d -p 91:80 nginx
需要注意的是使用 docker run 命令创建容器时,会先检查本地是否存在指定镜像,如果本地不存在,docker 会自动从 dockerHub 上下载一个该镜像并启动。
- 检验docker容器是否启动成功
访问地址http://localhost:91/
docker的三大要素
- 仓库:存储镜像的地方,分为公开仓库和私有仓库
- 镜像:包含了你打包的应用程序及其所依赖的环境
-
容器:用镜像创建的运行实例,可以把容器看成简易版的Linux的容器,一个运行中的容器是一个运行在Docker主机上的进程,但它和主机,以及所有运行在主机上其他进程都是隔离的。
-
容器是利用什么机制实现隔离的?
- Linux 命名空间
- Linux 控制组(cgroups)
-
docker底层原理
docker是一个client-server结构的进程,docker守护进程运行在主机上,然后通过socket连接从客户端的访问,守护进程从客户端接受命令并管理运行在主机上的docker容器。容器是一个运行时环境,就是鲸鱼背上的一个个集装箱。
docker常用命令
1.帮助命令
docker version
docker info
docker --help
2.镜像命令
docker images : 列出本地镜像
docker image -qa : 显示全部镜像id
docker images --digests : 显示镜像简介信息
docker images --digests --no-trunc
docker search tomcat : 搜索某个镜像
docker pull tomcat : 下载镜像到本地 等价于 docker pull tomcat:latest(默认下最新版本)
docker rmi tomact : 删除某个镜像
docker rmi tomcat:6.5 删除制定版本镜像
docker rmi -f tomcat 强制删除镜像
docker rmi -f nginx tomcat 强制删除多个镜像
docker rmi -f ${docker images -qa} 强制删除全部
3.容器命令
(1) docker pull centos : 下载centos镜像
(2) docker run [options] image
—name=“容器新名字” :为容器制定一个名字
-i : 容器的image id
-t : 交互式启动 ,比如 :docker run -it 0a8b6f21d511
-d : 后台运行容器
-p : 制定映射端口
docker run -it -p 8080:8080 tomcat (-p 指定主机端口:docker容器暴露给宿主机的端口;-P 随机分配端口)
(3) docker ps : docker中运行的进程,docker ps -n 5
(4) exit: 容器停止退出
(5) docker restart \ docker stop \ docker kill \ docker rm
(6)一次性删除多个容器:
docker rm -f $(docker ps -qa)
docker ps -aq | args docker rm
(7)docker run -d 容器名 : 运行容器
(8)docker logs -f -t --tail n 容器id(-f : 跟随最新的日志;-t :加入时间戳;--tail n : 倒数几行): 查看容器日志
演示命令:
docker run -d centos /bin/sh -c 'while true;do echo hello zzyy;sleep 2;done' : 每隔两秒输出内容
(9) docker top 容器ID : 查看容器内部运行的进程
(10) docker inspect 容器ID : 查看容器内部细节,如:docker inspect f791d79a4467
(11) docker attach 容器ID : 重新进入未停止的容器
(12) docker exec -t f791d79a4467 ls -l /tmp : 重新进入某个容器并执行容器中的命令,拿到结果反给宿主机
(13) docker cp 容器ID:路径文件 /宿主机路径 :copy容器内容到宿主机上
3.1 docker 命令使用举例
比如重启nginx过程:
- sudo docker restart nginx,重启
- sudo docker logs -f nginx,查看重启结果
- sudo docker exec -it nginx /bin/sh,进入容器, 使用nginx -t命令查看
docker的镜像
镜像是一种轻量级、可执行的独立软件包,用来打包软件运行环境和基于运行环境开发的软件,它包含运行某个软件所需的所有内容,包括代码、运行时需要的库、环境变量和配置。
- unionFS:联合文件系统,一层层文件系统组成
-
docker如何加载?
docker的镜像实际上由一层一层的文件系统组成,这种层级文件系统是unionFS- bootfs(boot file system):主要包含bootloader和kernel,bootloader主要引导加载kernel,linux刚启动是会加载bootfs文件系统,在docker镜像最底层是bootfs文件。这一层于我们典型的Linux/unix系统一样,包含boot加载器和内核。当boot加载完成之后整个内核就在内存中了,此时系统会卸载bootfs
- rootfs(root file system):在bootfs之上,包含的就是典型linux系统中的/dev,/bin,/etc等目录和文件。
docker commit -m=“提交信息” -a=“作者” 容器ID 要创建的目标镜像名称:[标签名]
docker commit -m=“helloword” -a=“feifei” 0a8b6f21d511 feifei/tomcat02:1.2
docker容器数据卷
docker容器产生的数据,如果不通过docker commit生成新的镜像,使得数据作为镜像的一部分保存下来,那么当容器删除后,数据自然就没有了,为了保存数据我们使用docker的数据卷。数据卷使得数据可以持久化和共享。
- 命令添加数据卷
docker run -it -v /宿主机绝对路径目录:/容器内目录 镜像名
例如:docker run -it -v /tmp/my-volume:/tmp/my-volume centos ;宿主机目录:/tmp/my-volume和docker容器目录/tmp/my-volume这两个目录中的数据可以随时同步,容器重启后,也会同步;
docker run -it -v /宿主机绝对路径目录:/容器内目录:ro 镜像名 (带权限的命令,同步到容器内的文件read only)
这种方式不支持多台宿主机都能够建立数据卷
- DockerFile添加
可以在Dockerfile中使用 VOLUME
指令来给镜像添加一个或多个数据卷
1.创建Dockerfile文件目录/Users/ShiFeifei/Software/docker-config
,在这个目录下
touch Dockerfile
vim Dockerfile
添加如下内容
FROM centos
RUN mkdir /myvol
RUN echo "hello world" > /myvol/greeting
VOLUME /myvol
2.新建一个 docker 容器
docker build -f /Users/ShiFeifei/Software/docker-config/Dockerfile -t sff/centos .
Dockerfile
Dockerfile 是用来构建 Docker镜像的构建文件,是由一系列命令和参数构成
Dockerfile 构建步骤
- 编写Dockerfile文件
- docker build
- docker run
Dockerfile 文件执行规则
- 关键字指令都必须是大写字母,并且后面要跟随至少一个参数
- 指令按照从上到下顺序执行
-
#
表示注释 - 每条指令都会创建一个新的镜像层,并对镜像进行提交
Dockerfile、Docker镜像和Docker容器分别代表了软件的三个不同阶段
- Dockerfile是软件的原材料
- Docker镜像是软件的交付品
- Docker容器则可以认为是软件的运行态
Dockerfile面向开发,Docker镜像成为软件交付标准,Docker容器则涉及部署与运维,三者缺一不可,是Docker体系的基石。
Dockerfile 保留字指令
- FORM : 基础镜像,当前要创建的来自于这个基础镜像
- MAINTAINER : 镜像维护者的姓名和邮箱地址
- RUN : 容器构建时需要运行的命令
- EXPOSE : 当前容器启动后对外暴露的端口声明
- WORKDIR : 指定在容器创建后,终端默认登录进来的工作目录,可以理解为家目录
- ENV : 设置环境变量
- ADD : 将宿主机目录下的文件拷贝给镜像,且ADD命令会自动处理URL和解压压缩包
- COPY : 类似ADD,拷贝文件和目录到镜像中
- VOLUME : 指定容器数据卷
- CMD : 指定一个容器启动时要运行的命令,Dockerfile 中可以有多个CMD命令,但只有最后一个生效;CMD 会被 docker run 之后的参数覆盖
- ENTRYPOINT : 指定一个容器启动时要运行的命令,目的和CMD一样,都是指定容器启动程序及参数,参数不会被覆盖,只会追加
- ONBUILD :
案例
1.实现一个功能,定制一个 mycentos 支持vim、ifconfig命令,并且修改登录后的默认路径
FROM centos
ENV homePath /tmp
WORKDIR $homePath #登录时的目录是 /tmp
RUN yum -y install vim
RUN yum -y install net-tools
EXPOSE 80
CMD /bin/bash
2.自定义一个centos,自带 tomcat 、jdk
FROM lentos
MAINTAINER shifeifei<shifeifei6@163.com>
#把宿主机当前路径下的文件c.txt拷贝到容器的/usr/local/路径下
COPY c.txt /usr/local/test.txt
#把Java和tomcat添加到容器中
ADD jdk-8u171-linux-x64.tar.gz /usr/local/
ADD apache-tomcat-9.0.8.tar.gz /usr/local/
#安装vim编辑器
RUN yum -y install vim
#设置工作访问时的WORKDIR路径
ENV MYPATH /usr/local
WORKDIR $MYPATH
#配置Java、tomcat环境变量
ENV JVAV_HOME /usr/local/jdk1.8.0_171
ENV CLASSPATH $JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar
ENV CATALINA_HOME /usr/local/apache-tomcat-9.0.8
ENV CATALINA_BASE /usr/local/apache-tomcat-9.0.8
ENV PATH $PATH:$JAVA_HOME/bin:$CATALINA_HOME/lib:$CATALINA_HOME/bin
#容器运行时监听端口
EXPOSE 8080
#启动运行tomcat
#CMD [“/usr/local/apache-tomcat-9.0.8/bin/startup.sh”,"run"]
CMD /usr/local/apache-tomcat-9.0.8/bin/startup.sh && tail -F /usr/local/apache-tomcat-9.0.8/bin/logs/catalina.out
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。