云原生(二) | Docker 篇之轻松学会原理|架构|安装|加速
前言
一文精讲一个知识点,多了你记不住,一句废话都没有
经典语录:人情绪的尽头不是脏话不是发泄,人情绪的尽头是沉默
一、Docker 架构
Client: 客户端;操作 docker 服务器的客户端(命令行或者界面)
Docker_Host:Docker 主机;安装 Docker 服务的主机
Docker_Daemon:后台进程;运行在 Docker 服务器的后台进程
Containers:容器;在 Docker 服务器中的容器(一个容器一般是一个应用实例,容器间互相隔离)
K8S:CRI(Container Runtime Interface)
Images:镜像、映像、程序包;Image 是只读模板,其中包含创建 Docker 容器的说明。容器是由 Image 运行而来,Image 固定不变。
Registries:仓库;存储 Docker Image 的地方。官方远程仓库地址: https://hub.docker.com/search
Docker 用 Go 编程语言编写,并利用 Linux 内核的多种功能来交付其功能。 Docker 使用一种称为名称空间的技术来提供容器的隔离工作区。 运行容器时,Docker 会为该容器创建一组名称空间。 这些名称空间提供了一层隔离。 容器的每个方面都在单独的名称空间中运行,并且对其的访问仅限于该名称空间。
容器与虚拟机
二、Docker 隔离原理
namespace 6 项隔离 (资源隔离)
cgroups 资源限制 (资源限制)
cgroup 提供的主要功能如下:
资源限制:限制任务使用的资源总额,并在超过这个 配额 时发出提示
优先级分配:分配 CPU 时间片数量及磁盘 IO 带宽大小、控制任务运行的优先级
资源统计:统计系统资源使用量,如 CPU 使用时长、内存用量等
任务控制:对任务执行挂起、恢复等操作
cgroup 资源控制系统,每种子系统独立地控制一种资源。功能如下
三、Docker 安装
以下以 centos 为例;
更多其他安装方式,详细参照文档: https://docs.docker.com/engine/install/centos/
1、移除旧版本
2、设置 docker yum 源
使用官方源地址(比较慢)
可以选择国内的一些源地址:
阿里云
清华大学源
3、安装最新 docker engine
4、安装指定版本 docker engine
1、在线安装
2、离线安装
https://download.docker.com/linux/centos/7/x86_64/stable/Packages/
rpm -ivh xxx.rpm
可以下载 tar
解压启动即可
https://docs.docker.com/engine/install/binaries/#install-daemon-and-client-binaries-on-linux
5、启动服务
6、镜像加速
以后 docker 下载直接从阿里云拉取相关镜像
/etc/docker/daemon.json 是 Docker 的核心配置文件。
7、 可视化界面-Portainer
1、什么是 Portainer
https://documentation.portainer.io/
Portainer 社区版 2.0 拥有超过 50 万的普通用户,是功能强大的开源工具集,可让您轻松地在 Docker, Swarm,Kubernetes 和 Azure ACI 中构建和管理容器。
Portainer 的工作原理是在易于使用的 GUI 后面隐藏使管理容器变得困难的复杂性。通过消除用户使用 CLI,编写 YAML 或理解清单的需求,Portainer 使部署应用程序和解决问题变得如此简单,任何人都可以做到。
Portainer 开发团队在这里为您的 Docker 之旅提供帮助。
2、安装
界面显示
版权声明: 本文为 InfoQ 作者【Lansonli】的原创文章。
原文链接:【http://xie.infoq.cn/article/76fa4a3bb6509f02f88bdc5ce】。文章转载请联系作者。
评论