虚拟化
# 什么是虚拟化
在计算机中,虚拟化(英语:Virtualization)是一种资源管理技术,是将计算机的各种实体资源,如服务器、网络、内存及存储等,予以抽象、转换后呈现出来,打破实体结构间的不可切割的障碍,使用户可以比原本的组态更好的方式来应用这些资源。这些资源的新虚拟部份是不受现有资源的架设方式,地域或物理组态所限制。一般所指的虚拟化资源包括计算能力和资料存储。
在实际的生产环境中,虚拟化技术主要用来解决高性能的物理硬件产能过剩和老的旧的硬件产能过低的重组重用,透明化底层物理硬件,从而最大化的利用物理硬件 对资源充分利用,虚拟化技术种类很多,例如:软件虚拟化、硬件虚拟化、内存虚拟化、网络虚拟化、桌面虚拟化、服务虚拟化、虚拟机等等。# 虚拟化的软件有哪些
kvm:开源的免费的,是一个开源的系统虚拟化模块,自Linux 2.6.20之后集成在Linux的各个主要发行版本中
exsi :vmware商用的,装在裸机上,可以虚拟化出很多机器vmware 装的哪个虚拟机软件VMware Workstation Pro
------对机器进行虚拟化------
openstack(python开发的,开源的):电信云,华为云 openstack管理云平台:对虚拟化出的虚拟机进行管理,创建虚拟化,删除虚拟机
阿里云(自研,阿里飞天):云服务器,到一个网站,点点---付款--完成
腾讯自研
----- 对虚拟机进行管理----
docker:容器技术--学习---创建一个个容器
docker-compose:单机容器管理(编排)
docker-swarm:docker官方出的,用的很少
k8s:多机容器管理,容器编排:谷歌公司出的
-----容器管理------
# 名词补充:linux的软件
nginx:反向代理服务器-web项目上线--转发--负载均衡
paramiko:python的模块,ssh链接操作linux机器,远程执行命令
ansible:python写的,基于paramiko封装--基于ssh链接--速度慢一些---管理机器少一些
指令,palybook--批量操作远程linux机器
python的sdk:包
salstack:批量管理远程linxu机器的--基于bs架构:主控机--被控机
zabbix:监控php写的有web页面---监控 进程
普罗米修斯:go语言写的 ,监控容器运行,没有web页面
granfan:前端--》对接上普罗米修斯---》显示监控情况
jenkins:java写的 持续集成工具,用于监控持续重复的工作
gitlab:代码仓库
docker架构
# 起源:
Docker 是一个开源项目,诞生于 2013 年初,最初是 dotCloud 公司内部的一个业余项目。它基于 Google 公司推出的 Go 语言实现。 项目后来加入了 Linux 基金会,遵从了 Apache 2.0 协议,项目代码在 [GitHub](https://github.com/docker/docker) 上进行维护
Docker 自开源后受到广泛的关注和讨论,以至于 dotCloud 公司后来都改名为 Docker Inc。Redhat 已经在其 RHEL6.5 中集中支持 Docker;Google 也在其 PaaS 产品中广泛应用
Docker 项目的目标是实现【轻量级的操作系统虚拟化解决方案】。 Docker 的基础是 Linux 容器(LXC)等技术
LXC 的基础上 Docker 进行了进一步的封装,让用户不需要去关心容器的管理,使得操作更为简便。用户操作 Docker 的【容器就像操作一个快速轻量级的虚拟机】一样简单
# Docker 概念:
docker 是cs架构 ,mysql,redis,c和s要通信,底层tcp协议,自己做封装
dockerc和s要通信,没有自定义协议,使用的http协议,符合resful规范
mysql://地址+端口
redis://地址+端口
http://地址+端口# 镜像和容器:
Docker镜像:镜像是基于一堆文件,类似于:虚拟机装操作系统的centos xx.iso 文件,4个多g,带了软件,类似于一堆文件Docker容器:镜像运行起来,成为了容器,【当成一台虚拟机上面装了一些软件】
一个镜像运行出多个容器---容器当成轻量级的操作系统
类和对象的概念:镜像是类---生成多个对象
Registry(注册中心):docker仓库拉取镜像的位置
-镜像是从注册中心中拉取下来
Docker安装
# 在linux机器上安装:
1、卸载docker:
yum remove docker docker-common docker-selinux docker-engine
rm -rf /var/lib/docker2、yum 包更新到最新:sudo yum update
3、安装需要的软件包, yum-util 提供yum-config-manager功能,另外两个是devicemapper驱动依赖的sudo yum install -y yum-utils device-mapper-persistent-data lvm2
4、设置yum源为阿里云
sudo yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
5、安装docker:sudo yum install docker-ce
6、安装后查看docker版本:docker -v7、启动docker
systemctl status docker # 查看docker软件运行状态
systemctl start docker #启动docker
systemctl restart docker # 重启
systemctl stop docker # 停止8、拉取镜像
9、查看本地镜像:docker images10、运行成容器
运行cento7镜像成容器: docker run -di --name=centos centos:711、查看正在运行的容器:docker ps
docker exec -it 容器id号 /bin/bash
# 保存退出
systemctl daemon-reload # 重新加载docker配置
systemctl restart docker # 重启docker
docker和传统虚拟机比较
# docker 不需要虚拟化出 操作系统这一层---更轻量级--占空间更新---还能实现隔离
# 虚拟机技术的缺点:
1.资源占用太多
2.冗余步骤多
3.启动很# 容器化技术:
1.服务器资源利用率高
2.比较轻量化
3.打包镜像测试,一键运行比较Docker和虚拟机技术不同:
1.传统虚拟机虚出一条硬件,运行一个完整的操作系统,然后在这个系统上安装和运行软件
2.容器内的应用之间运行在 宿主机的内容,容器是没有自己的内核的,也没有虚拟我们的硬件,所以久轻便了
3.每个容器间是互相隔离的,每个容器内都有属于自己的文件系统,互不影响
4.安全性,docker的安全性更弱,
5.与虚拟机相比,docker隔离性更弱,docker属于进程之间的隔离,虚拟机可实现系统级别隔离6、docker创建时秒级的,docker快速迭代性,无论是开发、测试、部署都可以节约大量时间
docker镜像操作
# 搜索镜像:
去网站搜:https://hub.docker.com/
使用命令行搜:docker search mysql
# 获取镜像,拉去镜像---从register下载到本地--阿里云镜像站--加速拉取
docker pull mysql:5.7 # 下载mysql 5.7镜像
docker pull redis:latest # 下载redis最新的镜像
docker pull nginx:latest # 下载 nginx最新的镜像
docker pull centos:centos7 # 下载 nginx最新的镜像
# 查看镜像:
docker images# 删除镜像:
docker rmi redis:latest
注册并登录到远程仓库
# gitee---远程仓库---本地代码---提交
登录进入可以看到你开源的项目
docker--hub.docker--镜像----我们自己的镜像,也可以传上去,给所有人用
登录进入:就能看到你传的镜像# 注册一个hub.docker 的账号
# 登录进入
# 上传你的镜像 :
1、登录:docker login2、给镜像打个标签:docker tag 本地镜像名:标签 你的名字/镜像名字:标签
docker tag redis:latest liuqingzheng/rredis:vv1 3、上传到远程仓库:docker push liuqingzheng/rredis:vv1
docker容器操作
# 把镜像运行成容器,并且一个镜像,可以运行出多个容器
把centos7 运行成容器
--name=centos7 容器名
run :创建并运行
-di :创建出容器并运行,命令行还在宿主机
docker run -di --name=centos77 centos:centos7查看正在运行的容器:docker ps
查看所有容器:docker ps -a
查看最后一次运行的容器:docker ps -l
启动停止的容器:docker start id/名字停止运行的容器:docker stop 7d5e
停止所有在运行的容器:docker stop `docker ps -q`
删除容器:
docker rm 容器id
# 记住四条:
docker ps
docker ps -a
docker start
docker stop
# 进入到容器内部:
docker exec -it 容器id /bin/bash
docker exec -it 90fd0665494f /bin/bash# 在centos的容器中安装mysql 3.9
不是在宿主机上装
容器中