Chinaunix首页 | 论坛 | 博客
  • 博客访问: 10706655
  • 博文数量: 2905
  • 博客积分: 20098
  • 博客等级: 上将
  • 技术积分: 36298
  • 用 户 组: 普通用户
  • 注册时间: 2009-03-23 05:00
文章存档

2012年(1)

2011年(3)

2009年(2901)

分类: LINUX

2009-03-23 11:15:38



VirtualBox, 我一直将其当作VMWare的替代软件,坚持使用,看到现在优秀的非商业软件已经越来越多了,着实让人欣慰。

但是,VirtualBox有个问题困扰了我很久,就是host system与guest system之间的通讯问题,即虚拟主机的虚拟网络与真实网络的通讯问题。VMWare在这个问题上解决得很好。对于VMWare来说,任何一种虚拟网络均不会影响虚拟主机网络的访问。但对于VirtualBox来说,其默认的NAT模式,却有着先天不足,包括无法转发ICMP、虚拟主机无法被真实网络访问等问题。不过VirtualBox的确提供了另外2种类型的虚拟网络,可以解决这个问题。

我时不时翻出VirtualBox的UserManual看一下,每次看到virtual networking的时候都很郁闷,因为看不懂,尝试着按上面的方法配置虚拟网卡,却均以失败告终。

正好昨天装了一个CentOS 5.0的虚拟系统,心想一定要把网络互通的问题解决,否则太不方便了。

几小时前,我再次按照手册上的方法操作了一遍,不出所料,又失败了。

刚才,启了dynamips做了个小实验,想到dynamips用到的虚拟网卡,灵机一动,若有所悟。


于是有了下面的解决方法,大致分为几步:

1)手工创建虚拟网卡

为了方便创建虚拟网卡,我写了一个脚本:

#!/bin/sh


if [ -z "$EUID" -a -x /usr/bin/id ]; then
   EUID=`id -u`
fi

if [ "$EUID" = "0" ]; then

   #----- vbox0 -------------------------------------------------------------
   /sbin/ifconfig vbox0 > /dev/null 2>&1
   if [ "$?" = "0" ]; then
      tunctl -d vbox0
      echo
      echo "*** vbox0 was removed! ***"
      echo
      exit 1
   else
      tunctl -u wandering -t vbox0
      ifconfig vbox0 172.16.0.1 netmask 255.255.255.0 up
      echo
      ifconfig vbox0
      echo
      echo "*** vbox0 was created with ip address of 172.16.0.1/24! ***"
      echo
   fi

else

   echo
   echo "*** Permission denied, please run this as root! ***"
   echo
   exit 1

fi



使用此脚本前记得将“
tunctl -u wandering -t vbox0”中的wandering替换为自己系统上要运行VirtualBox的用户名。



2)在VirtualBox虚拟系统的配置文件中引用第1步所创建的虚拟网卡

打开VirtualBox虚拟系统的setting界面,进入"settings->NetWork->Adapter 2";
勾选"Enable Network Adapter";
在"Attached to"下拉框中选择"Host interface"项;
在"Interface Name"输入框中填写"vbox0"(这是手工创建的虚拟网卡的名字,根据实际创建情况而定);
点击按钮"OK"关闭保存配置;



3)在启动的虚拟系统中,为新网卡配置网络

以我安装的 CentOS 5.0 为例:



在 Host 系统中 ping 虚拟系统的新网卡对应IP地址:

#
#

# ping 172.16.0.2
PING 172.16.0.2 (172.16.0.2) 56(84) bytes of data.
64 bytes from
172.16.0.2: icmp_seq=1 ttl=64 time=0.209 ms
^C
--- 172.16.0.2 ping statistics ---
1 packets transmitted, 1 received, 0% packet loss, time 0ms
rtt min/avg/max/mdev = 0.209/0.209/0.209/0.000 ms
#

#

# ssh -l root 172.16.0.2
The authenticity of host '172.16.0.2 (172.16.0.2)' can't be established.
RSA key fingerprint is a9:15:3d:cf:f5:b1:5c:5f:5d:96:fb:a9:b0:9d:37:61.
Are you sure you want to continue connecting (yes/no)? yes
Warning: Permanently added '172.16.0.2' (RSA) to the list of known hosts.
root@172.16.0.2's password:
Last login: Tue Oct  7 00:13:55 2008
[root@centos5 ~]#
[root@centos5 ~]# exit
logout



#




补充说明:我的Desktop用的是openSUSE 11.0 x86_64。


OK,一切搞定,可以正常通信了。




阅读(1460) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~