VM虚拟机网络设置
- 格式:pdf
- 大小:403.89 KB
- 文档页数:16
VM虚拟机网络设置
VMWare中的几种网络配置
(1)Bridged方式
用这种方式,虚拟系统的IP可设置成与本机系统在同一网段,虚拟系统相当于网络内的一台独立的机器,与本机共同插在一个Hub上,网络内其他机器可访问虚拟系统,虚拟系统也可访问网络内其他机器,当然与本机系统的双向访问也不成问题。
(2)NAT方式
这种方式也可以实现本机系统与虚拟系统的双向访问。
但网络内其他机器不能访问虚拟系统,虚拟系统可通过本机系统用N AT协议访问网络内其他机器。
NAT方式的I P地址配置方法:虚拟系统先用D HCP自动获得IP地址,本机系统里的V Mwareservice s会为虚拟系统分配一个I P,之后如果想每次启动都用固定IP的话,在虚拟系统里直接设定这个I P即可。
(3)host-only方式
顾名思义这种方式只能进行虚拟机和主机之间的网络通信,既网络内其他机器不能访问虚拟系统,虚拟系统也不能访问其他机器。
(4)not use方式
既是不使用网络,虚拟系统为一个单机。
一般来说,Bridged方式最方便好用。
但如果本机系统是win2000而网线没插(或者根本没有网卡),网络很可能不可用(大部分用PCI网卡的机器都如此),此时就只能用N AT方式或h ost-only,之前所说的那两块虚拟网卡就是适应这两种网络准备的。
vmware虚拟机的网络设置
虚拟机的网络设置(原理篇)
在正式开始之前,我想有必要先来学习一些必要的网络知识。
否则,在不懂得任何原理的情况下依葫芦画瓢虽然可解一时之需要,但遇到具体情况改变的情况下就只能干瞪眼了。
由于篇幅限制,这里只讲和
VM ware设置有关的一点简单网络知识。
1,什么是网络?
Interne t是指“互连网”,好象这句话说的有点多余,不过确实有很多人对他有错误的理解,“互连网”是指一个个网络互连,而不是像有些人想象的那样把一台台电脑杂乱无章的互连。
当我们需要用电脑和远方的电脑通讯的时候,先把本地电脑组成一个网络,当然,远方的电脑也要组成一个网络,在把这两个网络“互连”起来,组成“互连网”。
用电话线和MO DEM拨号上网的时候是通过电话线先把自己的电脑连到ISP(Interne t Service Provide r 网络服务提供商)的网络中,再经过ISP的网络和世界各地的电脑通信。
2,电脑如何通过网络传递数据?
每一个网络需要一个网络地址,网络中的电脑需要一个在网络中唯一确定的标识,网络号和电脑的标识号
组成了IP地址,所以IP地址是由网络号和主机号组成的。
当你的电脑要和其他的电脑通信的时候,电脑会先根据I P地址和子网掩码确定目标主机是在本地网络中还是在远程网络中,如果在本地网络中则直接把一个包含信息的IP数据包发送到本地网络上,目标主机会检测到并接收,如果目标主机在远程网络则需要通过一台被称为网关的的电脑转发到远程网络,网关(geteway)可以看做是连接网络和网络的桥梁,网关的概念很广,这里为了简化起见,我们暂且认为它和路由器是同一个概念。
路由器(router)是一种连接网络和网络,并选择IP数据包传送的路径的一台特殊计算机。
很多情况下网关的概念等同于路由器。
3,网络中电脑的I P地址有何要求?
在同一个网络中,每台电脑必须具有相同的网络号,这样电脑才认为目标主机是在本网络中并且可以正确送达,如果网络号不同,即使目标主机已经用网线连到本网络中数据也不能直接送达,即使这两台电脑近在咫尺,在电脑看来仍旧是一台远程电脑.比如一个网络的网络号为192.168.0,则该网络中的计算机的IP地址必须以192.168.0开头。
假如要传送一个数据包到网络号为192.168.1的网络,则必须通过路由器转发,如果该网络中没有路由器,则发送失败。
因此,为了连接两个网络,一台路又器至少要有两个网络接口(网卡、调制解调器等联网设备称为网络接口)。
网络和路由器的关系见下图:
--------------- -------------- --------------
| 网络A | | 路由器| | 网络B |
| | | | | |
|□--|-----------|--□□--|----------|--□|
| 1 | | 2 3 | | 4 |
--------------- -------------- --------------
图一
图中的小方框表示网卡或其他网络接口。
可以看到路由器至少有两个网络接口。
假设网络A的地址为192.168.0 网卡1的地址为192.168.0.1
网络B的地址为192.168.1 网卡4的地址为192.168.1.1
则路由器上的网卡2必须属于网络192.168.0 地址为192.168.0.x (x为任意小于255的数)
路由器上的网卡3必须属于网络192.168.1 地址为192.168.1.x (x为任意小于255的数)
就是说,路由器既属于网络A,又属于网络B,这样才起到桥梁的作用。
当数据从网络A发往网络B时,路由器从网卡2接收数据,经过改装后通过网卡3发送数据到网络B。
这样,我们称网卡2的地址192.168.0.x为网络A的网关
网卡3的地址192.168.1.x为网络B的网关
4,VMware虚拟机提供了那些虚拟网络设备?
默认安装的情况下VMwar e提供了虚拟网卡vmne t1和vmn et8,还有在虚拟系统上的虚拟网卡 "AMD PCNET FamilyPCI Etherne t Adapter"
请注意,vmnet1和vmnet8是主系统上虚拟设备,用ifconf ig命令可以看到,而"AMD PCNET FamilyPCI Etherne t Adapter"是虚拟系统上的虚拟设备,在安装完虚拟系统后可以在设备管理器中看到,前两个隶属于真实系统,是你的真实电脑中的设备,后一个隶属于虚拟系统,是虚拟电脑中的设备,不要搞混淆。
--------------- -------------- --------------
| 网络A | | 路由器| | 网络B |
| | | | | |
|□--|-----------|--□□--|----------|--□|
| 1 | | 2 3 | | 4 |
--------------- -------------- --------------
---------------- ------------------------- --------------
| 虚拟系统| | 主系统(路由器) | | 真实网络|
| | | | | |
|□--|-----------|--□□<--->□-----|------|--□|
|AMD PCNET卡| |vmnet1vmnet8真实网卡| | 4 |
---------------- ------------------------- --------------
图二
让我们来和上面的网络和路由器的关系做一个比对。
可以看到要想虚拟系统和主系统通信必须使AMD PCNET 网卡和vmne t1组成一个网络。
而vmnet1本来就在主系统中,系统可以直接访问,所以主系统又充当了路由器的功能,只要有这两个虚拟设备主系统和虚拟系统就可以通讯。
关键在于三点:
1.确定网卡AMD PCNET和v mnet1的网络号相同。
2.在虚拟系统里设置网络属性,把网关地址设为vmnet1的地址。
3.开启主系统的路由功能,使它成为一台路由器。
事实上,如果你只需要虚拟系统和主系统通信,而不需要和主系统所在的真实网络上的其他主机通信的话只要满足第一点就可以了。
因为满足第一点,主系统和虚拟系统就在同一网络中了,不需要路由器便可通信。
但是大多数情况下我们需要虚拟系统和主系统所在的真实网络通信,这就需要满足其他两点了。
四、虚拟机的网络设置(实施篇)
1,我们先来让虚拟系统和主系统联系上。
在VMware安装的时候安装程序会自动给vmnet1分配一个I P地址,下面是笔者电脑上例子:
vmnet1Link encap:Etherne t HWaddr00:50:56:C0:00:01
inet addr:192.168.221.1 Bcast:192.168.221.255 Mask:255.255.255.0
UP BROADCA ST RUNNING MULTICA ST MTU:1500 Metric:1
RX packets:191 errors:0 dropped:0 overrun s:0 frame:0
TX packets:63 errors:0 dropped:0 overrun s:0 carrier:0
collisi ons:0 txqueue len:100
RX bytes:0 (0.0 b) TX bytes:0 (0.0 b)
在第二行可以看到安装程序给vmnet1分配的IP地址为192.168.221.1(注意每次安装V MwareIP地址是随机分配的,实际的情况与这里的例子会不同)。
即虚拟网卡vm net1属于网络192.168.221。
因此我们需要启动虚拟系统,设置网络属性,把虚拟系统的网卡"AMD PCNET FamilyPCI Etherne t Adapter"的IP地址设置为192.168.221.x (x为除1以外2~254之间的任意数字笔者把它设置为2),把网关设置为v mnet1的地址:192.168.221.1(如果不和外界真实网络通信的话网关可以不设)
windows 2000和XP设置后立即生效,win98需要重新启动,linux需要重新启动网络服务:
#service network restart
在主系统上pi ng一下虚拟系统:
#ping -c 3 192.168.221.2
PING 192.168.221.2 (192.168.221.2) from 192.168.221.1 : 56(84) bytes of data.
64 bytes from 192.168.221.2: icmp_se q=1 ttl=128 time=6.91 ms
64 bytes from 192.168.221.2: icmp_se q=2 ttl=128 time=0.425 ms
64 bytes from 192.168.221.2: icmp_se q=3 ttl=128 time=0.527 ms
--- 192.168.221.2 ping statist ics ---
3 packets transmi tted, 3 receive d, 0% loss, time 2001ms
rtt min/avg/max/mdev = 0.425/2.623/6.917/3.036 ms
yeah!通了!
再在虚拟系统上ping主系统:
C:\>ping 192.168.221.1
Pinging 192.168.221.1 with 32 bytes of data:
Reply from 192.168.221.1: bytes=32 time<10ms TTL=64
Reply from 192.168.221.1: bytes=32 time<10ms TTL=64
Reply from 192.168.221.1: bytes=32 time<10ms TTL=64
Reply from 192.168.221.1: bytes=32 time<10ms TTL=64
Ping statist ics for 192.168.221.1:
Packets: Sent = 4, Receive d = 4, Lost = 0 (0% loss),
Approxi mate round trip times in milli-seconds:
Minimum = 0ms, Maximum = 0ms, Average = 0ms
yeah!又通了!主系统和虚拟系统顺利联系上啦!
2,让虚拟系统和主系统所在的真实网络通信
首先在你的电脑上需要有一块与真实网络相连真实的网卡(如图二所示)。
vmnet8就在与真实网络通讯的时候起作用了,vmnet8会和真实网卡对应起来,虚拟系统要发送数据包到真实网络中的时候,真实系统是一台路由器,首先数据发到虚拟网卡vmn et1,然后经过路由器(这里就是主系统linux)发到vmnet8,由于vmnet8和真实网卡是对应起来的,这一机制是有v mware完成的,所以发到vmn et8上的网卡就等于传送到了真实网卡上,然后数据包再通过真实网卡发送到真实网络,整个过程请看图二。
如果你的系统上有两块以上的真实网卡,在安装的时候安装程序会询问把虚拟网卡对应到哪个真实网卡上。
可以根据实际情况选择。
把vmnet8的IP地址设置为和真实网卡在同一网络的地址,假设真实网络的网络号为192.168.0,真实网卡的IP地址为192.168.0.1则可设置vm net8的I P地址为192.168.0.2
在linux中方法如下:
#ifconfi g vmnet8down
#ifconfi g vmnet8192.168.0.2 up
回顾一下上面讲的三个条件:
--------------------------------------------------------------
关键在于三点:
1.确定网卡AMD PCNET和v mnet1的网络号相同。
2.在虚拟系统里设置网络属性,把网关地址设为vmnet1的地址。
3.开启主系统的路由功能,使它成为一台路由器。
--------------------------------------------------------------
前两点我们已经在第一部分中做好了,现在只要开启了linux的路由功能虚拟系统就可以和外界通讯了。
linux是一个天生的网络操作系统,他在网络方面的强大功能使得它在网络服务器领域有广泛的应用。
用linux来做路由器甚至不需要额外的软件,linux的内核直接支持静态路由的功能。
我们要做的只是把路由功能打开就可以了。
可以先看看路由表:
#route
确定所有网卡的IP地址或网络地址都在D estina tion一栏里,如下图:
-------------------------------------------------------------------------------
KernelIP routing table
Destina tion Gateway Genmask Flags MetricRef Use Iface
192.168.0.0 * 255.255.255.0 U 0 0 0 eth1
192.168.0.0 * 255.255.255.0 U 0 0 0 eth1
192.168.0.0 * 255.255.255.0 U 0 0 0 vmnet8
192.168.221.0 * 255.255.255.0 U 0 0 0 vmnet1
127.0.0.0 * 255.0.0.0 U 0 0 0 lo
default www.gucuiwe n.co 0.0.0.0 UG 0 0 0 eth0
-------------------------------------------------------------------------------
默认情况下启动网络设备的时候系统会把该设备的IP地址添加到路由表中,如果没有的话可以重新启动一下网络服务:
#service network restart
再来开启路由功能:
# echo 1 > /proc/sys/net/ipv4/ip_forw ard
至此,linux的路由功能已经打开,你的linux系统已经成了一台路由器,连接着虚拟的网络和真实网络。
虚拟网络和真实网络间就可以通信了。
出于安全考虑,如果有必要的话还需要用ip tables命令来设置一下路由规则。
五、Windows下的虚拟机网络设置。
在Window s下的虚拟机的网络设置大致和linu x下的相同,只不过需要安装额外的路由软件,在Window s 平台上有很多这样的软件可以用,比如 SysGate WinGate等,如果用的是Wi ndows2000 Server或者是Wind ows NT Server的话可以用系统自带的“路由和远程访问”软件。
具体的设置就不祥述了,相信只要懂了其中的原理就不难找到合适的解决方案了。
如果你的电脑硬件足够的好,有1G以上的内存和2G以上的CPU的话,那你也可以同时运行几台虚拟机,把这几台虚拟机组成一个网络,这样在一台电脑上就可以有一个功能强大的网络实验平台了。
Vmware(虚拟机工作站)网络配置
vmware通过虚拟网络组件把虚拟机器同真实的物理网络连接起来。
虚拟网络组件主要有如下几种:
交换机:跟真实的交换机一样,它允许把多个网络组件连接起来,在vmware软件安装时根据需要自动安装,最多允许挂接9个交换机,名称分别为VM net0-8。
其中有3个已经默认分配给网桥(VMnet0),宿主机虚拟网络适配器(VMnet1)和网络地址转换NAT设备(VMnet8)。
通过在虚拟机的“Editing this machine setting s”的网络适配器条目,可以把虚拟机器连接到未被分配的交换机。
网桥:网桥把虚拟机器连接到你的宿主机所在的局域网LAN上。
其实现的方式就是把虚拟机器上的虚拟适配器连接到你的宿主机上的物理网络适配器上。
创建虚拟机的向导中如果选择了“typical”或者“Usingbridged network ing”的网络连接方式,那么网桥会自动生成。
上面图中给出了网桥连接方式下虚拟机网络适配器与宿主机物理适配器之间的关系。
这是让虚拟机访问宿主机所在网络的最容易的一种方式。
这种情况下虚拟机需要自己独立的标识,比如TCP/IP网络中就需要自己的IP地址,这个IP地址从网络管理员处获得,还有其它的一些网络细节都需要手工设置。
网桥方式下虚拟机跟宿主机一样是本地网络中的一个独立体,如同一个物理的机器一样。
如果在vmwa re中同时运
行多个虚拟机,那么每个虚拟机都应该有一个独立的IP地址。
宿主机上的虚拟适配器:就是出现在宿主机上的供vm ware工作站使用的一个虚拟的网络适配器。
允许虚拟机与宿主机通信,但是这个虚拟适配器不会连接到任何外部的网络,只有在宿主机上建立起特殊的软件诸如代理服务器才能把虚拟适配器和物理适配器连接起来。
实际上虚拟机只和宿主机进行网络连接,这种方式也称为host-only。
在创建虚拟机的向导中选择了自定义网络设置,并且选择了“UseHost-only network ing”,那么这种网络连接方式就会被自动建立起来。
此时,宿主机操作系统可以看到有一个虚拟的网络适配器。
宿主机与虚拟机可以通信。
很适合建立一个与外部网络隔绝的独立私有TCP/IP网络。
虚拟机的IP地址由虚拟的D HCP服务器提供。
这种连接方式结合Windo ws2000/XP/2003上的网络共享的特性,就可以允许虚拟机连接到外部Intern et。
网络地址转换设备:如果宿主机只有一个IP地址可用于外部物理网络的连接,那么使用NAT可以把虚拟机连接到外部网络。
如果在创建虚拟机的向导中选择自定义网络设置,并选择“Usenetwork address transla tion”,那么这样的连接就会被创建。
如果宿主机所在网络不能给该虚拟机一个I P地址,那么NAT就是最容易的一种让虚拟机访问宿主机网络的方式。
由于虚拟机没有外部物理网络的IP地址,因此vmwar e在宿主机上建立一个独立的私有网络,通过虚拟的DH CP服务器获得ip地址。
NAT能够把多个虚拟机的网络数据加以区分并在虚拟机与外部物理网络之间进行传送。
NAT方式下许多标准的TC P/IP协议都可以在虚拟机上使用,比如HTTP/FTP/TELET等。
但是默认情况下外部网络上的计算机不能连接到虚拟机上,因此虚拟机不能提供诸如WE B浏览这样的服务。
DHCP服务器:为虚拟机提供一个IP地址,只适用于NAT和host-only(指虚拟机只和宿主机进行网络连接)。
网络适配器:当用向导生成一个虚拟机时,为虚拟机建立一个虚拟网络适配器。
在虚拟机的操作系统中,可以看到一个名称为AMDPCNET PCI适配器。
在vmware的适配器设置中,可以建立最多3个虚拟网络适配器。
配置虚拟机上网
一般主机上网有两种方式,一是本机在局域网环境中,多台计算机通过交换机访问I nterne t,则交换机是拨号主机而不是本机,那么主机(交换机)就有一个IP地址,这种情况类似办公室的电脑。
另外一种方式是本机直接拨号上网,如家庭电脑。
根据本机不同的上网方式,其虚拟的计算机上网设置方法也有所区别,我们分开来介绍。
一、局域网环境
局域网环境下设置虚拟机上网其实非常简单,例如笔者的Wi ndowsXP系统计算机在局域网内分配的IP地址是192.168.0.2,而局域网环境下交换机的主机IP地址是192.168.0.1,那么VMwar e虚拟的Wi ndows2000系统可以把它看作是局域网内的一台计算机,给它分配一个I P地址为192.168.0.4即可。
设置过程:
首先在VMwa re程序的“虚拟机”菜单下打开“设置”命令窗口,然后在硬件设置中选择“以太网”设置一下虚拟机使用的网卡,这里选择“自定义VMne t0默认桥接”即可。
接下来在虚拟机Window s 2000系统中设置网络连接属性,在Window s 2000系统桌面上选中“网上邻居”点击右键打开“属性”窗口,然后选择“本地连接”点击右键打开其属性窗口,选中“Interne t协议(TCP/IP)”点击属性按钮,设置虚拟机的I P地址,如我们上面为它分配了虚拟机在局域网的地址为“192.168.0.4”,默认网关输入局域网主机的I P地址,首选DNS服务器指定为局域网主机的IP地址(图1)。
设置好后确定。
打开虚拟机Wi ndows2000的IE浏览器,输入一个网址访问检测是否能正常访问In ternet了。
二、本机拨号上网
如果用本机拨号上网,那么与局域网环境就不同了,本机没有一个I P地址,虚拟机该如何设置自己的IP上网呢?VMware虚拟运行环境有一个虚拟网络(虚拟局域网)的功能,在VMware中配置一下虚拟网络的主机IP,虚拟机(即Window s 2000系统)就可以利用虚拟网络主机的网关访问Int ernet了。
设置过程:
首先在VMwa re程序“编辑”菜单下选择“虚拟网络设置”命令,然后虚拟网络编辑器窗口的“摘要”选项卡下看到V Mware能够模拟的网络类型,其中有“虚拟网络8”。
下面要添加一个虚拟网络的网卡硬件,在“主机虚拟适配器”选项卡下添加名为“VMnet8”的虚拟网络,
点击“添加”按钮,选择VMnet8添加。
接着在“NAT”选项卡下查看虚拟的主机“V Mnet8”的网关IP地址,VMware默认设置的网关IP地址
是192.168.59.2,我们也可以自己修改它。
同样我们要在“虚拟机设置”中定义一下“以太网”的硬件设备,这里选择网络连接的方式是“自定义VMne t8(NAT)”。
最后在虚拟机的“Interne t协议(TCP/IP)”中设置当前环境下的虚拟计算机IP、网关、子网掩码,如分配这台虚拟机的IP为192.168.59.3,网关是上一步在“NAT”中设定的网关I P,然后单击“确定”按钮完成设置。
现在打开虚拟机的IE浏览器,输入网址便可在虚拟机中访问Intern et,享受冲浪的乐趣了
vmware,qemu各种方式上网设置
vmware三种网络连接,qemu两种网络连接实现虚拟机<--->主机虚拟机<--->互联网通信的方法。
顺便写了下如何不重新编译整个内核支持某个功能,对系统无影响,编译速度要快于编译整个内核。
如果你的XXX卡没被内核支持,又怕自己编译的内核会造成系统损坏就可以试试这个方法喽^_^
vmware三种网络连接上网设置:
1.bridge:
默认使用vmn et0
将虚拟机的ip设置与主机同网段未使用i p,其余与主机相同:
例如主机ip是10.70.54.31,设置虚拟机ip为10.70.54.22。
netmask,broadca st,gateway,dns都与主机相同即可实现虚拟机<--->主机虚拟机<---->互联网通信。
2.nat :
默认使用vmn et8
将虚拟机设置成使用dhcp方式上网,windows下选择"自动获取ip",linux下开启dhcp服务即可
也可以手动设置:
ip设置与vm net8同网段,gateway设置成vmn et8的ga teway(/etc/vmware/vmnet8/nat/nat.conf)中可以查到vm net8的g ateway,通常是xxx.xxx.xxx.2。
netmask,broadca st设置与v mnet8相同,dns设置与主机相同。
例如vmnet8ip:172.16.249.1 gw :172.16.249.2
虚拟机设置: ip :172.16.249.100 gw: 172.16.249.2
3.host-only :
默认使用vmn et1
将虚拟机ip设置与vmne t1同网段,gateway设置成vmn et1的ip,其余设置与vm net1相同,dns设置与主机相同
例如 vmnet1ip :172.16.245.1
虚拟机设置: ip :172.16.245.100 gateway :172.16.245.1
这样就实现了虚拟机<--->主机通信,但是虚拟机<--->互联网仍无法通信
虚拟机与互联网通信:
1.开启主机路由功能
2.设定iptab les,使主机成为一台nat server
1. echo 1 >/proc/sys/net/ipv4/ip_forw ard 这样就主机就具有了路由功能
2. iptable s -t nat -A POSTROU TING -o eth0 -s 172.16.245.0/24 -j MASQUER ADE
这条规则意思是将来自172.16.245.0/24封包的来源ip伪装成e th0的ip,实现虚拟机与互联网通信如果网络接口是ppp+或pppoe则需要修改成-o pppoe
当然-s 172.16.245.0/24 也要根据实际情况修改
qemu两种上网方式:
user mode network :
这种方式实现虚拟机上网很简单,类似vmwar e里的nat,qemu启动时加入-user-net参数,虚拟机里使用d hcp方式,即可与互联网通信,但是这种方式虚拟机与主机的通信不方便。
tap/tun network :
这种方式要比u ser mode复杂一些,但是设置好后虚拟机<-->互联网虚拟机<-->主机通信都很容易
这种方式设置上类似vmwa re的hos t-only,qemu使用t un/tap设备在主机上增加一块虚拟网络设备(tun0),然后就可以象真实网卡一样配置它.
首先内核中支持tap/tuns设备:
DeviceDrivers --->
Network ing support --->
[M] Univers al TUN/TAP devicedriversupport
如果当前内核没有支持,可以重新只编译相应模块加入,方法很简单:
将当前内核配置文件cp到内核源码目录下:
[root@LFS ~]#cp /boot/config-[kernel-version] /usr/src/linux
[root@LFS ~]#cd /usr/src/linux
配置内核,将TUN/TAP选择模块(M),如上所示:
[root@LFS ~]#make menucon fig
重新只编译模块(M),不编译核心(*)支持的东东:
[root@LFS ~]#make modules
编译好后在/usr/src/linux/drivers/net下可以找到tun.ko:
[root@LFS net]#ls -l /usr/src/linux/drivers/net/tun.ko
-rw-r--r-- 1 root root 11116 Mar 23 20:29 /usr/src/linux/drivers/net/tun.ko
[root@LFS net]#
将它cp到当前内核的模块目录的相应位置:
[root@LFS net]#cp /usr/src/linux/drivers/net/tun.ko /lib/modules/`uname -r`/kernel/drivers/net 重新建立模块依赖关系:
[root@LFS net]#depmod
现在就可以加载它了:
[root@LFS net]#modprob e tun
检查一下:
[root@LFS net]#lsmod |grep tun
tun 8704 0
[root@LFS net]#
OK. 成功不重新编译整个内核加入特殊模块支持
如果你的xx卡不被内核支持,又可以编译成模块,自己怕重新编译内核后出问题就可以用这个办法只编译自己需要的模块,然后手动安装到相应位置,再加载它。
这样编译速度要也比编译整个内核快,不会对系统有任何损害,就可以使用上X X卡喽。
^_^
要注意三点:
1.内核源码必须与当前内核版本完全一致,否则编译出的模块是不能用的。
2.注意只make modules(编译模块),没有makemodules_insta ll(自动安装模块到/lib/modules下)
3.加载新编译的模块前必须先运行depmo d,否则modpr obe找不到它
其实使用当前内核配置文件(/boot/config-[kernel-version]),只加入自己需要的模块,不做任何其他改,make modules_insta ll应该也不会有问题的。
不过最稳妥的办法还是手动安装它,控制权在自己手里更踏实嘛:-)
OK,转回qemu上网问题
如果使用ude v管理设备(通常2.6.x内核的发行版都已经使用u dev),当modpro be tun后就会自动建立/dev/net目录,并创建出tun设备,做好相关链接:
[root@LFS net]#ls -l /dev/net/tun
lrwxrwx rwx 1 root root 6 Mar 25 15:35 /dev/net/tun -> ../tun
[root@LFS net]#
如果很不幸,你没看到它,就需要自己手动做这些工作了
[root@LFS ~]#mkdir /dev/net
[root@LFS ~]#mknod /dev/net/tun c 10 200
OK,相关设备已经准备好了,还需要一个tu n/tap的初始化脚本:
/etc/qemu-ifup :
#!/bin/sh
/sbin/ifconfi g $1 172.20.0.1
再给予qemu-ifup x执行权限放在/etc下就可以了。
这个脚本只能r oot用户执行,如果需要普通用户使用qem u,就需要改成su do /sbin/ifconfi g .....再设置sudo相关权限。
启动qemu后,它会在主机上增加一块虚拟网络设备(tun0):
[root@LFS ~]#ifconfi g tun0
tun0 Link encap:Etherne t HWaddr0A3:8A:5D:97:CD
inet addr:172.20.0.1 Bcast:172.20.255.255 Mask:255.255.0.0
UP BROADCA ST RUNNING MULTICA ST MTU:1500 Metric:1
RX packets:0 errors:0 dropped:0 overrun s:0 frame:0
TX packets:0 errors:0 dropped:0 overrun s:0 carrier:0
collisi ons:0 txqueue len:500
RX bytes:0 (0.0 b) TX bytes:0 (0.0 b)
[root@LFS ~]#
现在就可以启动qemu配置虚拟机网络参数了,和vmware host-only一样:
ip与tun0相同网段,gateway为tun0ip 其余参数与tu n0相同,dns与主机相同:
tun0 : ip :172.20.0.1 broadca st:172.20.255.255 netmask :255.255.0.0
qemu : ip :172.20.0.100 broadca st:172.20.255.255 netmask :255.255.0.0 gateway:172.20.0.1 与host-only一样,这样只实现了虚拟机<---->主机间通信,还需要设置ro uter,nat才可以连上互联网
[root@LFS ~]#echo 1 > /proc/sys/net/ipv4/ip_forw ard
[root@LFS ~]#iptable s -t nat -A POSTROU TING -o eth0 -s 172.20.0.0/24 -j MASQUER ADE
[root@LFS ~]#
OK,虚拟机<--->主机虚拟机<---->互联网通信都完成啦。