设为首页 收藏本站
查看: 1137|回复: 0

[经验分享] 3、《每天5分钟玩转Docker容器技术》学习-Docker架构

[复制链接]

尚未签到

发表于 2019-2-22 07:45:13 | 显示全部楼层 |阅读模式
  ------------------------------------重要说明------------------------------------
  本文内容都是参考Cloudman系列进行学习,是个人学习过程记录!
  原版请参考cloudman《每天5分钟玩转Docker容器技术》Cloudman博客如下:
  https://blog.运维网.com/cloudman
  ------------------------------------重要说明------------------------------------
  Docker 服务器 - Docker daemon
  Docker 客户端 – Client
  Docker 容器 - Container
  Docker 镜像 - Image
  Registry – 仓库
  记忆理解:首先搭建一个码头dock/docker(Docker daemon),码头需要管理吗?(Docker client),码头干什么呢?运送集装箱(container),集装箱里面装的是什么呢?(货物/image),货物从哪里来的呢?(registry仓库)
  Docker 架构如下图所示:

  Docker 采用的是 Client/Server 架构。客户端向服务器发送请求,服务器负责构建、运行和分发容器。客户端和服务器可以运行在同一个 Host 上,客户端也可以通过 socket 或 REST API 与远程的服务器通信。
1. Docker 客户端
  最常用的 Docker 客户端是docker 命令。通过docker 我们可以方便地在 Host 上构建和运行容器。
  docker 支持很多操作(子命令),后面会逐步用到。

  除了docker 命令行工具,用户也可以通过 REST API 与服务器通信。
2. Docker 服务器
  Docker daemon 是服务器组件,以 Linux 后台服务的方式运行。

  Docker daemon 运行在 Docker host 上,负责创建、运行、监控容器,构建、存储镜像。
  默认配置下,Docker daemon 只能响应来自本地 Host 的客户端请求。如果要允许远程客户端请求,需要在配置文件中打开 TCP 监听,步骤如下:
  1、编辑配置文件 /etc/systemd/system/multi-user.target.wants/docker.service,在环境变量 ExecStart 后面添加 -H tcp://0.0.0.0,允许来自任意 IP 的客户端连接。

  如果使用的是其他操作系统,配置文件的位置可能会不一样
  2、重启 Docker daemon。

  3、服务器 IP 为 192.168.56.102,客户端在命令行里加上 -H 参数,即可与远程服务器通信。

  info 子命令用于查看 Docker 服务器的信息。
3. Docker 镜像
  可将 Docker 镜像看着只读模板,通过它可以创建 Docker 容器。
  例如某个镜像可能包含一个 Ubuntu 操作系统、一个 Apache HTTP Server 以及用户开发的 Web 应用。
  镜像有多种生成方法:
  1、可以从无到有开始创建镜像
  2、也可以下载并使用别人创建好的现成的镜像
  3、还可以在现有镜像上创建新的镜像
  我们可以将镜像的内容和创建步骤描述在一个文本文件中,这个文件被称作 Dockerfile,通过执行 docker build  命令可以构建出 Docker 镜像,后面我们会讨论。
4. Docker 容器
  Docker 容器就是 Docker 镜像的运行实例。
  用户可以通过 CLI(docker)或是 API 启动、停止、移动或删除容器。可以这么认为,对于应用软件,镜像是软件生命周期的构建和打包阶段,而容器则是启动和运行阶段。
5. Registry仓库
  Registry 是存放 Docker 镜像的仓库,Registry 分私有和公有两种。
  Docker Hub(https://hub.docker.com/) 是默认的 Registry,由 Docker 公司维护,上面有数以万计的镜像,用户可以自由下载和使用。
  出于对速度或安全的考虑,用户也可以创建自己的私有 Registry。后面我们会学习如何搭建私有 Registry。
  docker pull 命令可以从 Registry 下载镜像。
  docker run 命令则是先下载镜像(如果本地没有),然后再启动容器。
  还记得我们运行的第一个容器吗?现在通过它来体会一下 Docker 各个组件是如何协作的。
  容器启动过程如下:

  1、Docker 客户端执行 docker run 命令。
  2、Docker daemon 发现本地没有 httpd 镜像。
  3、daemon 从 Docker Hub 下载镜像。
  4、下载完成,镜像 httpd 被保存到本地。
  5、Docker daemon 启动容器。
  docker images 可以查看到 httpd 已经下载到本地

  docker ps 或者 docker container ls 显示容器正在运行。

6. 小结
  Docker 借鉴了集装箱的概念。标准集装箱将货物运往世界各地,Docker 将这个模型运用到自己的设计哲学中,唯一不同的是:集装箱运输货物,而 Docker 运输软件。
  每个容器都有一个软件镜像,相当于集装箱中的货物。容器可以被创建、启动、关闭和销毁。和集装箱一样,Docker 在执行这些操作时,并不关心容器里到底装的什么,它不管里面是 Web Server,还是 Database。
  用户不需要关心容器最终会在哪里运行,因为哪里都可以运行。
  开发人员可以在笔记本上构建镜像并上传到 Registry,然后 QA 人员将镜像下载到物理或虚拟机做测试,最终容器会部署到生产环境。
  使用 Docker 以及容器技术,我们可以快速构建一个应用服务器、一个消息中间件、一个数据库、一个持续集成环境。因为 Docker Hub 上有我们能想到的几乎所有的镜像。
  不知大家是否意识到,潘多拉盒子已经被打开。容器不但降低了我们学习新技术的门槛,更提高了效率。
  如果你是一个运维人员,想研究负载均衡软件 HAProxy,只需要执行docker run haproxy,无需繁琐的手工安装和配置既可以直接进入实战。
  如果你是一个开发人员,想学习怎么用 django 开发 Python Web 应用,执行 docker run django,在容器里随便折腾吧,不用担心会搞乱 Host 的环境。
  不夸张的说:容器大大提升了 IT 人员的幸福指数。
  ------------------------------------重要说明------------------------------------
  本文内容都是参考Cloudman系列进行学习,是个人学习过程记录!
  原版请参考cloudman《每天5分钟玩转Docker容器技术》Cloudman博客如下:
  https://blog.运维网.com/cloudman
  ------------------------------------重要说明------------------------------------
  书籍:
  1.《每天5分钟玩转Kubernetes》
  https://item.jd.com/26225745440.html
  2.《每天5分钟玩转Docker容器技术》
  https://item.jd.com/16936307278.html
  3.《每天5分钟玩转OpenStack》
  https://item.jd.com/12086376.html



运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-675493-1-1.html 上篇帖子: 2、《每天5分钟玩转Docker容器技术》学习-Docker What why how 下篇帖子: 4、《每天5分钟玩转Docker容器技术》学习--Docker环境搭建
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表