CentOS7.2上用KVM安装虚拟机window10踩过的坑
最近两个星期一直在琢磨kvm安装window10操作系统,并且通过桥接模式与外界通信,经历了九九八十一难,终于搞定。下面就记录以下我们在探索的过程中踩过的坑。
安装KVM
前期准备,首先需要配置好网卡
- [root@SH-DMZ-03 network-scripts]# egrep -v '^#|^$' ifcfg-em1
- DEVICE=em1
- HWADDR=d4:be:d9:b0:13:df
- TYPE=Ethernet
- UUID=4398f8a3-e10d-4674-9533-44ae1da13fdd
- ONBOOT=yes
- NM_CONTROLLED=yes
- BOOTPROTO=static
- BRIDGE=br0
- [root@SH-DMZ-03 network-scripts]# egrep -v '^#|^$' ifcfg-br0
- DEVICE=br0
- TYPE=Bridge
- ONBOOT=yes
- BOOTPROTO=static
- IPADDR=192.168.0.11
- PREFIX=24
- GATEWAY=192.168.0.1
这里需要根据自己的实际情况进行配置
1.
系统要求:需要一台可以运行最新linux内核的intel处理器(含VT虚拟化技术)或者AMD处理器(含SVM安全虚拟化技术的AMD处理器,也可以叫AMD-V)。(如果没有配置可以在BIOS中进行配置)
使用命令进行检查:
- [root@corehadoop31 ~]# cat /proc/cpuinfo |egrep "vmx|svm"
- flags : fpu vme de pse tsc msr pae mce cx8 apic sep mtrr pge mca cmov pat pse36 clflush dts acpi mmx fxsr sse sse2 ss ht tm pbe syscall nx pdpe1gb rdtscp lm constant_tsc arch_perfmon pebs bts rep_good nopl xtopology nonstop_tsc aperfmperf eagerfpu pni pclmulqdq dtes64 monitor ds_cpl vmx smx est tm2 ssse3 cx16 xtpr pdcm pcid dca sse4_1 sse4_2 x2apic popcnt tsc_deadline_timer aes xsave avx f16c rdrand lahf_lm arat epb pln pts dtherm tpr_shadow vnmi flexpriority ept vpid fsgsbase smep erms xsaveopt
- flags : fpu vme de pse tsc msr pae mce cx8 apic sep mtrr pge mca cmov pat pse36 clflush dts acpi mmx fxsr sse sse2 ss ht tm pbe syscall nx pdpe1gb rdtscp lm constant_tsc arch_perfmon pebs bts rep_good nopl xtopology nonstop_tsc aperfmperf eagerfpu pni pclmulqdq dtes64 monitor ds_cpl vmx smx est tm2 ssse3 cx16 xtpr pdcm pcid dca sse4_1 sse4_2 x2apic popcnt tsc_deadline_timer aes xsave avx f16c rdrand lahf_lm arat epb pln pts dtherm tpr_shadow vnmi flexpriority ept vpid fsgsbase smep erms xsaveopt
- flags : fpu vme de pse tsc msr pae mce cx8 apic sep mtrr pge mca cmov pat pse36 clflush dts acpi mmx fxsr sse sse2 ss ht tm pbe syscall nx pdpe1gb rdtscp lm constant_tsc arch_perfmon pebs bts rep_good nopl xtopology nonstop_tsc aperfmperf eagerfpu pni pclmulqdq dtes64 monitor ds_cpl vmx smx est tm2 ssse3 cx16 xtpr pdcm pcid dca sse4_1 sse4_2 x2apic popcnt tsc_deadline_timer aes xsave avx f16c rdrand lahf_lm arat epb pln pts dtherm tpr_shadow vnmi flexpriority ept vpid fsgsbase smep erms xsaveopt
- ......
一般都会有大量输出,代表系统中是支持的。
2.
安装kvm所需的各种依赖包
- yum -y install qemu-kvm kvm
- yum -y install virt-manager python-virtinst qemu-kvm-tools # 安装KVM的管理工具
- yum -y install libvirt libvirt-python libguestfs-tools bridge-utils virt-viewer virt-2v
缺什么包就安装什么包,搭建一个本地的yum仓库,以便一键解决各种依赖。
3.
确定是否正确加载kvm模块
- [root@corehadoop31 ~]# lsmod |grep kvm
- kvm_intel 170181 3
- kvm 554609 1 kvm_intel
- irqbypass 13503 1 kvm
表示已经正确加载
注意:
如果该命令什么都不返回,则需要手动加载模块,参见内核模块#Manual模块处理。
kvm_intel
或kvm_amd
失败但modprobing kvm
成功,并lscpu
声称支持硬件加速,请检查BIOS设置。某些供应商,尤其是笔记本电脑供应商,默认禁用这些处 要确定是否没有硬件支持或者是否在BIOS中禁用了扩展,那么dmesg
在无法使用modprobe之后的输出将告诉您。开始安装虚拟机
1,创建磁盘并检查是否成功创建
- qemu-img create -f raw /opt/kvm.raw 10G
- # 注意类型为raw,10G容量其实没有意义
- [root@corehadoop opt]# qemu-img info /opt/kvm.raw
- image: /opt/kvm.raw
- file format: raw
- virtual size: 10G (10737418240 bytes)
- disk size: 0
证明已经成功创建!注意在生产环境一般采用 qcow2格式,因为这个格式的硬盘是动态扩容的。
- qemu-img create -f qcow2 vdisk.img 10G
2,拷贝镜像
- dd if=/dev/cdrom of=/opt/CentOS-6.5-x86_64-bin-DVD1.iso
- dd if=/dev/cdrom of=/opt/cn_windows_10_enterprise_x64_dvd_6846957.iso
注意这里如果是window10要用window10的镜像,如果要装CentOS6就要用CentOS6的镜像。我们线上已经存在镜像,因此此步可以省略。
3,启动libvirt进程。
Libvirt是管理虚拟机和其他虚拟化功能,比如存储管理,网络管理的软件集合。它包括一个API库,一个守护程序(libvirtd)和一个命令行工具(virsh);libvirt本身构建于一种抽象的概念之上。它为受支持的虚拟机监控程序实现的常用功能提供通用的API。这个进程说直白了就是管理虚拟机的,因此必须启动,否则无法安装。
systemctl restart libvirtd
4,开始创建虚拟机
- window10虚拟机
- virt-install --virt-type kvm --name window10 --ram 2048 --cdrom=/opt/cn_windows_10_enterprise_x64_dvd_6846957.iso --boot cdrom --cpu core2duo --network bridge=br0,model='e1000' --graphics vnc,listen=0.0.0.0 --disk path=/opt/kvm.raw,bus='ide' --noautoconsole --os-type=windows
- CentOS6虚拟机
- virt-install --virt-type kvm --name kvm-demo --ram 512 --cdrom=/opt/CentOS-6.5-x86_64-bin-DVD1.iso --boot cdrom --network bridge=br0 --graphics vnc,listen=0.0.0.0 --disk path=/opt/kvm.raw --noautoconsole --os-type=linux
注意:一定要了解这么一大行安装虚拟机命令,根据自己情况进行调整。
- virt-install
- --virt-type kvm # 指定安装的类型无论是centos和window都一样
- --name window10 # 指定安装的虚拟机名称,只要便于识别就好
- --ram 2048 # 指定分配给虚拟机的内存大小
- --cdrom=/opt/cn_windows_10_enterprise_x64_dvd_6846957.iso # 指定安装需要镜像的路径
- --boot cdrom # 指出从哪里进行启动,这里指定从硬盘进行启动
- --cpu core2duo # 指定所需的cpu型号,这个需要根据自己的物理机的CPU型号来进行调整。
- --network bridge=br0,model='e1000' # 网络的连接模式,注意安装虚拟机的前提是必须配置好br0桥接的模式,否则无法安装。网卡类型选择千兆虚拟网卡
- --graphics vnc,listen=0.0.0.0 # 设置vnc,默认端口5900
- --disk path=/opt/kvm.raw,bus='ide' # 指定硬盘位置,硬盘类型为IDE
- --noautoconsole
- --os-type=windows
如果是window就会卡住,此时需要用VNC,连接上。我们线上在其他机器上安装的有window-server,所以输入:IP地址,默认为5900端口即可连接上进行安装。安装完成之后,任务并没有结束,还需要能使window和外界的进行通信,如果你也像我一样配置好br0桥接模式就可以进行通信了。下面来谈以下我们遇到的坑,首先说一样我们线上的双网卡使用的team模式,当配置好了桥接之后,window虚拟机可以和我们的宿主机的业务网卡进行通信,但是无法和其他的主机的业务网卡进行通信,折腾了两天,有安装了centos6的虚拟机也发现有类似的问题。后来通过转包发现,window虚拟机的网卡和本机的网卡可以进行通信,arp可以正常响应,但是和其他区主机无法进行arp的响应。后来我们怀疑是由于team模式的双网卡造成的,果然后来配置bond的双网卡就解决这个问题。但是发现配置bond0模式起不来,提前说明一下我们有四块网卡,两块管理的网卡做的是team模式的主备模式,业务的两块网卡做的bond的负载均衡(mode=6)的模式。后来关闭了NetworkManager服务之后bond就起来了,但是team模式严重的依赖NetworkManager服务。后这天服务器直接所有的网卡全部做成了bond模式就解决了,得出了以下几点经验。
1,安装虚拟时,建议在那台物理机上装上桌面,然后再装上(yum install tigervnc-server),在本地vnc去连接,ip:1 (此时默认的端口为1) , 然后以图像界面的方式进行安装kvm虚拟机的安装,好处是可以在虚拟机安装时进行动态的调整和尝试。
2,kvm虚拟机的桥接模式目前还不支持team模式,虽然team模式是红帽新推出的模式,是未来,但是目前kvm桥接还不能很好的支持
如果你也遇到类似的问题,欢迎留言,我们一起探讨!
CentOS7.2上用KVM安装虚拟机window10踩过的坑的更多相关文章
- 在Linux服务器上使用Vbox安装虚拟机
先去官网(www.virtualbox.org)上下载对应Linux系统的Vbox版本. 我这边用的是Oracle Linux 7系统(KDE安装) 使用rpm安装virtualbox 发现报错,按照 ...
- 安装kvm安装虚拟机centos
1 安装阿里云的镜像站 #将原来的镜像备份 cd /etc/yum.repos.d/ mkdir back mv CentOS-Base.repo ./back/ # 安装阿里的镜像 wget -O ...
- 可视化爬虫Portia安装和部署踩过的坑
背景 Scrapy爬虫的确是好使好用,去过scrapinghub的官网浏览一下,更是赞叹可视化爬虫的犀利.scrapinghub有一系列的产品,开源了大部分项目,Portia负责可视化爬虫的编辑,Sp ...
- 在CentOS7命令行模式下安装虚拟机
转载:https://blog.csdn.net/sunnyfg/article/details/51493602 1.主机环境描述: 操作系统:CentOS7 系统GUI:无 CPU:Intel4代 ...
- Centos7服务器上RabbitMQ单机安装
一.背景 最近项目中用到了RabbitMQ,但是发现自己本地没有安装,此文记录一下本地RabbitMQ的安装过程.注意不同的系统安装方式略有不同,此处我们记录的是Centos7的安装方式. 二.安装方 ...
- 〖Linux〗Ubuntu中使用KVM安装虚拟机
1. 安装软件: sudo apt-get install libvirt0 libvirt-bin libvirt-dev virt-manager qemu-system 2. 配置网桥: # i ...
- [原创]在Centos7.2上源码安装PHP、Nginx、Zentao禅道
版本 操作系统:CentOS Linux release 7.2.1511 (Core) PHP:5.6.33 Nginx:1.12.2 MySQL:5.6.38(192.168.1.103的Wind ...
- 阿里云centOS7.4上MySql5.6安装
最近一个项目要部署在阿里云上,为了开发团队方便,我自费买了个ECS,先装个数据库给开发用. 因为之前都是在真机安装,与这次阿里云上的部署比起来,还是有点区别的. Mysql 1 安装mysql版本包 ...
- centos7.3上用源代码安装zabbix3.2.7
安装zabbix之前请自行先搭建好LAMP环境! 1.下载源码安装包并解压 1.1 下载 [root@nmserver- ~]# mkdir zabbix [root@nmserver- ~]# cd ...
随机推荐
- 0基础搭建Hadoop大数据处理-编程
Hadoop的编程可以是在Linux环境或Winows环境中,在此以Windows环境为示例,以Eclipse工具为主(也可以用IDEA).网上也有很多开发的文章,在此也参考他们的内容只作简单的介绍和 ...
- Charles Proxy代理使用简要说明
1.去官网下载免费试用版: http://www.charlesproxy.com/ (需要机器有Java运行时)或下载破解注册版:http://charles.iiilab.com/,安装后开启默认 ...
- Document 对象
document.body //返回文档的body元素 document.cookies //返回当前文档有关的所有cookie document.createElement() //创建元素节点 d ...
- 大文件拆分问题的java实践(附源码)
引子 大文件拆分问题涉及到io处理.并发编程.生产者/消费者模式的理解,是一个很好的综合应用场景,为此,花点时间做一些实践,对相关的知识做一次梳理和集成,总结一些共性的处理方案和思路,以供后续工作中借 ...
- 机器学习:Python实现聚类算法(一)之K-Means
1.简介 K-means算法是最为经典的基于划分的聚类方法,是十大经典数据挖掘算法之一.K-means算法的基本思想是:以空间中k个点为中心进行聚类,对最靠近他们的对象归类.通过迭代的方法,逐次更新各 ...
- Spring Cloud 客服端负载均衡 Ribbon
一.简介 Spring Cloud Ribbon 是一个基于Http和TCP的客服端负载均衡工具,它是基于Netflix Ribbon实现的.它不像服务注册中心.配置中心.API网关那样独立部署, ...
- JavaScript 闭包究竟是什么
用JavaScript一年多了,闭包总是让人二丈和尚摸不着头脑.陆陆续续接触了一些闭包的知识,也犯过几次因为不理解闭包导致的错误,一年多了 资料也看了一些,但还是不是非常明白,最近偶然看了一下 jQu ...
- .net Core1.0 邮件发送
今天一天早,公司需要将之前的.net Core项目增加一个预处理机制,就是当程序出现异常后给我们的开发人员发送邮件,因为今天写些关于.netCore上发送邮件. 根据查阅资料发现在目前的Core1.0 ...
- ASP.NET Core:使用EntityFrameworkCore操作MySql来丰富仓储模块
概述 上一篇简单介绍了Dapper的基本用法,数据的存储为SqlServer.那么这一篇就记录一下使用EFCore来操作MySql的一些方式,这种模式比较适合那种一个项目中需要操作多种数据库的模式.不 ...
- Java静态代理与动态代理模式的实现
前言: 在现实生活中,考虑以下的场景:小王打算要去租房,他相中了一个房子,准备去找房东洽谈相关事宜.但是房东他很忙,平时上班没时间,总找不到时间去找他,他也没办法.后来,房东想了一个办法,他找到 ...