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 ...
随机推荐
- 001.Redis简介及安装
一 Redis简介 1.1 Redis 简介 Redis 是完全开源免费的,遵守BSD协议,是一个高性能的key-value数据库. Redis 与其他 key-value 缓存产品有以下三个特点: ...
- xss小结-从xss平台搭建到csp规则
0x00前言 xss是跨站脚本攻击,利用嵌入js代码达到‘控制’对方浏览器的作用,测试的时候我们是用alert(1)弹窗,而做CTF也好,实际中的漏洞利用也好一般是用xss获取管理员的cookie 0 ...
- python中sqlite问题和坑
import sqlite3 #导入模块 conn = sqlite3.connect('example.db') C=conn.cursor() #创建表 C.execute('''CREATE T ...
- Fruit HDU - 2152 -上下界生成函数
HDU - 2152 思路 :有上下界的生成函数 .生成函数即母函数,是组合数学中尤其是计数方面的一个重要理论和工具.生成函数有普通型生成函数和指数型生成函数两种, 其中普通型用的比较多.形式上说,普 ...
- linux 学习笔记 显示压缩文件 gong.zip 的文件内容
#zip -v gong zip zip info: xxx >删除压缩文件中俄smart.txt 文件 #zip -d gong.zip smart.txt deleting:smart.tx ...
- Xamarin Essentials教程屏幕常亮ScreenLock
Xamarin Essentials教程屏幕常亮ScreenLock 在一段时间内,如果用户没有对设备进行操作,设备就会自动关闭屏幕.用户必须手动操作,才能点亮屏幕.但是很多应用需要在用户没有操作 ...
- 谷歌浏览器把网页打印成pdf
一.认识markdown mweb for mac2.2.7 激活版 二.pdf和word pdf的可移植性比较好,在不同的操作系统中都能打开,而且安全,但是可编辑性不好,所以通常用markdown编 ...
- new关键字对构造函数做了什么
new 命令 基本用法 new 命令的作用,就是执行构造函数,返回一个实例对象. 1 var Vehicle = function (){ 2 this.price = 1000; 3 }; 4 5 ...
- IDEA2018.2.2 版本配置注释模板
Ctrl+Alt+S进入设置界面(我没改过按键映射,你也可以从File-OtherSetting进入设置),找到Editor->File and Code Templates,先在Include ...
- 谈一谈java里面的反射机制
首先来看看百度百科中是如何定义的: JAVA反射机制是在运行状态中,对于任意一个类,都能够知道这个类的所有属性和方法:对于任意一个对象,都能够调用它的任意方法和属性:这种动态获取信息以及动态调用对象方 ...