openstack-KVM-vCPU
一、KVM基础功能
(1)支持
硬件支持 VT-x VT-d
系统支持 kernel > 3.5
(2)计算机系统的子系统
CPU 处理器
Memory 内存
Storage 存储
Network 网络
Display 显示
二、 CPU
SMP(Symmetrical Multi-Processing),对称多处理技术,是指在一个计算机上汇集了一组处理器(多CPU),各CPU之间共享内存子系统以及总线结构。
SMT(Simultaneous multithreading),同时多线程。SMT 可通过复制处理器上的结构状态,让同一个处理器上的多个线程同步执行并共享处理器的执行资源。
CMP(Chip multiprocessors),即单芯片多处理器,也指多核心。其思想是将大规模并行处理器中的SMP(对称多处理器)集成到同一芯片内,各个处理器并行执行不同的进程。与CMP比较, SMT处理器结构的灵活性比较突出。
NUMA (非统一内存访问),是一种用于多处理器的电脑记忆体设计,内存访问时间取决于处理器的内存位置。 在NUMA下,处理器访问它自己的本地存储器的速度比非本地存储器(存储器的地方到另一个处理器之间共享的处理器或存储器)快一些。
NUMA架构在逻辑上遵循对称多处理(SMP)架构。
1、vCPU (virtual CPU)
(1)进程模式
用户模式 (User Mode): 主要处理I/O的模拟和管理,由QEMU实现。
内核模式 (Kernel Mode) :主要处理高性能和高安全的指令。
客户模式 (Guest Mode) :主要执行Guest的大部分命令。
图1 vCPU在KVM中的三种执行模式
(2)kvm
图2 KVM系统的分层架构
2、SMP
SMP(Symmetric Multi-Processor)对称多处理器。是指在一个计算机上汇集了一组处理器(多CPU),各CPU之间共享内存子系统以及总线结构。
3、CPU 超配
虚拟机的 vCPU总数可以超过物理CPU数量,这个叫 CPU over-commit(超配)。KVM允许 over-commit,这个特性使得虚拟机能够充分利用宿主机的 CPU 资源,但前提是在同一时刻,不是所有的虚拟机都满负荷运行。
4、CPU 模型
(1)CPU模型
qemu64
qemu32
直接传递
其它POWER
(2)VMM自定义策略的CPU类型,可以提供一些高级的过滤功能,同一组硬件平台上的动态迁移更加平滑和安全。
CPU类型存放位置及定义格式:
more /usr/share/libvirt/cpu_map.xml | grep "model name"
<domain type='kvm'>
<cpu mode='custom' match='exact'>
<model fallback='allow'>Westmere</model>
</cpu>
</domain>
(3)使用物理机CPU类型,定义如下:
<domain type='kvm'>
<cpu mode='host-passthrough'>
</cpu>
</domain>
(4)使用物理机CPU类型特点:
物理CPU特性供虚拟机使用,嵌套
公有云,客户看到物理CPU,体验会比较好
虚拟机的迁移会有问题
(5)使用物理机CPU的虚拟机vCPU参数配置文件:
文件所在位置:/etc/libvirt/qemu/
打开文件:virsh edit centos-2-1(虚拟机名)
<vcpu placement='static'></vcpu>
<cpu mode='host-passthrough' check='partial'>
<topology sockets='' cores='' threads=''/>
</cpu>
注:CPU插槽为2,内核为4,超线程为2。
(6)使用coreduo CPU的虚拟机vCPU参数配置文件:
<vcpu placement='static'></vcpu>
<cpu mode='custom' match='exact' check='partial'>
<model fallback='allow'>coreduo</model>
<topology sockets='' cores='' threads=''/>
</cpu>
注:CPU插槽为2,内核为4,超线程为2。
5、进程的处理器亲和性和vCPU绑定
进程的处理器亲和性(Processor Affinity),即CPU的绑定设置,是指将进程绑定到特定的一个或多个CPU上去执行,而不允许将进程调度到其他的CPU上。
(1)开机进入grub时,隔离1,2号CPU:
grub add
isolcpus=1,2
(2)查处理器编号对应的进程总数:
ps -eLo psr | grep 0 | wc -l
ps -eLo psr | grep 1 | wc -l
ps -eLo psr | grep 2 | wc -l
ps -eLo psr | grep 3 | wc –l
(3)查CPU编号对应的进程等信息:
ps -eLo ruser,pid,ppid,lwp,psr,args | awk '{if($5==1) print $0}'
ps -eLo ruser,pid,ppid,lwp,psr,args | awk '{if($5==2) print $0}'
参数:
migration:用于进程在没CPU间迁移
kworker:用于处理workqueues
ksoftirqd:用于调度CPU软中断的进程
-e:显示所有进程
-L:显示LWP(light weight process)
-o:自定义输出
psr:处理器编号
lwp:线程ID
ruser:运行进程的用户
pid:进程ID
ppid:父进程ID
args:运行的命令和参数
(4)字符安装虚拟机并绑定:
virt-install --name=c1 --disk path=/kvm/c1.img --memory=1024 --vcpus=2 --graphics spice --location=/kvm/CentOS.iso
ps -eLo ruser,pid,ppid,lwp,psr,args | grep qemu | grep -v grep
处理器和vCPU绑定:
taskset --help
taskset -pc 1 5339
处理器和vCPU绑定:
virsh vcpuinfo centos7.0
virsh vcpupin centos7.0 0 20
virsh vcpupin centos7.0 1 21
virsh vcpupin centos7.0 2 22
virsh vcpupin centos7.0 3 23
openstack-KVM-vCPU的更多相关文章
- openStack kvm 虚拟机CPU颗粒化控制
前一篇理解cpu topology对CPU Topology进行了学习总结,这里想总结下OpenStack下vCPU与pCPU常用的的绑定方式. 在尝试这些绑定之前,尤其是处理NUMA架构时还是建议看 ...
- OpenStack+kvm虚拟机xml格式解析
配置说明 首先介绍一下配置结构: xml配置遵循<keyword> xxxxxx </keyword>的格式,即一个配置段以<keyword>开头,以</ke ...
- 完整部署CentOS7.2+OpenStack+kvm 云平台环境(3)--为虚拟机指定固定ip
之前在测试环境(centos7.2)上部署了openstack云平台(完整部署CentOS7.2+OpenStack+kvm 云平台环境(1)--基础环境搭建),openstack在neutron组网 ...
- Migration workstation vms to openstack kvm
Migration workstation vms to openstack kvm 分别分成(磁盘是否拆分,vms 是否 有多个磁盘驱动器) 1, linux迁移 vmware workstatio ...
- 完整部署CentOS7.2+OpenStack+kvm 云平台环境(2)--云硬盘等后续配置
继上一篇博客介绍了完整部署CentOS7.2+OpenStack+kvm 云平台环境(1)--基础环境搭建,本篇继续讲述后续部分的内容 1 虚拟机相关1.1 虚拟机位置介绍 openstack上创建的 ...
- OpenStack, kvm, qemu-kvm以及libvirt之关系
OpenStack, kvm, qemu-kvm以及libvirt之关系: KVM是最底层的hypervisor,它是用来模拟CPU的运行,它缺少了对network和周边I/O的支持,所以我们是没法直 ...
- 完整部署CentOS7.2+OpenStack+kvm 云平台环境(1)--基础环境搭建
公司在IDC机房有两台很高配置的服务器,计划在上面部署openstack云平台虚拟化环境,用于承载后期开发测试和其他的一些对内业务.以下对openstack的部署过程及其使用做一详细介绍,仅仅依据本人 ...
- 完整部署CentOS7.2+OpenStack+kvm 云平台环境(4)--用OZ工具制作openstack镜像
在部署openstack云平台环境的时候,需要上传镜像到glance. 首先下载iso镜像,这里下载了centos6.5镜像,放到/usr/local/src目录下然后用OZ工具制作openstack ...
- 《4》CentOS7.0+OpenStack+kvm云平台部署—配置Nova
感谢朋友支持本博客,欢迎共同探讨交流,因为能力和时间有限,错误之处在所难免,欢迎指正! 假设转载.请保留作者信息. 博客地址:http://blog.csdn.net/qq_21398167 原博文地 ...
- KVM VCPU线程调度问题的讨论
2017-11-15 今天闲着没有突然想了想VCPU线程调度的问题,具体描述如下: 当代表VCPU的线程获得控制权后,首先会通过KVM接口进入到内核,从内核进入到非根模式,那么此时站在全局调度器的点上 ...
随机推荐
- win10同时安装 office2016和visio2016
一.下载镜像文件 因为office 2016和 visio2016 镜像文件是一样的,只是名称不一样,所以只需要下载一个即可. 二.下载Office 2016 Deployment Tool工具 到微 ...
- 【合集】Hadoop 合集
0. 说明 Hadoop 随笔的目录 1. HDFS 主要内容: [HDFS_1] HDFS 的概念和特性 [HDFS_2] HDFS 的 Shell 操作 [HDFS_3] HDFS 工作机制 [H ...
- ASP.NET -- WebForm -- ViewState
ASP.NET -- WebForm -- ViewState 1. ViewState的作用 当 ASP .NET 中的表单被提交时,表单会随所有表单值一同重新出现.这是由于 ASP .NET 维 ...
- 《Java大学教程》—第16章 二维数组
多维(Multi-dimensional)数组维数由索引个数决定.常用的数组:一维(one-dimensional)数组.二维(two-dimensional)数组 16.2 创建二维数组索引从 ...
- 【漫画解读】HDFS存储原理
根据Maneesh Varshney的漫画改编,以简洁易懂的漫画形式讲解HDFS存储机制与运行原理,非常适合Hadoop/HDFS初学者理解. 一.角色出演 如上图所示,HDFS存储相关角色与功能如下 ...
- 【转】cookie如何共享到各个浏览器
可以考虑HTML5 localstorage, 点击查看原始尺寸 http://www.cnblogs.com/xiaowei0705/archive/2011/04/19/2021372.html也 ...
- js模块化规范—概念和模块化进化史以及模块化的问题
模块的概念 一个复杂的项目开发中,会写很多js文件,一个js文件执行某些特定的功能,那么每个js都可以称为一个模块,这就是模块的概念 每个js模块内部数据/实现是私有的, 只是向外部暴露一些接口(方法 ...
- node基础—process对象(管理进程)
process对象概述 process对象是一个全局对象,可以在任何地方都能访问到他,通过这个对象提供的属性和方法,使我们可以对当前运行的程序的进程进行访问和控制 process 对象是一个 glob ...
- 2018年6月,最新php工程师面试总结
面试经常被问到的问题总结 1.字符串函数 2.数组函数 3.cookie和session的区别 4.状态码以及其功能
- appium-基本操作的再次封装(加上文件路径、log、截图、异常处理)
一:日志 二:文件路径 三:截图 四:异常处理(对基本操作,例如:等待元素出现.点击.按键灯进行封装.加上截图和日志记录)