远程控制 | 2018-11-20
KVM是一个基于linux内核的虚拟机解决方案。本文介绍KVM的使用方法,以及注意要点。主要以linux kvm虚拟机的安装和设置为重点内容进行展开阐述。linux kvm虚拟机的安装和设置是怎样的呢?
参考资料: KVM虚拟机和QEMU linux brctl
先决条件 硬件环境
x86(包括32位和64位),就是我们常用的系统。
CPU硬件虚拟化
kvm需要系统CPU支持,下面命令如果有输出,说明CPU支持硬件虚拟化:
egrep "flags.:.(svm|vmx)" /proc/cpuinfo
32位与64位
下面是32bit与64bit和主机系统与虚拟操作系统的关系:
主机操作系统 虚拟机操作系统 是否支持
32位 32位 是
32位 46位 否
64位 32位 是
64位 64位 是
总结为一句话:不能在32位主机上装64位的操作系统。
安装KVM
yao@debian:~$ apt-get install kvm qemu uml-utilities
一般情况下,安装好kvm后能就自动加载内核模块,你也可以手动加载:
yao@debian:~$ modprobe kvm_intel #or kvm_amd
虚拟机连网
虚拟机连网是头等大事,所以我们先解决这个问题。通过桥接可以实现联网,主要用到的命令有:brctl,ifconfig,tunctl,route
brctl
brctl是一个以太网桥接工具,常见的用法有:
命令原型 例子 说明
brctl show brctl show 显示已有网桥
brctl addbr
brctl delbr
brctl addif
brctl delif
如果发现无法删除网桥,那么可能是还没有将其关闭:
yao@twomoon:~$ sudo brctl delbr br0
bridge br0 is still up; can't delete it
yao@twomoon:~$ sudo ifconfig br0 down
yao@twomoon:~$ sudo brctl delbr br0
桥接
说了这么多,到这才是重点。首先,将物理网卡桥接:
yao@twomoon:~$ ifconfig -a |grep eth
eth0 Link encap:Ethernet HWaddr 90:fb:a6:14:cd:42
yao@twomoon:~$ brctl addbr br0
yao@twomoon:~$ brctl addif br0 eth0
yao@twomoon:~$ ifconfig eth0 0.0.0.0
yao@twomoon:~$ ifconfig br0 192.168.1.51 up
这样又多了一个网络设备br0:
yao@twomoon:~$ LANG=C ifconfig -a |grep Ethernet
br0 Link encap:Ethernet HWaddr 2a:24:d3:aa:99:e7
eth0 Link encap:Ethernet HWaddr 90:fb:a6:14:cd:42
如果没有弄明白为什么,可以上网找找桥接的资料和brctl的用法。
当然不能每次开机后都要手工输入这么多命令。你可以将这些命令写成一个脚本,每次开机就执行这个脚本:
ifconfig lo 127.0.0.1 up
if [ ! -z "ifconfig -a | grep br0
" ]; then
ifconfig br0 down
brctl delif br0 eth0
brctl delbr br0
fi
brctl addbr br0
brctl addif br0 eth0
ifconfig eth0 0.0.0.0 up
ifconfig br0 192.168.1.51 up
route add default gw 192.168.1.1
exit 0
也可以写到网卡的配置文件配置文件(/etc/network/interfaces)里,效果是一样的:
auto lo
iface lo inet loopback
auto br0
iface br0 inet static
address 192.168.1.51
netmask 255.255.255.0
gateway 192.168.1.1
bridge_ports eth0
安装以及运行虚拟机 kvm常用命令
参数 示例 说明
-hda -hda /data/windows.img 指定windows.img作为硬盘镜像
-cdrom -hda /data/windows.iso 指定windows.iso作为光盘镜像
-boot -boot c 从硬件启动
-boot d 从光盘启动
-m -m 512 分配512M内存给虚拟系统
-vnc -vnc :0 作为vnc服务器
-cpu -cpu ? 列出支持的CPU
-cpu core2duo 指定CPU为core2duo
-smp -smp 2 指定虚拟机有2个CPU
-net -net nic 为虚拟机网卡(默认为tap0)
-net tap 系统分配tap设备(默认为tap0)
-net nic -net tap 将虚拟机的网卡eth0连接真机里的tap0 安装虚拟操作系统
生成镜像文件:
yao@twomoon:~$ sudo kvm-img create windows2003-x86.img 25G -f "vmdk"
安装系统:
yao@twomoon:~$ sudo kvm -boot d -m 512 -hda ~/kvm/windows2003-x86.img -cdrom ~/software/wzmb2003.iso
运行系统:
yao@twomoon:~$ sudo kvm -boot c -m 512 -hda ~/kvm/windows2003-x86.img -net nic -net tap
可以发现多了一个网络设备tap0,这是系统自动创建的。
yao@twomoon:~$ LANG=C ifconfig -a |grep Ethernet
br0 Link encap:Ethernet HWaddr 2a:24:d3:aa:99:e7
eth0 Link encap:Ethernet HWaddr 90:fb:a6:14:cd:42
tap0 Link encap:Ethernet HWaddr 2a:24:d3:aa:99:e7 远程登录
如果虚拟机是linux,那么就用ssh;如果是windows,那么就用rdesktop。
yao@debian:~$ rdesktop -u username -p passwd 192.168.1.52 -f &
记得用Ctrl-Alt-Enter从全屏中切回来。
向日葵控控A2开通域名直接远控功能,让用户可以更简单地通过浏览器去远控,只需一个域名便可直接访问被控设备。
一般域名访问,使用的是默认域名,默认域名的缺点是由系统自动分配,地址较长,不可自定义,而葵域名是可自定义前缀,比如: lajiao.xrk.top短短的几个字母组合即可以替代长而杂的网址。
对机房运维来说,运维人员的工作职责是保障机房环境、支撑系统、监控设备、对计算机主机设备定期检测、维护和保养,保障机房设备运行稳定。目前,大部分机房运维人员可以通过远控软件以及设备识别码完成远程运维工作。但是,一名机房运维人员需要检测维护的设备太多,难免有时候会不记得需要检测设备的识别码,又或者设备忘记安装远控软件,这些小插曲都会大大降低运维工作的效率。
而使用域名访问的方式则会大大减轻运维人员的工作量,运维人员只需记住域名,便可访问被控设备。以向日葵控控A2与葵域名的搭配为例,在机房运维过程中,使用向日葵控控A2连接设备,让设备享有被控功能,让设备绑定一个葵域名,当机房设备需要检测维护时,运维人员可通过葵域名直接实施远程检测维护。
向日葵控控A2作为一个远控硬件,与传统的kvm相比,实现了远程管理,给予用户极大的方便;与ipkvm相比,向日葵控控A2除了极大的价格优势,同时支持WiFi与4G多种上网方式,性价比更高。另外,向日葵控控A2的应用不局限于所有操作系统,同样适配于如广告机之类的通过视频输出与USB输出的接入接口设备,支持1920*1080的高清分辨率。