您好,欢迎访问三七文档
当前位置:首页 > 商业/管理/HR > 质量控制/管理 > 交换机端口安全Port-Security超级详解
交换机端口安全Port-Security超级详解交换安全】交换机端口安全Port-Security超级详解一、Port-Security概述在部署园区网的时候,对于交换机,我们往往有如下几种特殊的需求:限制交换机每个端口下接入主机的数量(MAC地址数量)限定交换机端口下所连接的主机(根据IP或MAC地址进行过滤)当出现违例时间的时候能够检测到,并可采取惩罚措施上述需求,可通过交换机的Port-Security功能来实现:二、理解Port-Security1.Port-Security安全地址:secureMACaddress在接口上激活Port-Security后,该接口就具有了一定的安全功能,例如能够限制接口(所连接的)的最大MAC数量,从而限制接入的主机用户;或者限定接口所连接的特定MAC,从而实现接入用户的限制。那么要执行过滤或者限制动作,就需要有依据,这个依据就是安全地址–secureMACaddress。安全地址表项可以通过让使用端口动态学习到的MAC(SecureDynamic),或者是手工在接口下进行配置(SecureConfigured),以及sticyMACaddress(SecureSticky)三种方式进行配置。当我们将接口允许的MAC地址数量设置为1并且为接口设置一个安全地址,那么这个接口将只为该MAC所属的PC服务,也就是源为该MAC的数据帧能够进入该接口。2.当以下情况发生时,激活惩罚(violation):当一个激活了Port-Security的接口上,MAC地址数量已经达到了配置的最大安全地址数量,并且又收到了一个新的数据帧,而这个数据帧的源MAC并不在这些安全地址中,那么启动惩罚措施当在一个Port-Security接口上配置了某个安全地址,而这个安全地址的MAC又企图在同VLAN的另一个Port-Security接口上接入时,启动惩罚措施当设置了Port-Security接口的最大允许MAC的数量后,接口关联的安全地址表项可以通过如下方式获取:在接口下使用switchportport-securitymac-address来配置静态安全地址表项使用接口动态学习到的MAC来构成安全地址表项一部分静态配置,一部分动态学习当接口出现up/down,则所有动态学习的MAC安全地址表项将清空。而静态配置的安全地址表项依然保留。3.Port-Security与StickyMAC地址上面我们说了,通过接口动态学习的MAC地址构成的安全地址表项,在接口出现up/down后,将会丢失这些通过动态学习到的MAC构成的安全地址表项,但是所有的接口都用switchportport-securitymac-address手工来配置,工作量又太大。因此这个stickymac地址,可以让我们将这些动态学习到的MAC变成“粘滞状态”,可以简单的理解为,我先动态的学,学到之后我再将你粘起来,形成一条”静态“(实际上是SecureSticky)的表项。在up/down现象出现后仍能保存。而在使用wr后,这些sticky安全地址将被写入start-upconfig,即使设备重启也不会被丢失。三、默认的Port-Security配置Port-Security默认关闭默认最大允许的安全MAC地址数量1惩罚模式shutdown(进入err-disable状态),同时发送一个SNMPtrap四、Port-Security的部署注意事项1.Port-Security配置步骤a)在接口上激活Port-SecurityPort-Security开启后,相关参数都有默认配置,需关注b)配置每个接口的安全地址(SecureMACAddress)可通过交换机动态学习、手工配置、以及stciky等方式创建安全地址c)配置Port-Security惩罚机制默认为shutdown,可选的还有protect、restrictd)(可选)配置安全地址老化时间2.关于被惩罚后进入err-disable的恢复:如果一个psec端口由于被惩罚进入了err-disable,可以使用如下方法来恢复接口的状态:使用全局配置命令:err-disablerecoverypsecure-violation手工将特定的端口shutdown再noshutdown3.清除接口上动态学习到的安全地址表项使用clearport-securitydynamic命令,将清除所有port-security接口上通过动态学习到的安全地址表项使用clearport-securitysticky命令,将清除所有sticky安全地址表项使用clearport-securityconfigured命令,将清除所有手工配置的安全地址表项使用clearport-securityall命令,将清除所有安全地址表项使用showport-securityaddress来查看每个port-security接口下的安全地址表项4.关于sticky安全地址Sticky安全地址,是允许我们将Port-Security接口通过动态学习到的MAC地址变成“粘滞”的安全地址,从而不会由于接口的up/down丢失。然而如果我们希望在设备重启之后,这个sticky的安全地址表项仍然存在,那么就需要wr一下。将配置写入start-upconfig文件。Sticky安全地址也是一个简化我们管理员操作的一个很好的工具,毕竟现在不用再一条条的手工去绑了。5.port-security支持privatevlan6.port-security支持802.1Qtunnel接口7.port-security不支持SPAN的目的接口8.port-security不支持etherchannel的port-channel接口9.在CISCOIOS12.2(33)SXH以及后续的版本,我们可以将port-security及802.1X部署在同一个接口上。而在此之前的软件版本:如果你试图在一个port-security接口上激活8021.X则会报错,并且802.1X功能无法开启如果你试图在一个802.1X接口上激活port-security则也会报错,并且port-security特性无法开启10.Port-Security支持nonegotiatingtrunk接口Port-Security支持在如下配置的trunk上激活switchportswitchporttrunkencapsulation?switchportmodetruknswitchportnonegotiateIfyoureconfigureasecureaccessportasatrunk,portsecurityconvertsallthestickyandstaticsecureaddressesonthatportthatweredynamicallylearnedintheaccessVLANtostickyorstaticsecureaddressesonthenativeVLANofthetrunk.PortsecurityremovesallsecureaddressesonthevoiceVLANoftheaccessport.Ifyoureconfigureasecuretrunkasanaccessport,portsecurityconvertsallstickyandstaticaddresseslearnedonthenativeVLANtoaddresseslearnedontheaccessVLANoftheaccessport.PortsecurityremovesalladdresseslearnedonVLANsotherthanthenativeVLAN.11.Flexlinks和Port-Security互不兼容五、Port-security的配置1.激活Port-Security(在access接口上)Switch(config)#interfacefast0/1Switch(config-if)#switchportSwitch(config-if)#switchportmodeaccessSwitch(config-if)#switchportaccessvlan10Switch(config-if)#switchportport-security接口的Port-Security特性一旦激活后,默认的最大安全地址个数为1,也就是说,在不进行手工配置安全地址的情况下,这个接口将使用其动态学习到的MAC作为安全地址,并且,这个接口相当于被该MAC(所属的设备)独占。而且默认的violation是shutdownSW1#showport-securityinterfacef0/1PortSecurity:EnabledPortStatus:Secure-up!!接口目前的状态是up的ViolationMode:Shutdown!!违例后的惩罚措施,默认为shutdownAgingTime:0minsAgingType:AbsoluteSecureStaticAddressAging:DisabledMaximumMACAddresses:1!!最大安全地址个数,默认为1TotalMACAddresses:0ConfiguredMACAddresses:0!!手工静态配置的安全MAC地址,这里没配StickyMACAddresses:0!!sticky的安全地址,这里没有LastSourceAddress:Vlan:00b0.1111.2222:10!!最近的一个安全地址+vlanSecurityViolationCount:0!!该接口历史上出现过的违例次数这个时候,如果另一台PC接入到这个端口上,那么该port-security接口将会收到一个新的、非安全地址表项中的MAC地址的数据帧,于是触发的违例动作,给接口将被err-disable掉。同时产生一个snmptrap消息,另外,接口下,SecurityViolationCount将会加12.激活Port-Security(在trunk接口上)3.Port-Securityviolation惩罚措施默认的violation是shutdown。如果是protect,那么惩罚就会温柔些,对于非法的数据帧(例如数据帧的源MAC不在安全地址表项中的、且安全地址已经达到最大数),这些非法数据将仅仅被丢弃,合法数据照常转发,同时不会触发一个syslog消息,另外接口下的“SecurityViolationCount”也不会加1。而如果是restrict,那么非法数据被丢弃,同时触发一个syslog消息,再者,SecurityViolationCount加1,合法的数据照常转发。4.配置PortSecurityRateLimiter(注意,在6509交换机,truncatedswitching模式下不支持该功能)在交换机接口上开启Port-Security是会耗费资源的,Port-Security会检测每一个进入接口的数据帧,以判断流量是否合法,或者是否存在违例行为。当一个安全接口设置的violation为shutdown的时候,该接口在违例后触发惩罚机制,进入err-diasble状态,这样可以有效的方式有效的防止交换机由于处理违例事件导致交换机的CPU利用率过高。然而protect和restict的惩罚措施,则不会将端口关闭,端口依然可用,那么这就可能导致在违例事件发生的情况下交换机的CPU利用率飙高(例如大量的非法数据涌入)。因此当使用protect和restrict这两种违例惩罚措施事,可以通过Port-Secuirtyratelimiter来防止CPU飙高。Switch(config)#mlsrate-limitelayer2port-securityrate_in_pps[burst_size]关于rate_in_pps参数:范围是1
本文标题:交换机端口安全Port-Security超级详解
链接地址:https://www.777doc.com/doc-6070190 .html