01-MAC地址表命令
本章节下载: 01-MAC地址表命令 (249.96 KB)
目 录
1.1.2 display mac-address aging-time
1.1.3 display mac-address mac-learning
1.1.4 mac-address (interface view)
1.1.5 mac-address (system view)
1.1.6 mac-address mac-learning enable
1.1.7 mac-address mac-learning priority
1.1.8 mac-address max-mac-count
1.1.9 mac-address max-mac-count enable-forwarding
1.1.10 mac-address notification mac-move
1.1.11 mac-address notification mac-move suppression (interface view)
1.1.12 mac-address notification mac-move suppression (system view)
1.1.14 snmp-agent trap enable mac-address
本章节内容只涉及单播的静态、动态和黑洞MAC地址表项的配置。
display mac-address命令用来显示MAC地址表信息。
【命令】
display mac-address [ mac-address [ vlan vlan-id ] | [ [ dynamic | static ] [ interface interface-type interface-number ] | blackhole ] [ vlan vlan-id ] [ count ] ]
【视图】
任意视图
【缺省用户角色】
network-admin
network-operator
【参数】
mac-address:显示指定MAC地址的MAC地址表项,mac-address的格式为H-H-H。在配置时,用户可以省去MAC地址中每段开头的“0”,例如输入“f-e2-1”即表示输入的MAC地址为“000f-00e2-0001”。
vlan vlan-id:显示指定VLAN的MAC地址表项。vlan-id的取值范围为1~4094。
dynamic:显示动态MAC地址表项。
static:显示静态MAC地址表项。
interface interface-type interface-number:显示指定接口的MAC地址表项。interface-type interface-number为接口类型和接口编号。
blackhole:显示黑洞MAC地址表项。
count:显示MAC地址表项的数量。如果配置本参数,将仅显示符合条件的(由count前面的参数决定)MAC地址表项的数量,而不显示MAC地址表项的具体内容。如果不指定本参数,则显示符合条件的MAC地址表的具体内容。
【使用指导】
使用本命令可以查看静态、动态和黑洞MAC地址表项,表项内容主要包括MAC地址、VLAN ID、接口等信息。
如果不指定任何参数,将显示所有的MAC地址表项信息。
对于聚合接口,需要有选中端口,该聚合接口对应的动态MAC地址才能在MAC地址表项中显示。
【举例】
# 显示VLAN 100的MAC地址表项的信息。
<Sysname> display mac-address vlan 100
MAC Address VLAN ID State Port/Nickname Aging
GE1/0/2
0033-0033-0033 100 Blackhole N/A N
0000-0000-0002 100 Static GE1/0/3 N
00e0-fc00-5829 100 Learned GE1/0/4 Y
# 显示MAC地址表项的数量。
<Sysname> display mac-address count
1 mac address(es) found.
表1-1 display mac-address命令显示信息描述表
字段 |
描述 |
MAC Address |
MAC地址 |
VLAN ID |
MAC地址对应接口所属的VLAN |
State |
MAC地址表项的状态,包括: · Static:表示该表项是静态MAC地址表项 · Learned:动态MAC地址表项。可以手工配置也可以由设备学习获得 · Blackhole:表示该表项是黑洞MAC地址表项 · Security:表示该表项是端口安全特性中配置或学习到的MAC地址表项 |
Port/Nickname |
MAC地址对应的接口名称表示发往该MAC地址的报文将从此接口发出(黑洞MAC地址表项此处显示为N/A) |
Aging |
老化时间,该表项有两种取值: · Y:表示该表项会被老化 · N:表示该表项不会被老化 |
n mac address(es) found |
共有n个MAC地址表项 |
【相关命令】
· mac-address
· mac-address timer
display mac-address aging-time命令用来显示MAC地址表动态表项的老化时间。
【命令】
display mac-address aging-time
【视图】
任意视图
【缺省用户角色】
network-admin
network-operator
【举例】
# 显示MAC地址表中动态表项的老化时间。
<Sysname> display mac-address aging-time
MAC address aging time: 300s.
【相关命令】
· mac-address timer
display mac-address mac-learning命令用来显示MAC地址学习功能的开启状态。
【命令】
display mac-address mac-learning [ interface interface-type interface-number ]
【视图】
任意视图
【缺省用户角色】
network-admin
network-operator
【参数】
interface interface-type interface-number:显示指定接口的MAC地址学习状态。interface-type interface-number为接口类型和接口编号。如果不指定本参数,则显示全局和所有接口的MAC地址学习状态。
【举例】
# 显示全局和所有接口的MAC地址学习状态。
<Sysname> display mac-address mac-learning
Global MAC address learning status: Enabled.
Port Learning Status
GE1/0/1 Enabled
GE1/0/2 Enabled
表1-2 display mac-address mac-learning命令显示信息描述表
字段 |
描述 |
Global MAC address learning status |
全局的MAC地址学习状态:Enabled为开启,Disabled为禁止 |
Port |
接口名称 |
Learning Status |
接口的MAC地址学习状态:Enabled为开启,Disabled为禁止 |
【相关命令】
· mac-address mac-learning enable
mac-address命令用来在接口下添加或者修改MAC地址表项。
undo mac-address命令用来删除接口下的MAC地址表项。
【命令】
mac-address { dynamic | static } mac-address vlan vlan-id
undo mac-address { dynamic | static } mac-address vlan vlan-id
【缺省情况】
接口下未配置任何MAC地址表项。
【视图】
二层以太网接口视图
二层聚合接口视图
【缺省用户角色】
network-admin
【参数】
dynamic:动态MAC地址表项。
static:静态MAC地址表项。
mac-address:MAC地址,格式为H-H-H,不支持组播MAC地址、全0的MAC地址和全F的MAC地址。在配置时,用户可以省去MAC地址中每段开头的“0”,例如输入“f-e2-1”即表示输入的MAC地址为“000f-00e2-0001”。
vlan vlan-id:当前接口所属的VLAN。vlan-id为指定VLAN的编号,取值范围为1~4094。该VLAN必须已经创建。
【使用指导】
一般情况下,设备通过源MAC地址学习过程自动建立MAC地址表。为了提高接口安全性,网络管理员可手工在MAC地址表中加入特定MAC地址表项,将用户设备与接口绑定,从而防止非法用户骗取数据。手工配置的静态MAC地址表项优先级高于自动生成的表项。
如果不保存配置,设备重启后所有表项都会丢失;如果保存配置,静态MAC地址表项不会丢失,动态MAC地址表项会丢失。
【举例】
# 在端口GigabitEthernet1/0/1下增加静态MAC地址表项000f-e201-0101,该端口属于VLAN 2。
<Sysname> system-view
[Sysname] interface gigabitethernet 1/0/1
[Sysname-GigabitEthernet1/0/1] mac-address static 000f-e201-0101 vlan 2
# 在接口Bridge-Aggregation1下增加静态MAC地址表项000f-e201-0102,该接口属于VLAN 1。
<Sysname> system-view
[Sysname] interface bridge-aggregation 1
[Sysname-Bridge-Aggregation1] mac-address static 000f-e201-0102 vlan 1
【相关命令】
· display mac-address
· mac-address (system view)
mac-address命令用来添加或者修改MAC地址表项。
undo mac-address命令用来删除MAC地址表项。
【命令】
mac-address { dynamic | static } mac-address interface interface-type interface-number vlan vlan-id
mac-address blackhole mac-address vlan vlan-id
undo mac-address [ [ dynamic | static ] mac-address interface interface-type interface-number vlan vlan-id ]
undo mac-address [ blackhole | dynamic | static ] [ mac-address ] vlan vlan-id
undo mac-address [ dynamic | static ] interface interface-type interface-number
【缺省情况】
未配置任何MAC地址表项。
【视图】
系统视图
【缺省用户角色】
network-admin
【参数】
dynamic:动态MAC地址表项。
static:静态MAC地址表项。
blackhole:黑洞MAC地址表项。当报文的源MAC地址或目的MAC地址与黑洞MAC地址表项匹配时,该报文被丢弃。
mac-address:MAC地址,格式为H-H-H,不支持组播MAC地址、全0的MAC地址和全F的MAC地址。在配置时,用户可以省去MAC地址中每段开头的“0”,例如输入“f-e2-1”即表示输入的MAC地址为“000f-00e2-0001”。
vlan vlan-id:指定接口所属的VLAN。vlan-id为指定VLAN的编号,取值范围为1~4094。该VLAN必须已经创建。
interface interface-type interface-number:出接口。interface-type interface-number为接口类型和接口编号。
【使用指导】
通过本命令可以添加或者修改如下类型的MAC地址表项:
动态MAC地址:设备通过源MAC地址学习过程自动建立MAC地址表或者由用户手工配置。
静态MAC地址:为了提高接口安全性,网络管理员可手工在MAC地址表中加入特定MAC地址表项,将用户设备与接口绑定,从而防止非法用户骗取数据。手工配置的静态MAC地址表项优先级高于自动生成的表项。
黑洞MAC地址:用于丢弃指定源MAC地址或目的MAC地址的报文。
用户手工配置的静态MAC地址表项或黑洞MAC地址表项不会被动态MAC地址表项覆盖,而动态MAC地址表项可以被静态MAC地址表项和黑洞MAC地址表项覆盖。
删除MAC地址表项时,需要注意:
· 执行undo mac-address命令时若不指定任何参数,将删除所有单播MAC地址表项和静态组播MAC地址表项。
· 可以删除指定VLAN的所有MAC地址表项(包括单播MAC地址表项和静态组播MAC地址表项);可以选择删除动态MAC地址表项、静态MAC地址表项、黑洞MAC地址表项;可以按接口删除单播MAC地址表项,但不能按接口删除组播MAC地址表项。
如果不保存配置,设备重启后所有表项都会丢失;如果保存配置,静态MAC地址表项、黑洞MAC地址表项不会丢失,动态表项会丢失。
【举例】
# 添加静态地址表项,目的MAC地址为000f-e201-0101,出接口为GigabitEthernet1/0/1,且该接口属于VLAN 2。
<Sysname> system-view
[Sysname] mac-address static 000f-e201-0101 interface gigabitethernet 1/0/1 vlan 2
【相关命令】
· display mac-address
· mac-address (interface view)
mac-address mac-learning enable命令用来打开设备全局、接口或者VLAN的MAC地址学习功能。
undo mac-address mac-learning enable命令用来关闭设备全局、接口或者VLAN的MAC地址学习功能。
【命令】
mac-address mac-learning enable
undo mac-address mac-learning enable
【缺省情况】
MAC地址学习功能处于开启状态。
【视图】
系统视图
二层以太网接口视图
二层聚合接口视图
【缺省用户角色】
network-admin
【使用指导】
有时为了保证设备的安全,需要关闭MAC地址学习功能。常见的危及设备安全的情况是:非法用户使用大量源MAC地址不同的报文攻击设备,导致设备MAC地址表资源耗尽,造成设备无法根据网络的变化更新MAC地址表。关闭MAC地址学习功能可以有效防止这种攻击。
关闭MAC地址学习功能时,需要注意:
· 关闭MAC地址学习功能后,设备就学不到新地址,从而影响设备及时刷新MAC地址表。用户可以根据实际情况关闭接口的MAC地址学习功能。
· 关闭全局的MAC地址学习功能后,接口将不再学习新的MAC地址。
· 关闭MAC地址学习功能可能会导致广播,因此在关闭接口的MAC地址学习功能的同时,一般还要使用接口广播风暴抑制功能。有关广播风暴抑制功能的介绍,请参见“接口管理配置指导”中的“以太网接口”。
· 在开启全局的MAC地址学习功能的前提下,用户可以关闭设备上单个接口或指定VLAN的MAC地址学习功能。
· 关闭MAC地址学习功能后,对于已经存在的动态MAC地址表项,待老化时间超时后将自然老化。
【举例】
# 关闭全局MAC地址学习功能。
<Sysname> system-view
[Sysname] undo mac-address mac-learning enable
# 关闭VLAN 10的MAC地址学习功能。
<Sysname> system-view
[Sysname] vlan 10
[Sysname-vlan10] undo mac-address mac-learning enable
# 关闭端口GigabitEthernet1/0/1的MAC地址学习功能。
<Sysname> system-view
[Sysname] interface gigabitethernet 1/0/1
[Sysname-GigabitEthernet1/0/1] undo mac-address mac-learning enable
# 关闭接口Bridge-Aggregation1的MAC地址学习功能。
<Sysname> system-view
[Sysname] interface bridge-aggregation 1
[Sysname-Bridge-Aggregation1] undo mac-address mac-learning enable
【相关命令】
· display mac-address mac-learning
mac-address mac-learning priority命令用来配置接口的MAC地址学习优先级。
undo mac-address mac-learning priority命令用来恢复缺省情况。
【命令】
mac-address mac-learning priority { high | low }
undo mac-address mac-learning priority
【缺省情况】
MAC地址学习优先级为低优先级。
【视图】
二层以太网接口视图
二层聚合接口视图
【缺省用户角色】
network-admin
【参数】
high:配置MAC地址学习优先级为高优先级。
low:配置MAC地址学习优先级为低优先级。
【使用指导】
接口的MAC地址学习功能分为两个优先级:高优先级和低优先级。对于高优先级的接口,可以学习任何MAC地址;对于低优先级的接口,在学习MAC地址时需要查看高优先级接口是否已经学到该MAC地址,如果已经学到,则不允许学习该MAC地址。
为了预防攻击,避免下行接口学到网关等上层设备的MAC地址,可以进行如下配置:
· 将上行接口的MAC地址学习优先级配置为高优先级。
· 将下行接口的MAC地址学习优先级配置为低优先级。
【举例】
# 配置端口GigabitEthernet1/0/1的MAC地址学习优先级为高优先级。
<Sysname> system-view
[Sysname] interface gigabitethernet 1/0/1
[Sysname-GigabitEthernet1/0/1] mac-address mac-learning priority high
# 配置接口Bridge-Aggregation1的MAC地址学习优先级为高优先级。
<Sysname> system-view
[Sysname] interface bridge-aggregation 1
[Sysname-Bridge-Aggregation1] mac-address mac-learning priority high
mac-address max-mac-count命令用来配置接口的MAC地址数学习上限。
undo mac-address max-mac-count命令用来恢复缺省情况。
【命令】
mac-address max-mac-count count
undo mac-address max-mac-count
【缺省情况】
接口的MAC地址数学习上限为1024。
【视图】
二层以太网接口视图
二层聚合接口视图
【缺省用户角色】
network-admin
【参数】
count:接口的MAC地址数学习上限,为0即表示不允许该接口学习MAC地址。取值范围为0~1024。
【使用指导】
通过配置接口的MAC地址数学习上限,用户可以控制设备维护的MAC地址表的表项数量。如果MAC地址表过于庞大,可能导致设备的转发性能下降。当接口学习到的MAC地址数达到上限时,该接口将不再对MAC地址进行学习。
【举例】
# 配置端口GigabitEthernet1/0/1的MAC地址数学习上限为600。
<Sysname> system-view
[Sysname] interface gigabitethernet 1/0/1
[Sysname-GigabitEthernet1/0/1] mac-address max-mac-count 600
【相关命令】
· mac-address
· mac-address max-mac-count enable-forwarding (interface view)
mac-address max-mac-count enable-forwarding命令用来配置当达到接口的MAC地址数学习上限时,允许转发源MAC地址不在MAC地址表里的报文。
undo mac-address max-mac-count enable-forwarding命令用来配置当达到接口的MAC地址数学习上限时,禁止转发源MAC地址不在MAC地址表里的报文。
【命令】
mac-address max-mac-count enable-forwarding
undo mac-address max-mac-count enable-forwarding
【缺省情况】
当达到接口的MAC地址数学习上限时,允许转发源MAC地址不在MAC地址表里的报文。
【视图】
二层以太网接口视图
二层聚合接口视图
【缺省用户角色】
network-admin
【举例】
# 配置端口GigabitEthernet1/0/1的MAC地址数学习上限为600,当端口学习的MAC地址数达到600时,禁止转发源MAC地址不在MAC地址表里的报文。
<Sysname> system-view
[Sysname] interface gigabitethernet 1/0/1
[Sysname-GigabitEthernet1/0/1] mac-address max-mac-count 600
[Sysname-GigabitEthernet1/0/1] undo mac-address max-mac-count enable-forwarding
【相关命令】
· mac-address
· mac-address max-mac-count
mac-address notification mac-move命令用来开启MAC地址迁移上报功能。
undo mac-address notification mac-move命令用来关闭MAC地址迁移上报功能。
【命令】
mac-address notification mac-move [ interval interval ]
undo mac-address notification mac-move
【缺省情况】
MAC地址迁移上报功能处于关闭状态。
【视图】
系统视图
【缺省用户角色】
network-admin
【参数】
interval interval:MAC地址迁移检测周期,取值范围为1~60,单位为分钟。如果未指定该参数,将采用缺省MAC地址迁移检测周期1分钟。
【使用指导】
开启MAC地址迁移上报功能后,当系统检测到地址迁移,会按照MAC地址迁移检测周期的间隔记录上一个MAC地址迁移检测周期内发生的MAC地址迁移日志,包括MAC地址、该MAC地址所在VLAN ID、MAC地址迁移源接口和新接口,以及该MAC地址在一个MAC地址迁移检测周期内的迁移次数。
一个MAC地址迁移检测周期内,最多能生成20条MAC地址的迁移日志,并且按迁移次数降序排列。该检测周期内,当新生成的迁移日志的迁移次数超过已存在的迁移日志的迁移次数时,迁移次数最小的迁移日志会被丢弃,新的迁移日志按迁移次数降序排列。等到下一个检测周期,上一个检测周期的所有日志信息将被丢弃,重新开始生成迁移日志。
执行本命令后,系统采用Syslog方式上报MAC地址迁移信息到信息中心模块,如果同时通过snmp-agent trap enable mac-address命令开启MAC地址表的告警功能,系统还会采用Trap信息上报MAC地址迁移信息到SNMP模块。
【举例】
# 开启MAC地址迁移上报功能。
<Sysname> system-view
[Sysname] mac-address notification mac-move
[Sysname]
%May 14 17:16:45:688 2013 Sysname MAC/4/MAC_FLAPPING: MAC address 0000-0012-0034 in VLAN 500 has moved from port GE1/0/1 to port GE1/0/2 for 1 times
以上显示信息表明:MAC地址0000-0012-0034所在VLAN ID为500,MAC地址迁移源接口为GigabitEthernet1/0/1,MAC地址迁移新接口为GigabitEthernet1/0/2,该MAC地址在一个MAC地址迁移检测周期内的迁移次数为1。
mac-address notification mac-move suppression命令用来开启接口上的MAC地址迁移抑制功能。
undo mac-address notification mac-move suppression命令用来关闭接口上的MAC地址迁移抑制功能。
【命令】
mac-address notification mac-move suppression
undo mac-address notification mac-move suppression
【缺省情况】
MAC地址迁移抑制功能处于关闭状态。
【视图】
二层以太网接口视图
二层聚合接口视图
【缺省用户角色】
network-admin
【使用指导】
开启MAC地址迁移抑制功能后,当监测到一个MAC地址迁移检测周期内某个MAC地址从某端口上迁移出或者迁移到该端口的次数超过MAC地址迁移抑制的检测阈值,则将该端口down,用户可以执行命令shutdown和undo shutdown将该端口恢复,也可以等MAC地址迁移抑制时间间隔后让该端口自行恢复up。
MAC地址迁移抑制功能使端口down后,系统将发送日志信息到信息中心模块,如果设备开启了MAC地址表的告警功能(snmp-agent trap enable mac-address命令),系统还会发送告警信息到设备的SNMP模块。
【举例】
# 开启MAC地址迁移抑制功能。
<Sysname> system-view
[Sysname] interface gigabitethernet 1/0/1
[Sysname-GigabitEthernet1/0/1] mac-address notification mac-move suppression
【相关命令】
· mac-address notification mac-move suppression (system view)
mac-address notification mac-move suppression命令用来配置MAC地址迁移抑制功能的相关参数。
undo mac-address notification mac-move suppression命令用来恢复缺省情况。
【命令】
mac-address notification mac-move suppression { interval interval | threshold threshold }
undo mac-address notification mac-move suppression { interval | threshold }
【缺省情况】
MAC地址迁移抑制功能的相关参数未配置,采用缺省抑制时间间隔30秒和缺省阈值3次。
【视图】
系统视图
【缺省用户角色】
network-admin
【参数】
interval interval:MAC地址迁移抑制时间间隔(检测攻击后,端口保持down状态的持续时间),取值范围为30~86400,单位为秒。如果未指定该参数,将采用缺省抑制时间间隔30秒。
threshold threshold:MAC地址迁移抑制的检测阈值(一个MAC地址迁移检测周期内允许MAC地址迁移的最大的迁移次数),取值范围为0~1024。如果未指定该参数,将采用缺省阈值3次。
【使用指导】
配置本命令后,当接口上开启了MAC地址迁移抑制功能时,本命令配置的参数才能生效。
本命令可多次配置,配置interval interval和threshold threshold时互不影响。
【举例】
# 配置MAC地址迁移抑制功能的抑制间隔为40s,检测阈值为1。
<Sysname> system-view
[Sysname] mac-address notification mac-move suppression interval 40
[Sysname] mac-address notification mac-move suppression threshold 1
【相关命令】
· mac-address notification mac-move suppression (interface view)
mac-address timer命令用来配置动态MAC地址表项的老化时间。
undo mac-address timer命令用来恢复缺省情况。
【命令】
mac-address timer { aging seconds | no-aging }
undo mac-address timer
【缺省情况】
动态MAC地址表项的老化时间为300秒。
【视图】
系统视图
【缺省用户角色】
network-admin
【参数】
aging seconds:动态MAC地址表项的老化时间,单位为秒,取值范围为100~1400。
no-aging:不老化。
【使用指导】
用户配置的老化时间过长或者过短,都可能影响设备的运行性能:
· 如果用户配置的老化时间过长,设备可能会保存许多过时的MAC地址表项,从而耗尽MAC地址表资源,导致设备无法根据网络的变化更新MAC地址表。
· 如果用户配置的老化时间太短,设备可能会删除有效的MAC地址表项,可能导致设备广播大量的数据报文,影响设备的运行性能。
所以用户需要根据实际情况,配置合适的老化时间来有效的实现MAC地址老化功能。
【举例】
# 配置动态MAC地址表项的老化时间为500秒。
<Sysname> system-view
[Sysname] mac-address timer aging 500
【相关命令】
· display mac-address aging-time
snmp-agent trap enable mac-address命令用来开启MAC地址表的告警功能。
undo snmp-agent trap enable mac-address命令用来关闭MAC地址表的告警功能。
【命令】
snmp-agent trap enable mac-address
undo snmp-agent trap enable mac-address
【缺省情况】
MAC地址表的告警功能处于开启状态。
【视图】
系统视图
【缺省用户角色】
network-admin
【使用指导】
开启MAC地址表的告警功能后,MAC地址表模块会生成告警信息,用于报告该模块的重要事件。生成的告警信息将发送到设备的SNMP模块,请通过设置SNMP中告警信息的发送参数,来决定告警信息输出的相关属性。
关闭MAC地址表的告警功能后,设备将只发送日志信息到信息中心模块,此时请配置信息中心的输出规则和输出方向来查看MAC地址表模块的日志信息。
有关SNMP和信息中心的详细介绍,请参见“网络管理和监控配置指导”中的“SNMP”和“信息中心”。
目前MAC地址表模块仅有MAC地址迁移上报的告警功能,所以打开或关闭MAC地址迁移上报的告警功能,就相当于打开或关闭MAC地址表所有的告警功能。
【举例】
# 关闭MAC地址迁移的告警功能。
<Sysname> system-view
[Sysname] undo snmp-agent trap enable mac-address
不同款型规格的资料略有差异, 详细信息请向具体销售和400咨询。H3C保留在没有任何通知或提示的情况下对资料内容进行修改的权利!