基于Go语言的容器技术
1)解决环境不一致问题 2)环境迁移和备份、快速恢复 3)应用自动化部署
Docker client 客户端(安装了docker软件就可以称为docker客户端)
Hosts 本地仓库
Repository 远程仓库(中央仓库、私服:国内私服、公司内部私服服务器)
image 镜像(包含软件的文件系统)
container 容器(运行的安装了软件文件系统)
--vim /etc/docker/daemon.json
{
"registry-mirros":["中科大、阿里、腾讯"]
}
镜像:一个分层的文件系统(相当于类)
依赖包、配置、环境信息
容器:镜像运行之后的结果(相当于对象)
镜像仓库:
远程仓库:Docker中央仓库(国外服务器)、第三方提供的私服、本公司私服
本地仓库:安装了docker软件的服务器
服务相关操作
systemctl stop|start|restart|status|disable|enable 服务名称
#查看镜像
docker images [-q]
#搜索镜像(需要联网)
docker search 镜像名称
#拉取镜像(需要联网,如果不加“版本”默认下载最新镜像)
docker pull 镜像名称:镜像版本
#删除镜像
docker rmi 容器id|镜像名称[:镜像版本]
#docker rmi `docker images -q`(不要操作)
#查看镜像详情
docker inspect 容器id|镜像名称
镜像概念:
分层文件系统(boot文件系统复用)
#查看容器
docker ps #查看正在运行的容器
docker ps -a #查看所有容器
#运行容器
#交互式容器:创建容器后进入容器内部,退出容器后容器关闭
docker run -it --name=容器名称 镜像名称:镜像版本 /bin/bash
#守护式容器:创建容器后不进入容器内部,退出容器后容器不会关闭
docker run -id --name=容器名称 镜像名称:镜像版本
#进入容器(需要是启动的容器)
docker exec -it 容器ID[容器名称] /bin/bash
#停止、启动、重启容器
docker stop|start|restart 容器ID[容器名称]
#查看容器详情
docker inspect 容器ID[容器名称]
#删除容器
docker rm 容器ID[容器名称] [-force] #指定删除容器 --force强制删除
docker rm `docker ps -a -q` #删除所有容器
#目录挂载、映射(所共享的文件夹就称为“数据卷”)
docker run -id --name=容器名称 -v 宿主机目录:容器路径 [-v 宿主机目录:容器路径 ...] 镜像名称:镜像版本
#端口映射(外部服务器通过宿主机访问容器中的服务)
docker run -id --name=容器名称 -p 宿主机端口:容器端口 [-p 宿主机端口:容器端口...] 镜像名称:镜像版本
#查看容器运行日志
docker logs -f 容器ID[容器名称]
“基于镜像创建镜像”的docker组件
两种方式:
1)镜像运行成容器,通过修改容器,最终再把容器提交为镜像
缺点:使用目录挂载的文件,不生效
2)使用Dockerfile基于镜像创建镜像
执行dockerfile:
docker build -f ./centos_dockerfile -t 镜像名称 .
docker build [-f ./centos_dockerfile] -t 镜像名称 .
如果要build的文件名称为Dockerfile,可以不用-f指定文件名称
注意:执行docker build,最后的“.”不要省略
关键字 | 作用 | 备注 |
---|---|---|
FROM | 指定父镜像 | 指定dockerfile基于那个image构建 |
MAINTAINER | 作者信息 | 用来标明这个dockerfile谁写的 |
LABEL | 标签 | 用来标明dockerfile的标签 可以使用Label代替Maintainer 最终都是在docker image基本信息中可以查看 |
RUN | 执行命令 | 执行一段命令 默认是/bin/sh 格式: RUN command 或者 RUN ["command" , "param1","param2"] |
CMD | 容器启动命令 | 提供启动容器时候的默认命令 和ENTRYPOINT配合使用.格式 CMD command param1 param2 或者 CMD ["command" , "param1","param2"] |
ENTRYPOINT | 入口 | 一般在制作一些执行就关闭的容器中会使用 |
COPY | 复制文件 | build的时候复制文件到image中 |
ADD | 添加文件 | build的时候添加文件到image中 不仅仅局限于当前build上下文 可以来源于远程服务(还可以解压) |
ENV | 环境变量 | 指定build时候的环境变量 可以在启动的容器的时候 通过-e覆盖 格式ENV name=value |
ARG | 构建参数 | 构建参数 只在构建的时候使用的参数 如果有ENV 那么ENV的相同名字的值始终覆盖arg的参数 |
VOLUME | 定义外部可以挂载的数据卷 | 指定build的image那些目录可以启动的时候挂载到文件系统中 启动容器的时候使用 -v 绑定 格式 VOLUME ["目录"] |
EXPOSE | 暴露端口 | 定义容器运行的时候监听的端口 启动容器的使用-p来绑定暴露端口 格式: EXPOSE 8080 或者 EXPOSE 8080/udp |
WORKDIR | 工作目录 | 指定容器内部的工作目录 如果没有创建则自动创建 如果指定/ 使用的是绝对地址 如果不是/开头那么是在上一条workdir的路径的相对路径 |
USER | 指定执行用户 | 指定build或者启动的时候 用户 在RUN CMD ENTRYPONT执行的时候的用户 |
HEALTHCHECK | 健康检查 | 指定监测当前容器的健康监测的命令 基本上没用 因为很多时候 应用本身有健康监测机制 |
ONBUILD | 触发器 | 当存在ONBUILD关键字的镜像作为基础镜像的时候 当执行FROM完成之后 会执行 ONBUILD的命令 但是不影响当前镜像 用处也不怎么大 |
STOPSIGNAL | 发送信号量到宿主机 | 该STOPSIGNAL指令设置将发送到容器的系统调用信号以退出。 |
SHELL | 指定执行脚本的shell | 指定RUN CMD ENTRYPOINT 执行命令的时候 使用的shell |
基于镜像按顺序启动多个容器的docker组件
1)拉取基础镜像:centos7
docker pull centos7
2)制作镜像
2.1) 基础镜像运行成容器,在容器中安装软件:mysql、jdk、tomcat、maven、项目
2.2) Dockerfile,基于镜像制作镜像
3)“容器”制作“镜像”(注:2.1基于容器制作镜像才会有该步骤)
docker commit 容器名称[容器ID] 镜像名称:版本
4)制作的”镜像“上传到私服(镜像保存为压缩文件 docker save -o )
docker tag 镜像名称:tag 私服地址:私服端口/私服镜像名称:私服镜像版本 --添加版本标识
docker push 私服地址:私服端口/私服镜像名称:私服镜像版本
5)从私服拉取镜像运行成容器(压缩文件恢复成镜像运行成容器 docker load -i )
docker pull 私服地址:私服端口/私服镜像名称:私服镜像版本
概念:宿主机中的一个目录,该目录和“宿主机中的容器”进行了目录挂载
作用:1)容器数据持久化 2)宿主机和容器数据共享 3)容器和容器数据共享 4)外部服务器也可以访问容器数据
总结:容器和宿主机数据共享,防止删除容器,数据丢失
#数据卷容器(提取目录映射,简化目录映射)mount挂载
#创建数据卷容器
docker run -id --name=容器名称 镜像名称:镜像版本 -v 宿主机目录:容器目录 [-v 容器目录 ...]
#其他容器挂载数据卷容器
#数据卷容器:简化目录挂载
docker run -id --name=容器名称 镜像名称:镜像版本 --volumes-from 数据卷容器名称
环境一致:使用相同镜像
环境备份:dockerfile基于基础镜像制作自己需要的镜像;基于基础镜像运行容器,并进行修改,并把修改后的容器制作成镜像
环境迁移:镜像打包,把压缩包拷贝到多台服务器;镜像上传到私服,多台服务器从私服下载镜像
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。