将设为首页浏览此站
开启辅助访问 天气与日历 收藏本站联系我们切换到窄版

易陆发现论坛

 找回密码
 开始注册
查看: 2610|回复: 2
收起左侧

Linux-eth0 eth0:1 和eth0.1关系、ifconfig以及虚拟IP实现介绍

[复制链接]
发表于 2016-12-15 22:07:18 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有帐号?开始注册

x
eth0 eth0:1 和eth0.1三者的关系对应于物理网卡、子网卡、虚拟VLAN网卡的关系:( e6 A5 K6 T) o) g0 l5 e5 B0 ?
物理网卡:物理网卡这里指的是服务器上实际的网络接口设备,这里我服务器上双网卡,在系统中看到的2个物理网卡分别对应是eth0和eth1这两个网络接口。$ L& p; Q6 M: F4 b/ Z6 Z

/ @' J: O/ A. `8 |8 Y8 f& E8 q: ]# `子网卡:子网卡在这里并不是实际上的网络接口设备,但是可以作为网络接口在系统中出现,如eth0:1、eth1:2这种网络接口。它们必须要依赖于物理网卡,虽然可以与物理网卡的网络接口同时在系统中存在并使用不同的IP地址,而且也拥有它们自己的网络接口配置文件。但是当所依赖的物理网卡不启用时(Down状态)这些子网卡也将一同不能工作。& S7 W  t- x/ \! I2 `" M

- E( Y" f1 I; {& G# E/ m. C1 H虚拟VLAN网卡:这些虚拟VLAN网卡也不是实际上的网络接口设备,也可以作为网络接口在系统中出现,但是与子网卡不同的是,他们没有自己的配置文件。他们只是通过将物理网加入不同的VLAN而生成的VLAN虚拟网卡。如果将一个物理网卡通过vconfig命令添加到多个VLAN当中去的话,就会有多个VLAN虚拟网卡出现,他们的信息以及相关的VLAN信息都是保存在/proc/net/vlan/config这个临时文件中的,而没有独自的配置文件。它们的网络接口名是eth0.1、eth1.2这种名字。
注意:当需要启用VLAN虚拟网卡工作的时候,关联的物理网卡网络接口上必须没有IP地址的配置信息,并且,这些主物理网卡的子网卡也必须不能被启用和必须不能有IP地址配置信息。这个在网上看到的结论根据我的实际测试结果来看是不准确的,物理网卡本身可以绑定IP,并且给本征vlan提供通信网关的功能,但必须是在802.1q下。
* H% }+ K: e2 Q, P/ W% L# {3 H
/sbin/ifconfig 查看、配置、启用或禁用网络接口(网卡)的工具 5 {  |% K# |' d4 k2 ?8 Q+ G
ifconfig 是一个用来查看、配置、启用或禁用网络接口的工具,这个工具极为常用的。比如我们可以用这个工具来配置网卡的IP地址、MAC地址、掩码、广播地址等。值得一说的是用ifconfig 为网卡指定IP地址,这只是用来调试网络用的,并不会更改系统关于网卡的配置文件。如果您想把网络接口的IP地址固定下来,目前有三个方法:一是通过各个发行和版本专用的工具来修改IP地址;二是直接修改网络接口的配置文件;三是修改特定的文件,加入ifconfig 指令来指定网卡的IP地址,比如在redhat或Fedora中,把ifconfig 的语名写入/etc/rc.d/rc.local文件中;
/etc/sysconfig/network5 A. ^; f# O) b* J
/etc/sysconfig/network-scripts/ifcfg-eth0
& r+ P( n- D' k" h& w; c8 X4 G0 \
ifconfig配置网络接口语法: 0 b" C9 i4 d' Y, n4 i4 {
ifconfig 网络端口 IP地址 hw MAC地址 netmask 掩码地址 broadcast 广播地址 [up/down] ' m# s# u! ?' D% x1 @

! S3 C: B3 y3 }2 R: Uifconfig常用用法:
  • ifconfig : 查看主机激活状态的网络接口情况; 输出结果中:lo 是表示主机的回坏地址,eth0 表示第一块网卡, 其中 HWaddr 表示网卡的物理地址(MAC地址); inet addr 用来表示网卡的IP地址,Bcast表示广播地址,Mask表示掩码地址
  • ifconfig -a : 查看主机所有(包括没有被激活的)网络接口的情况
  • ifconfig eth0 : 查看特定网络接口的状态
  • ifconfig eth0 down = ifup eth0 : 如果eth0是激活的,就把它终止掉。此命令等同于 ifdown eth0;
  • ifconfig eth0 up = ifdown eth0 : 激活eth0 ; 此命令等同于 ifup eth0
  • ifconfig eth0 192.168.1.99 broadcast 192.168.1.255 netmask 255.255.255.0 : 配置 eth0的IP地址、广播地址和网络掩码;
  • ifconfig eth0 192.168.1.99 broadcast 192.168.1.255 netmask 255.255.255.0 up : 配置IP地址、网络掩码、广播地址的同时,激活网卡eth0
  • ifconfig eth1 hw ether 00:11:00:00:11:22 : 设置网卡的物理地址(MAC地址)。其中 hw 后面所接的是网络接口类型, ether表示以太网, 同时也支持 ax25 、ARCnet、netrom等,详情请查看 man ifconfig ;
    0 g' n) N- Y: d

  `. V3 R2 q4 c1 N9 k
虚拟IP技术在高可用领域像数据库SQLSERVER、web服务器等场景下使用很多,很疑惑它是怎么实现的,偶然,发现了一种方式可以实现虚拟ip。它的原理在于同一个物理网卡,是可以拥有多个ip地址的,至于虚拟网卡,也可用通过该方式拥有多个ip。  即对外提供数据库服务器的主机除了有一个真实IP外还有一个虚IP,使用这两个IP中的 任意一个都可以连接到这台主机,所有项目中数据库链接一项配置的都是这个虚IP,当服务器发生故障无法对外提供服务时,动态将这个虚IP切换到备用主机。
其实现原理主要是靠TCP/IP的ARP协议。因为ip地址只是一个逻辑地址,在以太网中MAC地址才是真正用来进行数据传输的物理地址,每台主机中都有一个ARP高速缓存,存储同一个网络内的IP地址与MAC地址的对应关系,以太网中的主机发送数据时会先从这个缓存中查询目标IP对应的MAC地址,会向这个MAC地址发送数据。操作系统会自动维护这个缓存。这就是整个实现 的关键。
在eth0处引用别名,设置完子网掩码即可1 |  x% _: H6 J
ifconfig eth0:0 166.111.69.100 netmask 255.255.255.0 up
此时查看网卡信息
[url=]http://common.cnblogs.com/images/copycode.gif[/url]
1 i/ [/ ]( T9 C+ y1 `% Qeth0 Link encap:Ethernet HWaddr 08:00:27:64:59:11           inet addr:166.111.69.17 Bcast:166.111.69.255 Mask:255.255.255.0          inet6 addr: 2402:f000:1:4412:a00:27ff:fe64:5911/64 Scope:Global          inet6 addr: fe80::a00:27ff:fe64:5911/64 Scope:Link          UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1          RX packets:597673 errors:0 dropped:0 overruns:0 frame:0          TX packets:215472 errors:0 dropped:0 overruns:0 carrier:0          collisions:0 txqueuelen:1000           RX bytes:67285933 (67.2 MB) TX bytes:22782158 (22.7 MB)eth0:0 Link encap:Ethernet HWaddr 08:00:27:64:59:11           inet addr:166.111.69.100 Bcast:166.111.69.255 Mask:255.255.255.0          UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1lo Link encap:Local Loopback           inet addr:127.0.0.1 Mask:255.0.0.0          inet6 addr: ::1/128 Scope:Host          UP LOOPBACK RUNNING MTU:16436 Metric:1          RX packets:843 errors:0 dropped:0 overruns:0 frame:0          TX packets:843 errors:0 dropped:0 overruns:0 carrier:0          collisions:0 txqueuelen:0           RX bytes:67174 (67.1 KB) TX bytes:67174 (67.1 KB)[url=]http://common.cnblogs.com/images/copycode.gif[/url]# k5 [6 O, V0 h4 J

! C! J9 B( t" b5 A8 v4 j* `
然后找另一台机器ping这个vip(eth0:0)就可以看到显示结果了。
( S, ]$ W* V( U, u# A* c写在/etc/rc.local里也可以,写在这里就不怕断电后机器无法正常使用了。

% D& g: U4 T/ m) t+ ^  p6 S用ifconfig 来配置虚拟网络接口: 8 H/ @  ?9 O) c; H( t% f
有时我们为了满足不同的需要还需要配置虚拟网络接口,比如我们用不同的IP地址来架运行多个HTTPD服务器,就要用到虚拟地址;这样就省却了同一个IP地址,如果开设两个的HTTPD服务器时,要指定端口号。 . ^, o. P4 J- X3 r7 J% e3 F! ^* q0 T
) ]  \/ d8 c, T4 P
虚拟网络接口指的是为一个网络接口指定多个IP地址,虚拟接口是这样的 eth0:0 、 eth0:1、eth0:2 ... .. eth1N。当然您为eth1 指定多个IP地址,也就是 eth1:0、eth1:1、eth1:2 ... ...以此类推;
/ S4 J( |3 k9 n/ o% ~% x; v" i" @& iifconfig eth1:0 192.168.1.250 hw ether 00:11:00:00:11:44 netmask 255.255.255.0 broadcast 192.168.1.255 up
% ]" L1 H: u- iifconfig eth1:1 192.168.1.249 hw ether 00:11:00:00:11:55 netmask 255.255.255.0 broadcast 192.168.1.255 up . T. b: a; G7 r9 t# E
注意:指定时,要为每个虚拟网卡指定不同的物理地址;
8 `3 W  {& ^, k1 S" ?; P/ T
 楼主| 发表于 2016-12-15 22:10:42 | 显示全部楼层
经常用eth0和eth:0这样的方式处理问题,在cisco中提到过使用VLAN标签,就eth0.0的VLAN标签。
 楼主| 发表于 2016-12-15 22:10:51 | 显示全部楼层
经常用eth0和eth:0这样的方式处理问题,在cisco中提到过使用VLAN标签,就eth0.0的VLAN标签。
您需要登录后才可以回帖 登录 | 开始注册

本版积分规则

关闭

站长推荐上一条 /4 下一条

如有购买积分卡请联系497906712

QQ|返回首页|Archiver|手机版|小黑屋|易陆发现 点击这里给我发消息

GMT+8, 2022-1-28 01:41 , Processed in 0.075782 second(s), 26 queries .

Powered by LR.LINUX.cloud bbs168x X3.2 Licensed

© 2012-2022 Comsenz Inc.

快速回复 返回顶部 返回列表