码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 【重识云原生】第六章容器6.1.2节——容器安装部署


        《重识云原生系列》专题索引:

    1. 第一章——不谋全局不足以谋一域
    2. 第二章计算第1节——计算虚拟化技术总述
    3. 第二章计算第2节——主流虚拟化技术之VMare ESXi
    4. 第二章计算第3节——主流虚拟化技术之Xen
    5. 第二章计算第4节——主流虚拟化技术之KVM
    6. 第二章计算第5节——商用云主机方案
    7. 第二章计算第6节——裸金属方案
    8. 第三章云存储第1节——分布式云存储总述
    9. 第三章云存储第2节——SPDK方案综述
    10. 第三章云存储第3节——Ceph统一存储方案
    11. 第三章云存储第4节——OpenStack Swift 对象存储方案
    12. 第三章云存储第5节——商用分布式云存储方案
    13. 第四章云网络第一节——云网络技术发展简述
    14. 第四章云网络4.2节——相关基础知识准备
    15. 第四章云网络4.3节——重要网络协议
    16. 第四章云网络4.3.1节——路由技术简述
    17. 第四章云网络4.3.2节——VLAN技术
    18. 第四章云网络4.3.3节——RIP协议
    19. 第四章云网络4.3.4.1-2节——OSPF协议综述
    20. 第四章云网络4.3.4.3节——OSPF协议工作原理
    21. 第四章云网络4.3.4.4节——[转载]OSPF域内路由
    22. 第四章云网络4.3.4.5节——[转载]OSPF外部路由
    23. 第四章云网络4.3.4.6节——[转载]OSPF特殊区域之Stub和Totally Stub区域详解及配置
    24. 第四章云网络4.3.4.7节——OSPF特殊区域之NSSA和Totally NSSA详解及配置
    25. 第四章云网络4.3.5节——EIGRP协议
    26. 第四章云网络4.3.6节——IS-IS协议
    27. 第四章云网络4.3.7节——BGP协议
    28. 第四章云网络4.3.7.2节——BGP协议概述
    29. 第四章云网络4.3.7.3节——BGP协议实现原理
    30. 第四章云网络4.3.7.4节——高级特性
    31. 第四章云网络4.3.7.5节——实操
    32. 第四章云网络4.3.7.6节——MP-BGP协议
    33. 第四章云网络4.3.8节——策略路由
    34. 第四章云网络4.3.9节——Graceful Restart(平滑重启)技术
    35. 第四章云网络4.3.10节——VXLAN技术
    36. 第四章云网络4.3.10.2节——VXLAN Overlay网络方案设计
    37. 第四章云网络4.3.10.3节——VXLAN隧道机制
    38. 第四章云网络4.3.10.4节——VXLAN报文转发过程
    39. 第四章云网络4.3.10.5节——VXlan组网架构
    40. 第四章云网络4.3.10.6节——VXLAN应用部署方案
    41. 第四章云网络4.4节——Spine-Leaf网络架构
    42. 第四章云网络4.5节——大二层网络
    43. 第四章云网络4.6节——Underlay 和 Overlay概念
    44. 第四章云网络4.7.1节——网络虚拟化与卸载加速技术的演进简述
    45. 第四章云网络4.7.2节——virtio网络半虚拟化简介
    46. 第四章云网络4.7.3节——Vhost-net方案
    47. 第四章云网络4.7.4节vhost-user方案——virtio的DPDK卸载方案
    48. 第四章云网络4.7.5节vDPA方案——virtio的半硬件虚拟化实现
    49. 第四章云网络4.7.6节——virtio-blk存储虚拟化方案
    50. 第四章云网络4.7.8节——SR-IOV方案
    51. 第四章云网络4.7.9节——NFV
    52. 第四章云网络4.8.1节——SDN总述
    53. 第四章云网络4.8.2.1节——OpenFlow概述
    54. 第四章云网络4.8.2.2节——OpenFlow协议详解
    55. 第四章云网络4.8.2.3节——OpenFlow运行机制
    56. 第四章云网络4.8.3.1节——Open vSwitch简介
    57. 第四章云网络4.8.3.2节——Open vSwitch工作原理详解
    58. 第四章云网络4.8.4节——OpenStack与SDN的集成
    59. 第四章云网络4.8.5节——OpenDayLight
    60. 第四章云网络4.8.6节——Dragonflow
    61.  第四章云网络4.9.1节——网络卸载加速技术综述

    62. 第四章云网络4.9.2节——传统网络卸载技术

    63. 第四章云网络4.9.3.1节——DPDK技术综述

    64. 第四章云网络4.9.3.2节——DPDK原理详解

    65. 第四章云网络4.9.4.1节——智能网卡SmartNIC方案综述

    66. 第四章云网络4.9.4.2节——智能网卡实现

    67. 第六章容器6.1.1节——容器综述

    68. 第六章容器6.1.2节——容器安装部署

    69. 第六章容器6.1.3节——Docker常用命令

    70. 第六章容器6.1.4节——Docker核心技术LXC

    71. 第六章容器6.1.5节——Docker核心技术Namespace

    72. 第六章容器6.1.6节—— Docker核心技术Chroot

    73. 第六章容器6.1.7.1节——Docker核心技术cgroups综述

    74. 第六章容器6.1.7.2节——cgroups原理剖析

    75. 第六章容器6.1.7.3节——cgroups数据结构剖析

    76. 第六章容器6.1.7.4节——cgroups使用

    77. 第六章容器6.1.8节——Docker核心技术UnionFS

    78. 第六章容器6.1.9节——Docker镜像技术剖析

    79. 第六章容器6.1.10节——DockerFile解析

    80. 第六章容器6.1.11节——docker-compose容器编排

    81. 第六章容器6.1.12节——Docker网络模型设计

    82. 第六章容器6.2.1节——Kubernetes概述

    83. 第六章容器6.2.2节——K8S架构剖析

    84. 第六章容器6.3.1节——K8S核心组件总述

    85. 第六章容器6.3.2节——API Server组件

    86. 第六章容器6.3.3节——Kube-Scheduler使用篇

    87. 第六章容器6.3.4节——etcd组件

    88. 第六章容器6.3.5节——Controller Manager概述

    89. 第六章容器6.3.6节——kubelet组件

    90. 第六章容器6.3.7节——命令行工具kubectl

    91. 第六章容器6.3.8节——kube-proxy

    92.  第六章容器6.4.1节——K8S资源对象总览

    93. 第六章容器6.4.2.1节——pod详解

    94. 第六章容器6.4.2.2节——Pod使用(上)

    95. 第六章容器6.4.2.3节——Pod使用(下)

    96. 第六章容器6.4.3节——ReplicationController

    97. 第六章容器6.4.4节——ReplicaSet组件

    98. 第六章容器基础6.4.5.1节——Deployment概述

    99. 第六章容器基础6.4.5.2节——Deployment配置详细说明

    100. 第六章容器基础6.4.5.3节——Deployment实现原理解析

    101. 第六章容器基础6.4.6节——Daemonset

    102. 第六章容器基础6.4.7节——Job

    103. 第六章容器基础6.4.8节——CronJob

    104. 第六章容器基础6.4.9.1节——Service综述

    105. 第六章容器基础6.4.9.2节——使用 Service 连接到应用

    106. 第六章容器基础6.4.9.3节——Service拓扑感知

    107. 第六章容器基础6.4.10.1节——StatefulSet概述

    108. 第六章容器基础6.4.10.2节——StatefulSet常规操作实操

    109. 第六章容器基础6.4.10.3节——StatefulSet实操案例-部署WordPress 和 MySQL

    110. 第六章容器基础6.4.10.4节——StatefulSet实操案例-使用 StatefulSet 部署Cassandra

    111. 第六章容器基础6.4.10.5节——Statefulset原理剖析

    112. 第六章容器基础6.4.11.1节——Ingress综述

    1. Docker的安装部署

            Docker的安装支持离线安装与在线安装两种方式。

    1.1 离线安装Docker系统

    第一步:下载docker离线包

    https://download.docker.com/linux/static/stable/x86_64/docker-20.10.6.tgz

            补充,也可以从Index of linux/static/stable/网址下载指定版本

    第二步:下载离线安装工具

    GitHub - Jrohy/docker-install: auto install latest docker by online/offline (binary install)

    第三步:将下载好的资源放在一个目录,例如:

    第四步:在linux环境下,创建/root/setup/docker目录,然后拷贝下载好的资源到此目录(可通过MobaXterm工具直接上传到linux目录),例如

    第五步:执行安装操作

            ①# 进入/root/setup/docker 文件夹

            指令:cd /root/setup/docker

            ②# 为 install.sh添加执行权限

            指令:chmod +x install.sh

            ③# 安装 ./install.sh -f docker-20.10.6.tgz

            安装成功后,会出现如下信息:

    Created symlink from /etc/systemd/system/multi-user.target.wants/docker.service to /usr/lib/systemd/system/docker.service.

    docker 20.10.6 install success!

    第六步:安装成功以后,检查安装状态

            指令:docker info

    1.2 在线安装Docker系统

    第一步:安装一组工具

            sudo yum install -y yum-utils

    第二步:设置 yum 仓库地址

            sudo yum-config-manager https://download.docker.com/linux/centos/docker-ce.repo

            sudo yum-config-manager http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo

    第三步:更新 yum 缓存

            sudo yum makecache fast #yum 是包管理器

    第四步:安装新版 docker

            sudo yum install -y docker-ce docker-ce-cli containerd.io

    第五步:安装成功以后,检查安装状态

            指令:docker info

    1.3 Docker服务基本操作

    • 启动docker服务

    systemctl start docker

    • 查看Docker状态

            查看docker是否启动了,是否是运行状态

    systemctl status docker

    • 设置Docker开机自启

    systemctl enable docker

    • 禁用Docker开机自启

    systemctl disable docker

    • 重新启动Docker服务

    systemctl restart docker

    • 查看Docker信息

    docker info

    • 查看docker info中具体key的信息,例如:

    docker info | grep 'Docker Root Dir:'

    • 停止docker服务

    systemctl stop docker

    1.4 Docker镜像操作实践

            本章节操作以hello-word镜像为例

    • 下载镜像

            语法:docker pull 镜像名

            案例:(下载一个名为hell-word的镜像)

            docker pull hello-world

    • 浏览镜像文件

            语法:docker images

    • 查看镜像详情

            语法:docker inspect 镜像名或镜像id

            例如:查看一个名为hello-word的镜像

            docker inspect hello-world

    • 查看镜像历史

            一个镜像是由多个层(layer)组成的,那么,我们要如何知道各个层的具体内容呢?通过 docker history 命令,可以列出各个层(layer)的创建信息,

            例如:查看hello=word的历史信息(查看镜像进行了什么操作,等。。。)

    docker history hello-world

    • 导出镜像文件

            镜像导出(linux系统中的镜像文件下载到本地-例如window),导出后给他人使用

    语法:docker save hello-world | gzip >(这里填写要导出的镜像名).tar.gz

    docker save hello-world | gzip > hello-world.tar.gz

    • 删除镜像文件

            语法:docker image rm 镜像名或镜像id

            例如:删除一个名为hello-word的镜像

    docker image rm hello-world

    • 导入镜像操作

            镜像导入(要在hello-world.tar.gz 文件所在目录下执行这个命令)注意这里的hello-world.tar.gz 文件是我们要导入的镜像,这里以hello-world.tar.gz 文件为例。

    docker load < hello-world.tar.gz

    • 运行镜像文件

            基于镜像,启动容器运行。

            语法:docker run 镜像名

    docker run hello-world

    1.5 Docker 容器操作实践

            本次以CentOS镜像为例,讲解容器的基本操作。

    • 下载镜像(Image)

            通过docker pull指令下载CentOS镜像,例如

    docker pull centos:7

            说明,官方镜像仓库地址为Docker Hub

            下载完以后,查看centos7镜像文件。

    docker images

    • 创建并启动容器(Container)

    基本语法解析:

            docker run -it xxxx bash

    语法解析

            1)xxxx - :镜像名, 或 image id 的前几位,

            2)-it :这是两个参数(-i表示交互式操作, -t 表示终端)

            3) bash :表示进入操作终端,基于交互式进行相关操作(例如执行linux相关指令)。

            案例:通过docker启动运行 centos7镜像

    docker run -it centos:7 bash

    • 查看Docker中的容器(Container)

            查看docker运行中的容器(要在宿主机执行docker指令)

    docker ps

            说明,假如在容器中执行docker指令会出现如下问题,例如:

    • 查看docker运行中的所有容器

    docker ps -a

            解释-a表示全部(all)

    • 查看容器日志(logs)信息

            查看容器启动运行日志时,这个指令非常重要,假如容器没有启动,要通过此指令去看一下错误日志。

            docker container logs 802 #802为自己的容器id(一般写前三位即可)

            说明,查看容器的运行日志时,容器应该处于一种运行状态.

    • 停止(stop)或重启(Restart)容器(Container)

            停止运行的容器,代码如下:

    docker container stop 802 #802为容器自己的id

            重新启动容器,代码如下:

    docker container restart 802 #802位容器自己的id

    • 进入(exec)指定容器(Container)

            当容器处于运行状态,要进入容器,可以使用 docker exec 命令,例如:

    docker exec -it 802 bash #802为容器id

            说明,假如容器处于一种非运行状态,此时你执行docker exec进入容器会出现如下问题:

    • 从容器(Container)中退出(exit)

            假如从宿主机进入了启动的容器,退出容器需要使用exit指令,例如:

    exit

    • 删除(rm)容器(Container)

            假如容器不用了,可执行删除操作,例如:

    docker container rm 802 #802为容器id

            说明,假如容器正在运行执行删除,会出现如下问题,例如:

            其中,如果删除运行中的容器,需要添加 -f 参数执行强制删除,例如:

    docker container rm -f 802 #802为容器id

    • 清理所有处于终止状态容器

    docker container prune

            说明,执行完这个指令以后,可以通过docker ps -a 再查看容器,看看是否有删除

    2. 配置

    2.1 配置加速器

            由于众所周知的一些原因,我们访问 Docker Hub 速度非常慢,为此我们需要添加一个国内的镜像站来作为极速器。

    2.1.1 阿里云加速器

            登录地址开放云原生应用-云原生(Cloud Native)-云原生介绍 - 阿里云 ,点击"创建我的容器镜像",找到"Docker Hub 镜像站点",如下图:

    sudo mkdir -p /etc/docker sudo tee /etc/docker/daemon.json <<-'EOF' { "registry-mirrors": ["https://78ssvya7.mirror.aliyuncs.com"] } EOF sudo systemctl daemon-reload sudo systemctl restart docker

    2.1.2 DaoCloud 加速器

            注册 DaoCloud 账户(支持微信登录),然后访问:道客镜像站_DaoCloud道客

    curl -sSL https://get.daocloud.io/daotools/set_mirror.sh | sh -s http://b149d2fd.m.daocloud.io

    2.2 Docker开启远程管理

            默认配置下,Docker daemon 只能响应来自本地 Host 的客户端请求。如果要允许远程客户端请求,需要在配置文件中打开 TCP 监听,步骤如下:

    2.2.1 修改配置文件

            编辑配置文件 /etc/systemd/system/multi-user.target.wants/docker.service,在环境变量 ExecStart 后面添加 -H tcp://0.0.0.0,允许来自任意 IP 的客户端连接。

    2.2.2 重启Docker daemon

    systemctl daemon-reload systemctl restart docker

    2.2.3 验证

    参考链接

    聊聊Docker理论知识(二) - 小水滴18 - 博客园

    Docker的安装_没名字的星星的博客-CSDN博客_docker安装

    docker安装详细教程_polo.feng的博客-CSDN博客_安装docker

    Docker系列-docker安装 - 狮子挽歌丿 - 博客园

    Docker安装及使用 - 知乎

     《重识云原生系列》专题索引:

    1. 第一章——不谋全局不足以谋一域
    2. 第二章计算第1节——计算虚拟化技术总述
    3. 第二章计算第2节——主流虚拟化技术之VMare ESXi
    4. 第二章计算第3节——主流虚拟化技术之Xen
    5. 第二章计算第4节——主流虚拟化技术之KVM
    6. 第二章计算第5节——商用云主机方案
    7. 第二章计算第6节——裸金属方案
    8. 第三章云存储第1节——分布式云存储总述
    9. 第三章云存储第2节——SPDK方案综述
    10. 第三章云存储第3节——Ceph统一存储方案
    11. 第三章云存储第4节——OpenStack Swift 对象存储方案
    12. 第三章云存储第5节——商用分布式云存储方案
    13. 第四章云网络第一节——云网络技术发展简述
    14. 第四章云网络4.2节——相关基础知识准备
    15. 第四章云网络4.3节——重要网络协议
    16. 第四章云网络4.3.1节——路由技术简述
    17. 第四章云网络4.3.2节——VLAN技术
    18. 第四章云网络4.3.3节——RIP协议
    19. 第四章云网络4.3.4节——OSPF协议
    20. 第四章云网络4.3.5节——EIGRP协议
    21. 第四章云网络4.3.6节——IS-IS协议
    22. 第四章云网络4.3.7节——BGP协议
    23. 第四章云网络4.3.7.2节——BGP协议概述
    24. 第四章云网络4.3.7.3节——BGP协议实现原理
    25. 第四章云网络4.3.7.4节——高级特性
    26. 第四章云网络4.3.7.5节——实操
    27. 第四章云网络4.3.7.6节——MP-BGP协议
    28. 第四章云网络4.3.8节——策略路由
    29. 第四章云网络4.3.9节——Graceful Restart(平滑重启)技术
    30. 第四章云网络4.3.10节——VXLAN技术
    31. 第四章云网络4.3.10.2节——VXLAN Overlay网络方案设计
    32. 第四章云网络4.3.10.3节——VXLAN隧道机制
    33. 第四章云网络4.3.10.4节——VXLAN报文转发过程
    34. 第四章云网络4.3.10.5节——VXlan组网架构
    35. 第四章云网络4.3.10.6节——VXLAN应用部署方案
    36. 第四章云网络4.4节——Spine-Leaf网络架构
    37. 第四章云网络4.5节——大二层网络
    38. 第四章云网络4.6节——Underlay 和 Overlay概念
    39. 第四章云网络4.7.1节——网络虚拟化与卸载加速技术的演进简述
    40. 第四章云网络4.7.2节——virtio网络半虚拟化简介
    41. 第四章云网络4.7.3节——Vhost-net方案
    42. 第四章云网络4.7.4节vhost-user方案——virtio的DPDK卸载方案
    43. 第四章云网络4.7.5节vDPA方案——virtio的半硬件虚拟化实现
    44. 第四章云网络4.7.6节——virtio-blk存储虚拟化方案
    45. 第四章云网络4.7.8节——SR-IOV方案
    46. 第四章云网络4.7.9节——NFV
    47. 第四章云网络4.8.1节——SDN总述
    48. 第四章云网络4.8.2.1节——OpenFlow概述
    49. 第四章云网络4.8.2.2节——OpenFlow协议详解
    50. 第四章云网络4.8.2.3节——OpenFlow运行机制
    51. 第四章云网络4.8.3.1节——Open vSwitch简介
    52. 第四章云网络4.8.3.2节——Open vSwitch工作原理详解
    53. 第四章云网络4.8.4节——OpenStack与SDN的集成
    54. 第四章云网络4.8.5节——OpenDayLight
    55. 第四章云网络4.8.6节——Dragonflow
    56.  第四章云网络4.9.1节——网络卸载加速技术综述

    57. 第四章云网络4.9.2节——传统网络卸载技术

    58. 第四章云网络4.9.3.1节——DPDK技术综述

    59. 第四章云网络4.9.3.2节——DPDK原理详解

    60. 第四章云网络4.9.4.1节——智能网卡SmartNIC方案综述

    61. 第四章云网络4.9.4.2节——智能网卡实现

    62. 第六章容器6.1.1节——容器综述

    63. 第六章容器6.1.2节——容器安装部署

    64. 第六章容器6.1.3节——Docker常用命令

    65. 第六章容器6.1.4节——Docker核心技术LXC

    66. 第六章容器6.1.5节——Docker核心技术Namespace

  • 相关阅读:
    理解MySQL事务
    C进阶 -- 自定义类型
    正向代理与反向代理:理解代理服务器在网络通信中的不同作用
    【GIT版本控制】--协作流程
    一起Talk Android吧(第四百一十一回:绘制文字)
    C++重载 强制类型转换运算符
    CF 111B Petya and Divisors
    【已解决】SpringBoot图片更新需重启服务器才能显示
    java设计模式之策略模式
    网络安全笔记8——虚拟专网技术
  • 原文地址:https://blog.csdn.net/junbaozi/article/details/126439626
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号