首页 > 其他分享 >Docker

Docker

时间:2022-08-20 19:44:44浏览次数:69  
标签:容器 -- 主机 docker 镜像 Docker port

 

  • 特性
    • 相比于VM,Docker的目标是可装配、轻量化。
    • VM的隔离级别是内核级,但也带来了多余的overhead,每个APP都需要对应一套OS和环境,即使有些APP对环境的要求是一样的
    • Docker的隔离级别是环境级,通过不同环境隔离不同APP组,同一环境上可部署多个APP(只要他们对环境的要求是一样的),使用Docker引擎(daemon)管理这些环境,支撑每个环境的是轻量级Linux
    • Docker解耦了镜像和容器,镜像是静态的文件,即使运行的容器损坏,也能从镜像快速重启;而对于VM,二者是高度耦合的,OS损坏往往需要重装系统,不能快速重启
    • 底层实现原理
      • Linux的Namespace技术,用于修改当前进程的视图,是一种映射,使在宿主机上的PID映射到容器中的PID,容器中的进程只能看到本容器,看不到其他容器和宿主机进程(如果没暴露的话)
      • Linux的CGroups技术,虽然namespace做了资源隔离,但由于真实管理者还是HostOS,可能会使宿主机视角下的容器资源分配出问题,CGroups可以对容器分配资源
      • 因此,Docker对容器的管理本质上还是HostOS在执行,并没有VM中的Hypervisor充当管理者
    • 优点:可复用,可装配,轻量级,高性能
    • 缺点:隔离级别较低,安全性没VM高,对于无法使用namespace的要素(如系统时间)无法做隔离
  • 名词解释
    • 镜像:一套封装好的环境蓝本,镜像的唯一标识可以是
      • 镜像名:版本号
      • ID
    • 容器:运行镜像,这个轻量级的系统启动后就充当容器功能,其内部可盛装APP
    • 仓库:镜像的存储发布管理中心
    • 层:镜像是由一系列层堆叠而成的,每一层的功能和所需资源都不同,最大层数为128。如某镜像 = [Ubuntu + Nginx + JDK + MySQL + APP],共5层。不同镜像指向所需层,相同层是可共享的
  • 常用命令
    • docker pull xxx 拉取镜像
    • docker rmi 删除镜像
    • docker rm 删除容器
    • docker images 查看本地镜像
    • docker run 运行容器
      • -it 进行容器交互
      • --restart=always 容器随引擎启动
      • --rm 容器stop后立即删除
      • --add-host 注入解析
    • docker ps 列出所有运行中的容器
    • docker start 启动容器
    • docker restart 重启容器
    • docker stop 停止容器
    • docker kill 强制停止
    • docker build 构建dockerfile
    • docker-compose 规定多个有依赖关系容器的启停顺序
    • docker info 查看引擎信息
    • docker search 检索容器
    • docker stats 查看容器占用资源
    • docker inspect 查看容器信息

 

  • 持久化
    • 容器一旦被删除,内部数据随之删除,这对数据库等容器很不利,需要将容器中的数据持久化
    • 容器与容器间持久化
      • NFS
      • 主机temp目录作为文件桥
      • --volumes-from 容器——容器
    • 容器与主机间持久化
      • 在DockerFile中指定数据卷VOLUME
      • -v 容器——主机
  • 网络通信
    • 容器网络模型
      • 同宿主机间容器通信——docker0虚拟网卡作为端口,转发交由真实网卡eth0处理
      • 跨宿主机间容器通信——利用Overlay网络进行隧道通信,比如三层的FlannelUDP模式
        • 用户的容器都连接在docker0网桥上。而网络插件则在宿主机上创建一个特殊的设备(UDP模式创建的是TUN设备,VXLAN模式创建的则是VTEP设备),docker0与这个设备之间,通过IP转发(路由表)进行协作
        • 然后,网络插件通过某种方法,把不同宿主机上的特殊设备连通,从而达到容器跨主机通信的目的
    • 通信模式:--net
      • host模式:使用主机ip:port
      • container模式:使用指定容器的命名空间[ip:port]
      • none模式:不指定网络模式,可自定义
      • bridge模式:即NAT组网,同一子网的容器对外暴露统一ip:port,子网间的容器可通过网桥通信,是默认通信方式
      • overlay模式:在Docker集群的内部节点之间创建虚拟根节点,不同内部容器通过虚拟根节点跨主机访问
    • 端口映射:-p
      • 容器port绑定指定ip:port
      • 容器port绑定指定ip的随机port
      • 容器port绑定主机ip的指定port
      • 主机port:容器port
      • docker port 查看容器的端口映射
    • 容器通信
      • 容器间通信[默认通信方式]
        • 使用网桥docker0 +命名空间完成交换
      • 容器访问主机
        • SNAT
      • 主机访问容器
        • DNAT
  • 格式化命令
    • 嵌套:类似sql子查询,使用$()列出子查询结果,作为外层命令的执行对象
      • 强制删除所有容器:docker rm -f $(docker ps -a -q)
  • 制作DockerFile
    • 在基础OS上使用bash配置好所需环境后,使用docker commit生成有状态的镜像
    • 使用DockerFile生成linux命令,创建无状态的镜像
      • 1. FROM 基础image
      • 2. MAINTAINER 创建者
      • 3. RUN 执行基础image命令,与其他DockerFile命令配合使用,多条命令用&&连接
      • 4. CMD/ENTRYPOINT 设置容器启动时执行的指令,多条指令用&&连接
      • 5. USER 容器启动用户
      • 6. EXPOSE 暴露指定端口给主机
      • 7. ENV 注入环境变量kv
      • 8. ADD 从源路径复制文件到容器的指定路径,源路径可以是基础image中的绝对或相对路径或url,如果文件是tar,会被自动解压
      • 9. COPY 同ADD,但不支持url,且不会解压
      • 10. WORKDIR 切换目录,与RUN配合使用
      • 11. ONBUILD 设置如果当前镜像被制作为新的镜像,则在新镜像中执行,配合RUN
      • 12. VOLUME 挂载主机文件映射
      • 13. 最后运行docker build [-t name:version] [DockerFile path]生成镜像
  • 容器资源设置
    • 内存限制
      • --memory [b/k/m/g] 设置容器最大硬内存
      • --memory-reservation 设置容器最大软内存
      • --oom-kill-disable 设置内存不足时,容器是否会被杀死
    • CPU限制
      • -c 设置容器占用CPU权重,默认1024
      • --cpus 设置容器能使用的cpu个数
      • --cpu-period 设置容器的调度周期
      • --cpu-quota 设置容器在每个调度周期内可使用的CPU时间
    • 生产环境中,制作完DockerFile后需进行内存/CPU压测

标签:容器,--,主机,docker,镜像,Docker,port
From: https://www.cnblogs.com/rellik96/p/16593033.html

相关文章

  • 使用docker简单编译k20pro内核
    简介本文将介绍一下如何使用docker编译红米k20pro的内核。作者当时尝试构建内核的原因是为了将3年前(好像是吧)购买的k20pro至尊版(已退役,12GB内存,512GB硬盘)制作成一个小的服......
  • Docker入门-基础知识
    Docker入门-基础知识Cloud研习社 Cloud研习社 2022-06-1707:26 发表于山东收录于合集#实战经验33个#云计算34个#计算机37个#docker3个#IT23个 Dock......
  • ClickHouse 本地Docker版搭建及Go链接体验Demo
    1,Win10用Docker启动单机版本ClickHouseWin10上用WSL搭建Docker环境部署就不讲了,直接上ClickHouse的镜像部署;找到官方Docker镜像库,搜索选中:clickhouse/clickhouse-se......
  • docker save与docker export实现docker镜像与容器的备份
    本来想写一篇关于dockersave/export/commit/load/import之间的关系的文章,后来看了看,已经有很多人写过了,我就不做重复工作了。参见:dockersave与dockerexport的区别Do......
  • Docker常用命令
    1.镜像相关dockerpull#拉取镜像dockerimages#查看镜像列表dockerimages-aq......
  • 使用Docker搭建Nextcloud私有网盘
    一、准备材料安装环境:linux工具:docker软件:MySql、Nextcloud二、安装Docker安装Docker:https://www.cnblogs.com/jzcn/p/15693786.html三、下载镜像使用DocKer下载......
  • Docker创建ElasticSearch集群以及常见问题
    本篇文章演示在WSL2中通过DockerCompose搭建ES集群,解决其中遇到的问题。虚拟内存最大映射数第一个问题是几乎所有机器上搭建ES集群都会遇到的,即虚拟内存最大映射数默认为......
  • Ubuntu 安装docker
    安装切换为root用户,非root用户,请在所有命令前面加上sudo更新aptaptupdate安装依赖aptinstallapt-transport-httpsca-certificatescurlsoftware-propertie......
  • Docker容器网络(基本网络模型)
    解析Docker的4种容器网络默认网络模型先介绍默认的网络模型:安装docker后,输入ifconfig就会发现多了网卡中多了一个docker0:$ifconfigdocker0:flags=4099<UP,BROADC......
  • macbook 安装docker machine
    dockermachine在最新版本已被弃用,用dockerdesktop替代#安装docker-machinebase=https://github.com/docker/machine/releases/download/v0.16.2&&curl-L$base......