docker:是一个应用打包,发布,部署工具。
docker优势:跨平台部署,性能优越(按需分配),自动化部署,稳定性优越。
docker运行方式:Docker是C/S模式,以客户端和守护进程的方式来运行。
一个docker容器同时只能管理一个进程,这个进程退出后,容器也就退出了,当然一个容器里可以同时运行多个进程。当容器启动完后执行某脚本后,该进程结束了,其他进程也结束了,所以该容器自动退出了,解决方案:我们可以让该脚本一直运行不停止。 (知识来自博客:https://blog.csdn.net/zhuchunyan_aijia/article/details/81143481?utm_source=blogxgwz8)
docker怎么实现宿主机上的代码能够实时同步到docker ------>使用文件挂载方法(bind mount)
docker怎么能然数据持久化,不会随着容器的丢失而丢失,特别是容器运行过程中产生的数据 ----->使用文件挂载的方式(volume),容器创建在宿主机上的目录进行管理。
多容器通信:只需要将几个容器放入同一个网络中就可以;针对复杂的多个容器docker提供了docker-compose来管理。
怎么实现docker’数据的备份和迁移:bind mount方式可以直接拷贝宿主机上的数据;volume方式有容器创建和管理,可以借助Ubuntu容器将数据弄出来。详情见:https://docker.easydoc.net/doc/81170005/cCewZWoN/XQEqNjiu
docker三剑客
①. docker-machine:解决docker运行环境问题,一个linux的虚拟机。win10已经有hyper-v虚拟机,可以直接运行。(目前已经淘汰)
②. docker-componse:容器编排技术,例如:两个容器之间通信
③. docker-swarm:解决多主机多容器调度部署问题。(已经淘汰,目前用K8S代替。)
run,cmd,endpoint三个指令的区别
①. run:用于镜像打包过程的命令,常用来安装软件包。
②. cmd:容器启动后执行的命令和参数,但是参数会被 docker run命令指定参数替代
③. endpoint:配置容器启动时执行的命令和参数,其参数不会被docker run命令指定的参数替代。
docker快速上手资料:https://docker.easydoc.net/doc/81170005/cCewZWoN/lTKfePfP
docker file关键字于语法介绍:注意一点,写命令的时候要分清楚宿主机和容器的路径关系,以及运行时机
代码如下(示例):
# 基于基础镜像
FROM python:3.9.6
#维护者信息
MAINTAINER name xxxx
#将当前文件夹下的代码添加到镜像的 Code文件见
ADD ./docker_pywebio /code
#设置code文件夹是工作目录
WORKDIR /code
#安装支持依赖
RUN pip install -r requirements.txt
#docker 运行python程序
CMD ['python', 'code/pywebio_pyecharts_demo.py']
报错:启动容器报错:/bin/bash: 1: [python,:not found
报错分析:yaml中CMD 不能使用单引号,要用双引号
代码如下(示例):
FROM python:3.9.6 #基础软件版本
MAINTAINER lwx333184 #维护者
ADD D:\01.WORKSPACE\01.docker\project_app /app #将本地文件拷贝到容器中,容器中目录自动创建
WORKDIR /app #指定容器工作区
RUN "mkdir -p /app/env" #在容器中新建env目录
COPY D:\01.WORKSPACE\01.docker\requriments.txt /app/env #将本地文件复制到容器目录中
ENV USERNAME=lwx333184 #传递环境变量
LABLE PASSWD=11111
RUN pips install -r /app/env/requriments.txt #RUN执行容器中的文件
VOLUME /app #数据持久,挂盘
EXPOSE 8080 #容器端口暴露给宿主机
CMD ["python", "/app/kunyi_docker.py"] #执行容器中的程序文件
报错:启动容器报错:failed to solve with frontend dockerfile.v0: failed to create LLB definition: dockerfile parse error line 1: FROM requires either one or three arguments
报错分析:yaml中会把在同一行的注释当成参数,所以注释必须单独为一行
代码如下(示例):
#基础软件版本
FROM python:3.9.6
#维护者
MAINTAINER lwx333184
#将本地文件拷贝到容器中,容器中目录自动创建
ADD D:\01.WORKSPACE\01.docker\project_app /app
#指定容器工作区
WORKDIR /app
#在容器中新建env目录
RUN "mkdir -p /app/env"
#将本地文件复制到容器目录中
COPY D:\01.WORKSPACE\01.docker\requriments.txt /app/env
#传递环境变量
ENV USERNAME=lwx333184
#添加元数据
LABEL PASSWD=11111
#RUN执行容器中的文件
RUN pips install -r /app/env/requriments.txt
#数据持久,挂盘
VOLUME /app
#容器端口暴露给宿主机
EXPOSE 8080
#执行容器中的程序文件
CMD ["python", "/app/kunyi_docker.py"]
报错:容器build的时候报错,
failed to compute cache key: “/D:01.WORKSPACE01.dockerrequriments.txt” not found: not found
报错分析:docker file中 ADD,COPY只能使用build中PATH路径的相对路径,不能使用绝对路径。
代码如下(示例):
#基础软件版本
FROM python:3.9.6
#维护者
MAINTAINER lwx333184
#将本地文件拷贝到容器中,容器中目录自动创建
ADD ./project_app /app
#指定容器工作区
WORKDIR /app
#在容器中新建env目录
RUN "mkdir -p /app/env"
#将本地文件复制到容器目录中
COPY ./requriments.txt /app/env
#传递环境变量
ENV USERNAME=lwx333184
#添加元数据
LABEL PASSWD=11111
#RUN执行容器中的文件
RUN pips install -r /app/env/requriments.txt
#数据持久,挂盘
VOLUME /app
#容器端口暴露给宿主机
EXPOSE 8080
#执行容器中的程序文件
CMD ["python", "/app/kunyi_docker.py"]
报错:容器build的时候报错,
=> ERROR [4/6] RUN “mkdir -p /app/env”
#8 0.471 /bin/sh: 1: mkdir -p /app/env: not found
报错分析:docker file中 RUN语句常用来执行软件安装,容器未启动时,时无法创建文件夹的;其中CMD时容器启动后默认执行的参数,参数可以被docker build中的参数取代;ENTRYPOINT 时容器启动时的命令,一定会执行
正确较为全面的DockerFile文件
#基础软件版本
FROM python:3.9.6
#维护者
MAINTAINER lwx333184
#将本地文件拷贝到容器中,容器中目录自动创建
ADD ./project_app /app
#指定容器工作区
WORKDIR /app
#将本地文件复制到容器目录中
COPY ./requriments.txt /app
#传递环境变量
ENV USERNAME=lwx333184
#添加元数据
LABEL PASSWD=11111
#RUN执行容器中的文件
RUN pip install -r /app/requriments.txt
#数据持久,挂盘
VOLUME /app
#容器端口暴露给宿主机
EXPOSE 8080
#执行容器中的程序文件
CMD ["/bin/bash", "mkdir -p /app/env; mv /app/requriments.txt /app/env"]
CMD ["python", "/app/kunyi_docker.py"]
docker pull [OPTIONS] NAME[:TAG|@DIGEST]
docker build [OPTIONS] PATH | URL | -
docker run [OPTIONS] IMAGE [COMMAND] [ARG…]
options参数介绍:
常见的几个例子:
docker ps [OPTIONS]
docker images [OPTIONS] [REPOSITORY[:TAG]]
docker volume ls 查看volume列表
docker network ls 查看网络列表
docker exec -it container_id bash 进入容器
docker container attach contain_id 进入容器,当多个终端同时进入的时候,所有窗口会同步显示; 实际操作中改命令卡住,特别注意,推出的时候,容器会同步推出,所以需要用 Ctrl+P+Q来退出。
docker rm container-id 删除指定id的容器
docker rm container-id 删除指定id的容器
docker rmi image-id/image-name:version 删除指定id的镜像
docker stop/start container-id 停止/启动指定id的容器
docker network COMMAND
举个例子:应用要与数据库通信,则需要通过网络将应用和MySql建立通信,方法就是部署在同一个网络中。
Docker 打包,发布,运行的方式极大的提升了应用程序的可移植性,是运维三板斧之一。