淘先锋技术网

首页 1 2 3 4 5 6 7

容器技术简介

一切在云端,万物皆容器,说到容器,大家都会想到Docker,Docker现在几乎是容器的代名词,什么是Docker? 为什么会出现呢?
正如所谓的AB法则,before之前是什么,为什么出现after,互联网公司技术部门开发工程师、测试工程师、运维工程师、常常因为的所使用的环境不一致,频繁出现我这里可以运维,你那边为什么不能部署?加大了开发和运维的沟通成本,加班现象常常出现,容器的诞生很好的解决了开发与运维的沟通,解决了运行环境和配置问题的软件容器,方便做集成并有助于整体发布的容器虚拟化技术。达到了一次编译,到处运行的效果,那么容器生态系统包含了哪些技术呢?

容器的核心技术

容器给的核心技术主要包括、容器规范、容器的runtime、容器管理工具、Registries

(1)容器规范:
为了保证不同容器之间能够兼容,Google在内的若干公司成立了一个叫OPen Container Initative (OCI)的组织,其目的是为了制定容器开放的容器规范。

目前OCI发布了两个规范:runtime spec和image format spec。有了这两个规范,不同组织和厂商开发的容器能够在不同的runtime上运行。这样保证了容器的可移植性和互相操作性。

容器runtime
runtime是容器真正运行的地方,容器运行时提供了对容器的抽象层,使得容器可以像独立的进程一样在主机上运行。runc 是DOcker自己开发的容器runtime,符合oci规范,也是现在的Docker的默认runtime。

(2)容器管理工具

只有runtime还不够,用户得有工具来管理容器,runc的管理工具是docker engine 包含了后台deamon和cli docker Daemon客户端工具,用于同Docker Daemon进行通信,执行用户指令,可部署在Docker Host上,也可以部署在其它主机,能够连接到Docker Daemon即可操作, Docker CLI是Docker的命令行工具,它提供了一组命令,可以用来管理Docker容器、镜像、网络和卷等。

(3)Registry
容器是通过image创建的,需要有一个仓库来统一存放image,这个仓库就叫做Registry,功能类似github 企业可以用docker Registry搭建私有的Registry。

容器平台技术

容器平台技术、包括容器编排引擎、容器管理平台等

(1)容器编排引擎
所谓的编排,通常包括容器管理、调度、集群、服务发现等,通过容器编排引擎,完成微服务的调用,实现业务需求。自动化集成:Kubernetes容器引擎,Kubernetes简称K8S,是一个开源的分布式的容器编排引擎,用来对容器化应用进行自动化部署和管理。

(2)容器的管理平台

容器给管理平台是架构在容器编排引擎之上的一个更为通用平台,用来管理容器的生命周期,容器日常的运维,如启停、查看日志等,Portainer正是容器管理平台的一种,支持多种容器技术,如Docker、Kubernetes和Swarm等。它提供了一个易于使用的Web UI界面,可用于管理和监控容器和集群。

容器的支持技术

容器的支持技术主要分为容器的网络(docke network)、服务发现(etcd zookeeper)、监控(Promethus)、数据管理(容器与主机之前的数据管理技术)、日志管理(kibanna)、安全性等

Docker理念

Docker是基于Go语言实现的云开源项目。也就是通过对应用组件的封装、分发、部署、运行等生命周期的管理,使用户的APP(可以是一个WEB应用或数据库应用等等)及其运行环境能够做到“一次镜像,处处运行”。

Docker的出现解决了什么问题?
通过镜像成为运行在Docker容器上面的实例,而 Docker容器在任何操作系统上都是一致的,这就实现了跨平台、跨服务器。只需要一次配置好环境,换到别的机子上就可以一键部署好,大大简化了操作。
在这里插入图片描述

容器与虚拟机的对比

虚拟机的缺点:
1 资源占用多
2 冗余步骤多
3 启动慢

容器的优点
1.启动速度快
2.占用体积下
3.容器之间互相隔离,每个容器有自己的文件系统 ,容器之间进程不会相互影响,能区分计算资源。
4.性能、尤其是内存和IO的开销

Docker安装

CentOS Docker 安装

Centos 7下载路径

安装步骤
1.卸载旧版本

yum remove docker \
                  docker-client \
                  docker-client-latest \
                  docker-common \
                  docker-latest \
                  docker-latest-logrotate \
                  docker-logrotate \
                  docker-engine

2.yum安装gcc相关
确保能上外网
安装gcc

yum -y install gcc
yum -y install gcc-c++

3.安装所需要的软件包并设置仓库地址
在新主机上首次安装Docker Engine之前,您需要设置Docker存储库。之后,您可以从存储库中安装和更新Docker

yum install -y yum-utils
yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo (不推荐)

推荐使用阿里的仓库地址

4.更新yum软件包索引
yum makecache fast ( 将软件包信息提前在本地索引缓存,用来提高搜索安装软件的速度,建议执行这个命令可以提升yum安装的速度)

5.安装docker Engine(引擎)

安装Docker引擎、容器和Docker Compose

 yum install docker-ce docker-ce-cli containerd.io docker-buildx-plugin docker-compose-plugin

6.启动docker

systemctl start docker

7.测试docker

systemctl  status docker
docker version
docker run hello-world

8.卸载docker

(1).卸载Docker Engine cli、containerd和Docker Compose软件包:

yum remove docker-ce docker-ce-cli containerd.io docker-buildx-plugin docker-compose-plugin docker-ce-rootless-extras

(2)主机上的映像、容器、卷或自定义配置文件不会自动删除。要删除所有图像、容器和卷,请执行以下操作:

rm -rf /var/lib/docker
rm -rf /var/lib/containerd

配置阿里云镜像加速器

地址:https://cr.console.aliyun.com/cn-hangzhou/instances

1.输入淘宝账号进行登录

2.登录成功后进入到容器镜像服务页面,选择镜像工具>镜像加速器>获取镜像加速器地址

https://o8g3n837.mirror.aliyuncs.com
在这里插入图片描述

3.配置镜像加速器
根据所安装操作系统镜像版本选择对应的安装步骤
在这里插入图片描述
4.修改daemon.json文件

mkdir -p /etc/docker 

tee /etc/docker/daemon.json <<-'EOF' { "registry-mirrors": ["https://o8g3n837.mirror.aliyuncs.com"] }EOF