5

docker简介

1.docker是基于go语言实现
主要目标是对对应组件的封装、分发、部署、运行等生命周期的管理,使应用程序及其运行环境能够做到“一次封装,到处运行”

2.docker为了解决运行环境和配置问题的软件容器,方便做持续集成并有助于整体发布的容器虚拟化技术

3.docker能干些什么?

  • 虚拟机技术
    简单理解可以在一种操作系统里面运行另外一种操作系统,比如windows中运行linux系统,常见的是vmware;缺点:占用资源,启动慢,安装步骤繁琐。
  • 容器虚拟化技术
    docker既是一种容器虚拟化技术,docker本身是一个容器运行载体或称之为管理引擎,我们把应用程序和配置依赖打包好形成一个可交付的运行环境,这个打包好的运行环境就是镜像文件,只有通过这个镜像文件才能生成docker容器。docker 根据 image 镜像文件生成容器实例。同一个image文件可以生成多个同时运行的容器实例。
  • docker 架构

clipboard.png

docker使用

docker 初体验

新建并启动一个docker容器,使用 docker run命令即可

docker run -d -p 91:80 nginx

clipboard.png
需要注意的是使用 docker run 命令创建容器时,会先检查本地是否存在指定镜像,如果本地不存在,docker 会自动从 dockerHub 上下载一个该镜像并启动。

  • 检验docker容器是否启动成功

访问地址http://localhost:91/

clipboard.png

docker的三大要素

  • 仓库:存储镜像的地方,分为公开仓库和私有仓库
  • 镜像:包含了你打包的应用程序及其所依赖的环境
  • 容器:用镜像创建的运行实例,可以把容器看成简易版的Linux的容器,一个运行中的容器是一个运行在Docker主机上的进程,但它和主机,以及所有运行在主机上其他进程都是隔离的。

    • 容器是利用什么机制实现隔离的?

      • Linux 命名空间
      • Linux 控制组(cgroups)

docker底层原理

docker是一个client-server结构的进程,docker守护进程运行在主机上,然后通过socket连接从客户端的访问,守护进程从客户端接受命令并管理运行在主机上的docker容器。容器是一个运行时环境,就是鲸鱼背上的一个个集装箱。

clipboard.png

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:联合文件系统,一层层文件系统组成

clipboard.png

  • 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体系的基石。

clipboard.png

Dockerfile 保留字指令

  • FORM : 基础镜像,当前要创建的来自于这个基础镜像
  • MAINTAINER : 镜像维护者的姓名和邮箱地址
  • RUN : 容器构建时需要运行的命令
  • EXPOSE : 当前容器启动后对外暴露的端口声明
  • WORKDIR : 指定在容器创建后,终端默认登录进来的工作目录,可以理解为家目录
  • ENV : 设置环境变量
  • ADD : 将宿主机目录下的文件拷贝给镜像,且ADD命令会自动处理URL和解压压缩包
  • COPY : 类似ADD,拷贝文件和目录到镜像中
  • VOLUME : 指定容器数据卷
  • CMD : 指定一个容器启动时要运行的命令,Dockerfile 中可以有多个CMD命令,但只有最后一个生效;CMD 会被 docker run 之后的参数覆盖
  • ENTRYPOINT : 指定一个容器启动时要运行的命令,目的和CMD一样,都是指定容器启动程序及参数,参数不会被覆盖,只会追加
  • ONBUILD :

clipboard.png

案例

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

一只小小鸟
144 声望25 粉丝

如何做一个深层次的思考者,从简单开始、从记录开始。