裸金属 → 虚拟机 → 容器→ 函数化、代码化
云计算涌现出很多改变传统IT架构和运维方式的新技术,比如虚拟机、容器、微服务、Serverless(无服务),无论这些技术应用在哪些场景,降低成本、提升效率是云服务永恒的主题。
1.运行物理机,也称为裸金属
2.虚拟机VM,可以在一台物理机上创建多个虚拟机,并把物理配置分发成多个虚拟配置
虚拟机常用软件:
VMware workstation(windows)
vm Sphere+ESXI (Windows server)
KVM(linux内核)
3.容器 (常用软件:docker、podman、rocket、container)
4.函数(函数化,代码化)
Docker是一个开源的应用容器引擎,基于go语言开发并遵守了apache2.0协议开源。
Docker是在Linux容器里运行应用的开源工具,是一种轻量级的“虚拟机”。
Docker的容器技术可以在一台主机上轻松为任何应用创建一个轻量级的、可移植的、自给自足的容器。
(Docker是创建容器的工具。应用运行在容器中,每个容器都有一致的运行环境,所以可以在任何主机中运行。即实现“一次封装,到处运行”的目的。)
docker借鉴了标准集装箱的概念。标准的集装箱将货物运往世界各地,Docker将这个模型运用到自己的设置中,唯一不同的是:集装箱运输货物,而Docker运输软件
Docker运行在CentOS-6.5或更高的版本的CentOS上,要求系统为64位、系统内核版本为2.6.32-431或者更高版本
④. Docker是一个Client-Server结构的系统,Docker守护进程运行在主机上,然后通过Socket连接从客户端访问,守护进程从客户端接受命令并管理运行在主机上的容器。容器,是一个运行时环境,就是我们前面说到的集装箱
docker | 虚拟机 | |
操作系统 | 共享宿主机内核 | 拥有独立的操作系统 |
部署速度 | 启动速度快秒级 | 十秒级 |
运行性能 | 性能接近原生,几乎无损耗 | 通过hypervisor对主机进行虚拟访问,会多占用一些资源(最多占用50%) |
隔离性 | namespace资源隔离,cgroup资源限制 | 完全隔离 |
存储大小 | 单机容量成百上千,镜像小,便于存储和传输 | 几十个,镜像庞大(vmdk、vdi等) |
移植性 | 轻便、灵活、适用于linux | 笨重、与虚拟化技术耦合度高 |
容器化越来越受欢迎,因为容器是:
linux六大namespace(命名空间):
类型 | 系统调用参数 | 功能说明 |
MNT Namespace | CLONE_NEWNS | 提供磁盘挂载点(文件系统)隔离能力 |
IPC Namespace | CLONE_NEWWIPS | 信号量,消息队列和共享内存 |
Net Namespace | CLONE_NEWNET | 提供网络设备,网络栈,端口等隔离能力 |
UTS Namespace | CLONE_NEWUTS | 提供主机名和域名隔离能力 |
PID Namespace | CLONE_NEWPID | 提供进程隔离能力 |
User Namespace | CLONE_NEWUSER | 用户和用户组(3.8以后的内核才支持) |
目前 Docker 只能支持 64 位系统。
#关闭防火墙和selinuxsystemctl stop firewalld.servicesetenforce 0#安装依赖包yum install -y yum-utils device-mapper-persistent-data lvm2 --------------------------------------------------------------------------------------------#yum-utils:提供了 yum-config-manager 工具。#device mapper: 是Linux内核中支持逻辑卷管理的通用设备映射机制,它为实现用于存储资源管理的块设备驱动提供了一个高度模块化的内核架构。#device mapper存储驱动程序需要 device-mapper-persistent-data 和 lvm2。--------------------------------------------------------------------------------------------#设置阿里云镜像源yum-config-manager --add-repo https://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo #安装 Docker-CE并设置为开机自动启动yum install -y docker-ce #docker-ce-cli、containerd.io 会作为依赖包被安装systemctl start docker.servicesystemctl enable docker.service
#查看 docker 版本信息docker version#docker信息查看docker info//查看的部分信息如下:
Client:Context: defaultDebug Mode: falsePlugins:app: Docker App (Docker Inc., v0.9.1-beta3)buildx: Docker Buildx (Docker Inc., v0.9.1-docker)scan: Docker Scan (Docker Inc., v0.21.0)Server:Containers: 0 #容器数量Running: 0Paused: 0Stopped: 0Images: 0 #镜像数量Server Version: 20.10.21 #server版本Storage Driver: overlay2 #docker使用的是overlay2 文件驱动Backing Filesystem: xfs #宿主机上的底层文件系统Supports d_type: trueNative Overlay Diff: trueuserxattr: falseLogging Driver: json-fileCgroup Driver: cgroupfs #cgroups 驱动,默认为cgroupfs,也可以修改为systemdCgroup Version: 1Plugins:Volume: localNetwork: bridge host ipvlan macvlan null overlayLog: awslogs fluentd gcplogs gelf journald json-file local logentries splunk syslogSwarm: inactive
上一篇:Java基础:Java流程控制
下一篇:Apache部署静态网站