Docker概述

Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的 Linux 机器上,也可以实现虚拟化。容器是完全使用沙箱机制,相互之间不会有任何接口。
一个完整的Docker有以下几个部分组成:
dockerClient客户端
Docker Daemon守护进程
Docker Image镜像
DockerContainer容器
Docker 架构
Docker 使用客户端-服务器 (C/S) 架构模式,使用远程API来管理和创建Docker容器。Docker 容器通过 Docker 镜像来创建。容器与镜像的关系类似于面向对象编程中的对象与类。
Docker采用 C/S架构 Docker daemon 作为服务端接受来自客户的请求,并处理这些请求(创建、运行、分发容器)。 客户端和服务端既可以运行在一个机器上,也可通过 socket 或者RESTful API 来进行通信。
Docker daemon 一般在宿主主机后台运行,等待接收来自客户端的消息。 Docker 客户端则为用户提供一系列可执行命令,用户用这些命令实现跟 Docker daemon 交互。

Docker的核心概念

镜像

类似于虚拟机的快照,可以理解为一个是面向Docker容器引擎的制度模板,比如一个镜像可以是一个完整的centos操作系统,也可以从网上下

容器

容器是从镜像创建的运行实力,它可以被启动停止,创建,删除。每个一个容器都是相互隔离,互不可见,可以保证平台的安全性,还可以吧容器看做一个简易版的Linux环境

仓库

仓库用来集中保存镜像地方当创建了自己的镜像后,可以使用qush命令上传到公共仓库

Docker 特点
特点 Docker容器 虚拟机
启动速度 秒级 分钟级
计算机能力耗损 几乎无 损耗50%左右
性能 接近原生 弱于
系统支持量(单机) 上千个 几十个
隔离性 资源限制 完全隔离

Docker安装

配置仓库

# vim /etc/yum.repos.d/ghostcloud.repo
[dockerrepo]
name=Docker Repository
baseurl=https://yum.dockerproject.org/repo/main/centos/$releasever/
enabled=1
gpgcheck=1
gpgkey=https://yum.dockerproject.org/gpgyum list 

安装Docker

yum install docker-engine -y
systemctl start docker                    //启动docker
systemctl enable docker.service    //设置开机自启动
docker version                      //查看版本
docker info    //查看docker基本信息
Docker镜像操作

搜索并获取镜像

docker search cobbler      //搜索关键字cobbler
docker pull jasonlix/docker-cobbler   //下载搜索出的结果

docker images //查看所有镜像 (也可以单独查询 后面跟仓库名称和标签)

docker inspect //指定ID号查看 详细信息

导入、导出、删除镜像
删除之前确保没有被容器使用,若有容器使用需要先删除容器。# docker rmi cobbler:cobbler  //删除  注:当镜像有多个标签时只是删除标签
存出镜像和载入镜像# docker save -o cobbler jasonlix/docker-cobbler    //将本地镜像存为文件cobbler
# docker load < cobbler     //载入镜像
或者
# docker --input cobller   //载入镜像



容器创建

docker create -it jasonlix/docker-cobbler /bin/bash  会生一串序列号
docker ps -a 查看容器中所有进程
docker start 启动容器 跟ID号
docker stop 停止同期 跟ID号

docker run jasonlix/docker-cobbler /usr/bin/bash -c ls / 查看镜像根目录
docker run -d jasonlix/docker-cobbler /usr/bin/bash -c "while true;do echo htllo;done"  一直保持在启动
docker ps -a  你要进入的序列号的状态Up About a minute 或者Up 1 second
docker exec -it 1c0b830793a7 /bin/bash  进入到容器中shell环境中前提是保持开启状态 exit退出



Docker资源限制

限制CPU使用速率:

docker run --cpu-quota 20000 centos(容器名) //cpu的使用率限定为20%

按比例分享CPU:

docker run --cpu-shares 1024 centos

限制CPU内核使用:

docker run --cpu-shares 1024 centos

限制CPU内核使用:

docker run --cpuset-cpus 0,1 centos //容器centos独享 第1和第2个内核

限制内存使用:

docker run -m 512m centos //限制cents容器内存512M

对blkio限制:

限制容器的/dev/sda1 的写入ipos为1MB docker run --device-write-bps /dev/sda1:1mb centos

转载于:https://blog.51cto.com/13660858/2157065

Docker架构镜像及容器管理相关推荐

  1. 容器-Docker《三》容器管理

    容器-Docker<三>容器管理 下载镜像只是相当于将软件下载下来安装好,但是并不代表把它运行起来,类似于root@ubuntu2204:~# apt install nginx = do ...

  2. 在Centos7 更改Docker默认镜像和容器的位置

    在Centos7 更改Docker默认镜像和容器的位置 一.Why? 通常,当你开始使用docker时,我们并不太关心Docker 用于存储镜像和容器的默认目录.当使用Docker进行更多实验时,Do ...

  3. Docker的镜像和容器的区别

    Docker的镜像和容器的区别 作者:chszs,版权所有,未经同意,不得转载.博主主页:http://blog.csdn.net/chszs 一.Docker镜像 要理解Docker镜像和Docke ...

  4. Docker 学习笔记(Docker 架构 / 镜像 / 容器 / 常用命令 / Dockerfile / 镜像仓库)

    Docker 1. Docker 入门 1.1 Docker 是什么 1.2 Docker 和 虚拟机 1.3 镜像 容器 仓库 1.4 Docker 架构 1.5 Docker 安装 1.6 doc ...

  5. docker镜像、容器管理

    Docker优势 1) 更高效的利用系统资源 无论是应用执行速度.内存损耗或者文件存储速度,都要比传 统虚拟机技术更高效. 2)更快速的启动时间 Docker 容器应用,由于直接 运行于宿主内核,无需 ...

  6. 在 Docker 中运行 MySQL:多主机网络下 Docker Swarm 模式的容器管理

    本文将以多主机网络环境为基础,探讨如何利用内置编排工具 Docker Swarm 模式对各主机上的容器加以管理. Docker Engine – Swarm 模式 在多台主机之上运行 MySQL 容器 ...

  7. docker swarm MySQL_容器与云|在 Docker 中运行 MySQL:多主机网络下 Docker Swarm 模式的容器管理...

    本文将以多主机网络环境为基础,探讨如何利用内置编排工具 Docker Swarm 模式对各主机上的容器加以管理. Docker Engine – Swarm 模式 在多台主机之上运行 MySQL 容器 ...

  8. Docker持续集成与容器管理--系列教程

    一 Docker简介 Docker介绍 Docker架构 二 Docker安装 Ubuntu Docker 安装 CentOS Docker 安装 Windows Docker 安装 MacOS Do ...

  9. 多主机网络下 Docker Swarm 模式的容器管理

    导读 本文将以多主机网络环境为基础,探讨如何利用内置编排工具 Docker Swarm 模式对各主机上的容器加以管理. Docker Engine – Swarm 模式 在多台主机之上运行 MySQL ...

最新文章

  1. 教你用 buildroot 构建根文件系统
  2. 【C语言】 Linux内核源码-- do...while(0)解析
  3. linux中用户与组的概念,Linux用户和组的概念
  4. (转)nmake学习笔记
  5. Nature机器学习子刊被讽开历史倒车,Jeff Dean等数百学者签名抵制
  6. 07堆排序 python
  7. ※C++随笔※=☆C++基础☆=※№→C++中 #include与#include
  8. win32汇编 invoke 和 call区别
  9. 贴片电阻字码阻值对照表
  10. iTextSharp操作PDF
  11. 2022年美赛S奖得主的三次完赛经历
  12. matlab 画温度分布,matlab画温度分布图
  13. Linux原子操作与锁实现
  14. 【Godot】一个节点发射器(泼水机)
  15. HTTP 所有状态码
  16. 如何在Linux系统下的IntelliJ IDEA 2018.3.5下载与安装以及激活教程
  17. python环境搭建及应用
  18. class的操作:className和classList
  19. 织梦网站 mysql,织梦(DEDECMS)网站程序及数据库迁移搬家教程
  20. 用计算机进行论文检索应用,计算机检索论文摘要怎么写 计算机检索论文摘要范文参考...

热门文章

  1. AIstudio——李宏毅机器学习课程记录(一、机器学习介绍)
  2. 特斯拉持续涨价,中国制造可望因此受益
  3. AngularJS 核心概览
  4. 实训项目日志(二)——分镜制作
  5. i40e网卡驱动中的PCI-E带宽警告
  6. ip网络的时延:发送时延(传输时延),传播时延,处理时延,排队时延
  7. ChatterBot构建聊天机器人
  8. Western Union 为中国微信用户推出针对国际汇款的收款服务
  9. 基于matlab的心电信号处理毕业论文,浅议仿真基于MATLAB的“数字信号处理”仿真实验毕业论文范文...
  10. 如何在ICEM中将有对称面的半模结构网格转变为全模(解决uncovered faces 问题)