Ring3的用户态是没有权限管理硬件的,须要切换到内核态Ring0,这样的切换(系统调用)称之为上下文切换,物理机到虚拟机屡次的上下文切换,势必会致使性能出现问题。node
对于全虚拟化,inter实现了技术VT-x,在cpu硬件上实现了加速转换,CentOS7默认是不须要开启的linux
[root@linux-node1 qemu]# lscpu|grep cache L1d cache: 32K L1i cache: 32K L2 cache: 256K L3 cache: 6144K
L1是静态缓存,造价高,L2,L3是动态缓存,经过脉冲的方式写入0和1,造价较低。cache解决了cpu处理快,内存处理慢的问题,相似于memcaced和数据库。若是cpu调度器把进程随便调度到其余cpu上,而不是当前L1,L2,L3的缓存cpu上,缓存就不生效了,就会产生miss,为了减小cache miss,须要把KVM进程绑定到固定的cpu上,可使用taskset把某一个进程绑定(cpu亲和力绑定,能够提升20%的性能)在某一个cpu上,例如:taskset -cp 1 25718(1指的是cpu1,也能够绑定到多个cpu上,25718是指的pid).
cpu绑定的优势:提升性能,20%以上
cpu绑定的缺点:不方便迁移,灵活性差web
内存寻址:算法
宿主机虚拟内存 -> 宿主机物理内存
虚拟机的虚拟内存 -> 虚拟机的物理内存 数据库
之前VMM经过采用影子列表解决内存转换的问题,影子页表是一种比较成熟的纯软件的内存虚拟化方式,但影子页表固有的局限性,影响了VMM的性能,例如,客户机中有多个CPU,多个虚拟CPU之间同步页面数据将致使影子页表更新次数幅度增长,测试页表将带来异常严重的性能损失。vim
在此之际,Inter在最新的Core I7系列处理器上集成了EPT技术(对应AMD的为RVI技术),以硬件辅助的方式完成客户物理内存到机器物理内存的转换,完成内存虚拟化,并以有效的方式弥补了影子页表的缺陷,该技术默认是开启的centos
宿主机上默认会开启ksmd进程,该进程做为内核中的守护进程存在,它按期执行页面扫描,识别副本页面并合并副本,释放这些页面以供它用,CentOS7默认是开启的缓存
[root@linux-node1 qemu]# ps aux|grep ksmd|grep -v grep root 31 0.0 0.0 0 0 ? SN 07:07 0:00 [ksmd]
[root@linux-node1 qemu]# cat /sys/kernel/mm/transparent_hugepage/enabled [always] madvise never
IO调度算法,也叫电梯算法,详情请看http://www.unixhot.com/article/4
① Noop Scheduler:简单的FIFO队列,最简单的调度算法,因为会产生读IO的阻塞,通常使用在SSD硬盘,此时不须要调度,IO效果很是好
② Anticipatory IO Scheduler(as scheduler)适合大数据顺序顺序存储的文件服务器,如ftp server和web server,不适合数据库环境,DB服务器不要使用这种算法。
③ Deadline Schedler:按照截止时间的调度算法,为了防止出现读取被饿死的现象,按照截止时间进行调整,默认的是读期限短于写期限,就不会产生饿死的情况,通常应用在数据库
④ Complete Fair Queueing Schedule:彻底公平的排队的IO调度算法,保证每一个进程相对特别公平的使用IO服务器
2.6 内核: Noop CFQ AS Deadline 默认:CFQ
3.10内核: Noop CFQ Deadline 默认:Deadlineoop
[root@linux-node1 qemu]# dmesg|grep -i "scheduler" #查看本机Centos7默认所支持的调度算法
[ 1.207359] io scheduler noop registered [ 1.207362] io scheduler deadline registered (default) [ 1.207404] io scheduler cfq registered
[root@linux-node1 qemu]# cat /sys/block/sda/queue/scheduler #centos 7 默认是deadline noop [deadline] cfq
一开始建立的虚拟磁盘就是镜像
[root@linux-node1 data]# ls centos-7-x86_64
centos-7-x86_64