Docker的学习
学习地址:http://blog.51cto.com/lizhenliang 和 他的视频
九 图形化界面管理
十 构建容器监控系统
一 Docker 的介绍和安装
1.1 Docker是什么
1.2 Docker的体系结构
1.3 内部组件
1.4 虚拟机和容器的区别
1.5 Docker的应用场景
1.6 Linux 安装Docker
- 1 Docker是什么:
Docker是一个开源的应用容器引擎,使用Go语言开发,基于Linux内核的cgroup, namespace, Union FS等技术,对应用进程进行封装隔离,并且独立于宿主机与其他进程,这种运行时封装的状态称为容器。Docker早起版本实现是基于LXC,并进一步对其封装,包括文件系统、网络互联、镜像管理等方面,极大简化了容器管理。从0.7版本以后开始去除LXC,转为自行研发的libcontainer,从1.11版本开始,进一步演进为使用runC和containerd。Docker理念是将应用及依赖包打包到一个可移植的容器中,可发布到任意Linux发行版Docker引擎上。使用沙箱机制运行程序,程序之间相互隔离。
它是通过内核虚拟化技术来提供容器的资源的隔离和安全保证等等,因为docker是通过操作系统层的虚拟化实现隔离,所以docker容器在运行的时候是不需要额外的虚拟化管理程序,他是内核级别的虚拟化,可以实现更加高效的性能,同事对资源的额外的需求很低,他的最本质的特征,docker是通过隔离来进行创建容器。
- 2 Docker的体系结构:

我们通过Docker 客户端发送指令,通过Docker引擎来分发指令,是下载镜像或者是创建容器,如果本地有镜像直接引用,如果本地没有就从仓库拉取,通知Containerd 创建容器,Containerd在收到Engine的请求之后会启动一个shim,shim 会让runc提供一个容器的运行环境,runC就会去挂载文件系统,最后runC就会在文件系统启动一个进程。
Containerd:是一个简单的守护进程,使用runC管理容器。向Docker Engine提供接口
Shim:只负责管理一个容器。
runC:是一个轻量级的工具,只用来运行容器。


- 3 Docker 的内部组件
Namespace
命名空间,Linux内核提供的一种对进程资源隔离的一种机制,例如进程、网络、挂载点等资源,把他们封装在一个名称空间中,只能看到本容器内的资源
CGroups
控制组,LInux内核提供的一种限制进程资源的机制:例如CPU、内存等资源
我们可以在宿主机上通过 ls /sys/fs/cgroup 看到我们队哪些资源进行了限制,限制的资源有 blkio cpu cpuacct cpu,cpuacct cpuset devices freezer hugetlb memory net_cls net_cls,net_prio net_prio perf_event pids systemd
UnionFS:
联合文件系统,支持将不同位置的目录挂载到同一个虚拟文件系统,形成一种分层的模型
- 4 虚拟机和容器的区别
以KVM为例和Docker相比
启动时间:
Docker 秒级启动,KVM分钟级别启动
轻量级:
容器镜像大小通常以M为单位,虚拟机以G为单位
容器资源占用小,要比虚拟机部署更加的快速
性能:
资源共享宿主机内核,系统级虚拟化,占用资源少,没有Hypervisor层开销,容器性能基本接近物理机
虚拟机需要Hypervisor层支持,虚拟化一些设备,具有完整的GuestOS,虚拟化开销大,因而降低性能,没有容器性能好
安全性:
由于共享宿主机内核,只是进程级隔阂,因此隔离性和稳定性不如虚拟机,容器具有一定权限范根宿主机内核,存在一定安全隐患
使用要求:
KVM基于硬件的完全虚拟化,需要硬件CPU虚拟化技术支持
容器共享宿主主机内核,可运行在主流的Linux发行版,不用考虑CPU是否支持虚拟化技术
应用场景:(http://blog.51cto.com/lizhenliang/1978081)
节省橡胶木环境部署时间
单项目打包
整套项目打包
新开源技术试用
环境一致性
持续集成
微服务
弹性伸缩
Linux 安装Docker
就我的环境看一下文档的安装方式:
https://docs.docker.com/install/linux/docker-ce/centos/
我们这里安装ce 版本
sudo yum install -y yum-utils device-mapper-persistent-data lvm2
yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo
sudo yum install docker-ce
这里我们现在要是启动的话,我们用的仓库源的地址就是官方的,可能用起来不太方便,我们可以给企改成国内的,然后在启动
systemctl start docker
卸载的方式:
yum remove docker-ce
rm -rf /var/lib/docker
博客总结来源于:http://edu.51cto.com/course/10659.html
Docker的学习的更多相关文章
- 在Windows环境中开始Docker的学习和体验
研究docker有一段时间了,当然我主要的使用环境还是在Linux中,确实很方便. 但也有不少朋友希望使用Windows来工作学习,这里介绍一下在Windows中如何快速开始Docker的学习和体验吧 ...
- Docker容器学习梳理 - 应用程序容器环境部署
关于国内Docker镜像,可以参考:Docker容器学习梳理--基础知识(2) 的Docker镜像使用. 如果我们需要在Docker环境下部署tomcat.redis.mysql.nginx.php等 ...
- Docker容器学习梳理 - 日常操作总结
使用Docker已有一段时间了,今天正好有空梳理下自己平时操作Docker时的一些命令和注意细节: Docker 命令帮助 $ sudo docker Commands: attach Attach ...
- docker深入学习
docker深入学习 一.容器的介绍和容器的发展史 为什么要学习容器? 在openstack之后,目前互联网最火热的技术莫过于docker容器了,早在2015年,京东技术备战双11就是使用了10万+D ...
- 服务器搭建远程docker深度学习环境
服务器搭建远程docker深度学习环境 本文大部分内容参考知乎文章 Docker+PyCharm快速搭建机器学习开发环境 搭建过程中出现ssh连接问题可以查看最后的注意事项 Docker Docker ...
- Docker命令学习
今天更换腾讯云系统的时候发现了多了个CoreOS,据说是专门运行docker的轻量系统,顺便学习一下docker命令. 1. docker version 显示 Docker 版本信息. 2. doc ...
- 有关docker的学习链接
本文是自己搜索的比较好的网上资源,便于有兴趣者查阅. 英文官网 https://docs.docker.com/engine/getstarted/ 中文入门手册 http://www.docker. ...
- Docker个人学习总结
最近一段时间学习了下Docker,关于Docker的安装,运用什么的在这里我不会过多的说明,我只说我对于Docker的一些理解,附加我用于记录的少量代码. 刚开始学习Docker的时候,找资料在网上看 ...
- Docker技术学习
原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 .作者信息和本声明.否则将追究法律责任.http://sofar.blog.51cto.com/353572/1598249 貌似Doc ...
- Docker入门学习
Python爬虫 最近断断续续的写了几篇Python的学习心得,由于有开发经验的同学来说上手还是比较容易,而且Python提供了强大的第三方库,做一个小的示例程序还是比较简单,这不我之前就是针对Pyt ...
随机推荐
- RESTful架构&简单使用Django rest framework
RESTful架构 1 什么是REST REST全称是Representational State Transfer,中文意思是表述性状态转移. 它首次出现在2000年Roy Fielding的博士论 ...
- 使用百度的富文本编辑器UEditor遇到的问题总结
1.下载地址:http://ueditor.baidu.com/website/download.html(我下载的是.net版本) 下载后要先看一下ueditor.config.js和 net/co ...
- PXE无人值守安装
简介 1.1 什么是PXE PXE(Pre-boot Execution Environment,预启动执行环境)是由Intel公司开发的最新技术,工作于Client/Server的网络模式,支持工作 ...
- Python virtualenvwrapper在Win下的安装和管理
安装: 在Win下安装wrapper的时候,需要安装一个特殊的版本,即virtualenvwrapper-win.如果安装的只是virtualenvwrapper,则会出现mkvirtualenv,l ...
- 机器学习系列-tensorflow-03-线性回归Linear Regression
利用tensorflow实现数据的线性回归 导入相关库 import tensorflow as tf import numpy import matplotlib.pyplot as plt rng ...
- Linux搭建 SVN 服务器
安装 Subversion Subversion 是一个版本控制系统,相对于的 RCS . CVS ,采用了分支管理系统,它的设计目标就是取代 CVS . yum install -y subvers ...
- [蓝点ZigBee] Zstack 之按键驱动以及控制LED灯 ZigBee/CC2530 视频资料
这一节主要演示如何在Zstack 下根据板子的不同修改按键驱动,实际演示的时候代码跳动比较多,建议大家除了看视频资料以外,还需要在网上找一下相关资料进一步学习. 视频总览:http://bphero. ...
- Module not found: Error: Can't resolve 'XXX' in 'XXXX'
故障 控制台运行webpack/npm时出现 Module not found: Error: Can't resolve 'XXX' in 'XXXX' 解决方案 npm i XXX --save ...
- React入门——制作一个TodoList App
源码 import React, { Component, Fragment } from "react"; class TodoList extends Component { ...
- MySQL数据库视图(view),视图定义、创建视图、修改视图
原文链接:https://blog.csdn.net/moxigandashu/article/details/63254901