文档章节

配置虚拟机Ubuntu网络连接

gzwawj
 gzwawj
发布于 2019/03/14 15:25
字数 1343
阅读 422
收藏 0

有两种设置网络的方式:

  • Bridged:在Ubuntu内部(/etc/network/interfaces)中设置的ip与主机类似;
  • NAT: 在Ubuntu内部中设置为dhcp(自动获取)。

另外还需要通过Virtual Network Editor 进行设置。

有时候也要看人品的。反正我设置第一种一致没有成功。

关于设置Ubuntu的interfaces:

基本的配置大概是下面这个样子

1 auto lo
2 iface lo inet loopback
3 
4 # The primary network interface
5 auto eth0
6 iface eth0 inet static
7      address 192.168.0.42
8      network 192.168.0.0
9      netmask 255.255.255.0
10      broadcast 192.168.0.255
11      gateway 192.168.0.1

上面的配置中,

第1行跟第5行说明lo接口跟eth0接口会在系统启动时被自动配置;

第2行将lo接口设置为一个本地回环(loopback)地址;

第6行指出eth0接口具有一个静态的(static)IP配置(也可以设置为dhcp);

第7行-第11行分别设置eth0接口的ip、网络号、掩码、广播地址和网关。

再来看一个更复杂点的

12 auto eth0
13 iface eth0 inet static
14     address 192.168.1.42
15     network 192.168.1.0
17     netmask 255.255.255.128
18     broadcast 192.168.1.0
19     up route add -net 192.168.1.128 netmask 255.255.255.128 gw 192.168.1.2
20     up route add default gw 192.168.1.200
21     down route del default gw 192.168.1.200
22     down route del -net 192.168.1.128 netmask 255.255.255.128 gw 192.168.1.2

这次,有了一个复杂一些的掩码,和一个比较奇怪的广播地址。还有就是增加的接口启用、禁用时的路由设置;

第19行和20行配置的左右是在接口启用的时候,添加一条静态路由和一个缺省路由;

第21行和22行会在接口禁用的时候,删掉这两条路由配置。

至于配置路由的写法,仔细看,它就是route命令嘛。

继续,一个物理网卡上多个接口的配置方法

23 auto eth0 eth0:1
24 iface eth0 inet static
25     address 192.168.0.100
26     network 192.168.0.0
27     netmask 255.255.255.0
28     broadcast 192.168.0.255
29     gateway 192.168.0.1
30 iface eth0:1 inet static
31     address 192.168.0.200
32     network 192.168.0.0
33     netmask 255.255.255.0

30行到33行在eth0上配置了另外一个地址,这种配置方法在配置一块网卡多个地址的时候很常见:有几个地址就配置几个接口。冒号后面的数字可以随便写的,只要几个配置的名字不重复就可以。

下面是pre-up和post-down命令时间。这是一组命令(pre-up、up、post-up、pre-down、down、post-down),分别定义在对应的时刻需要执行的命令。

34 auto eth0
35 iface eth0 inet dhcp
36     pre-up [ -f /etc/network/local-network-ok ]

第36行会在激活eth0之前检查/etc/network/local-network-ok文件是否存在,如果不存在,则不会激活eth0。

再更进一步的例子

37 auto eth0 eth1
38 iface eth0 inet static
39     address 192.168.42.1
40     netmask 255.255.255.0
41     pre-up /path/to/check-mac-address.sh eth0 11:22:33:44:55:66
42     pre-up /usr/local/sbin/enable-masq
43 iface eth1 inet dhcp
44     pre-up /path/to/check-mac-address.sh eth1 AA:BB:CC:DD:EE:FF
45     pre-up /usr/local/sbin/firewall

第 41行和第44行中,check-mac-address.sh放在/usr/share/doc/ifupdown/examples/目录 中,使用的时候需要给它加上可执行权限。这两行命令会检测两块网卡的MAC地址是否为11:22:33:44:55:66和 AA:BB:CC:DD:EE:FF,如果正确,则启用网卡。如果MAC地址错误,就不会启用这两块网卡。

第42行和第45行是假定在这两块网卡上分别执行的命令,你可以把它们替换成你想要的任何玩意 :)

手 册上说,这种方法主要是用来检测两块网卡的MAC地址交换(If their MAC addresses get swapped),其实就是两块网卡名互换了,这种情况在debian系统上再常见不过了,主要是因为内核识别网卡的顺序发生了变化。这个问题可以用下面 的这种方法来避免。

46 auto eth0 eth1
47 mapping eth0 eth1
48     script /path/to/get-mac-address.sh
49     map 11:22:33:44:55:66 lan
50     map AA:BB:CC:DD:EE:FF internet
51 iface lan inet static
52     address 192.168.42.1
53     netmask 255.255.255.0
54     pre-up /usr/local/sbin/enable-masq $IFACE
55 iface internet inet dhcp
56     pre-up /usr/local/sbin/firewall $IFACE

第48行中的get-mac-address.sh也在/usr/share/doc/ifupdown/examples/目录里,也同样要加可执行权限。这个脚本的作用,就是获得每块网卡的MAC地址。

这段配置首先配置了两个逻辑接口(这个名词的定义请参见debian参考手册)lan和internet,然后根据网卡的MAC地址,将逻辑接口映射(mapped)到物理接口上去。

再来看下面这段配置

57 auto eth0  
58 iface eth0 inet manual  
59       up ifconfig $IFACE 0.0.0.0 up  
60       up /usr/local/bin/myconfigscript  
61       down ifconfig $IFACE down

这段配置只是启用一个网卡,但是ifupdown不对这个网卡设置任何ip,而是由外部程序来设置ip。

最后一段配置,这段配置启用了网卡的混杂模式,用来当监听接口

177 auto eth0
178 iface eth0 inet manual
179     up ifconfig $IFACE 0.0.0.0 up
180       up ip link set $IFACE promisc on
181       down ip link set $IFACE promisc off
182       down ifconfig $IFACE down

好了,interfaces中对于以太网卡的配置基本上介绍完了

配置虚拟机Ubuntu网络连接

© 著作权归作者所有

gzwawj
粉丝 0
博文 10
码字总数 10711
作品 0
石家庄
私信 提问
加载中

评论(0)

Windows 下用 SecureCRT 连接 VirtualBox 中的 Ubuntu

软件准备工作 (1)下载VirtualBox 虚拟机,地址:https://www.virtualbox.org/wiki/Downloads (2) 下载Ubuntu 10.4 LTS,地址:http://download.chinaunix.net/download/0013000/12776.shtm......

IT追寻者
2013/12/15
2.8K
0
SSH远程连接VMware虚拟机中linux

场景,SSH远程连接VMware虚拟机中linux系统,涉及两台物理机,我本身的情况是一台PC,一台win 2012服务器,将VMware装在服务器上,现在使用putty远程连接VMware中Ubuntu。 相关配置 PC利用p...

fjie
2015/12/25
0
0
虚拟机搭建Ubuntu开发环境

很多人都是Win下开发,Linux下面部署,但是有些时候在Win下面做开发也是有些不方便的,例如有一次笔者需要做个小功能,给视频截图,采用ffmpeg这个强大的工具,但是Win下面配置起来特别麻烦 ...

一个不想写代码的程序员
2017/11/20
0
0
VirtualBox 使用 NAT 方式网络的 SSH 连接

在Ubuntu 14.04上亲测解决问题。 本文的 VirtualBox 是基于 Windows 平台环境,虚拟机中安装了 Ubuntu,即在 Windows 平台下通过 SSH 方式连接虚拟机中的 Ubuntu。   一直以来都使用 Virt...

SBaof
2015/08/06
523
0
Ubuntu网络配置与SSH远程连接

操作前需要以下软件,且,Ubuntu已经安装在VMware Workstation上。 VMware的编辑tab->虚拟网络编辑 菜单查看网络配置: 1.进入模式下,设置虚拟机IP为的,配置如下: interfaces.png 也可以把...

sparkle123
2017/12/28
0
0

没有更多内容

加载失败,请刷新页面

加载更多

django

aiodns 1.1.1aiohttp 3.6.1asn1crypto 0.24.0async-timeout 3.0.1attrs 19......

MtrS
10分钟前
29
0
SQL查询单表数据(一)

本节讲述 基本的 select 查询单表数据语句 1 从单表中查询所有的行和列 查询表中所有的数据 select * from t_user 在 SQL 中,字符 "*" 具有特殊的含义,使用用它,将从指定的表中返回每一列...

赵子龙
17分钟前
19
0
签名与无符号整数

我是否正确地说有符号和无符号整数之间的区别是: 无符号可以保持较大的正值,而不是负值。 无符号使用前导位作为值的一部分,而带符号版本使用最左侧位来标识数字是正数还是负数。 有符号整...

javail
23分钟前
39
0
【Vue_05】前端工程化

一、ES6的模块化 1. ES6模块化规范 每个 js 文件都是一个独立的模块 导入模块成员使用 import 关键字 暴露模块成员使用 export 关键字 2. 基本语法 发使用 export default { }导出默认成员 ...

Demo_Null
24分钟前
33
0
阿里P7高级架构师分享6年多的Java工作经验(想冲破瓶颈者必看)

很多工作了五年左右的程序员每天已经习惯了机器般的写代码,如果是这样那么你永远只会是个基础程序员,因为你不能只会用,你要知道原理,不至于让你自己实现一个出来,但是基本原理要知道。 ...

JAVA一方
35分钟前
25
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部