16-会话管理配置
本章节下载: 16-会话管理配置 (306.95 KB)
目 录
会话管理是为了实现NAT(Network Address Translation,网络地址转换)、ASPF(Advanced Stateful Packet Filter,高级状态包过滤)、攻击检测及防范等基于会话进行处理的业务而抽象出来的公共功能。此功能把传输层报文之间的交互关系抽象为会话,并根据发起方和响应方的报文信息对会话进行状态更新和老化,支持多个业务特性分别对同一个业务报文进行处理。
会话管理实现的主要功能包括:
· 报文到会话的快速匹配;
· 传输层协议状态的管理;
· 报文应用层协议类型的识别;
· 按照协议状态或应用层协议类型对会话进行老化;
· 支持指定的会话维持较为长时间的连接;
· 为需要进行端口协商的应用层协议提供特殊的报文匹配;
· 支持对ICMP/ICMPv6差错控制报文的解析以及根据解析结果进行会话的匹配。
会话管理主要基于传输层协议对报文进行检测。其实质是通过检测传输层协议信息来对连接的状态进行跟踪,并对所有连接的状态信息进行基于会话表和关联表的统一维护和管理。
客户端向服务器发起连接请求报文的时候,系统会创建一个会话表项。该表项中记录了一个会话所对应的请求报文信息和回应报文信息,包括源IP地址/端口号、目的IP地址/端口号、传输层协议类型、应用层协议类型、会话的协议状态等。对于多通道协议(特指部分应用协议中,客户端与服务器之间需要在已有连接基础上协商新的连接来完成一个应用),会话管理还会根据协议的协商情况,创建一个或多个(由具体的应用协议决定)关联表表项,用于关联属于同一个应用的不同会话。关联表项在多通道协议协商的过程中创建,完成对多通道协议的支持后即被删除。
上述会话管理的工作原理描述仅针对目的地址为单播地址的报文,对于目的地址是组播地址的报文稍有不同。组播报文到达设备后通常经由一个入接口到多个出接口进行转发,因此对于同一个应用的组播报文的连接,在入接口和多个出接口均会建立起各自的会话表项,我们称这类组播报文触发建立的会话表项为组播会话表项,以区别于单播报文触发建立的单播会话表项。若无特殊说明,本文中的会话表项不区分单播和组播类型。
在实际应用中,会话管理作为公共功能,只能实现连接状态的跟踪,并不能阻止潜在的攻击报文通过。会话管理配合ASPF特性,可实现根据连接状态信息动态地决定是否允许数据包通过设备进入内部区域,以便阻止恶意的入侵。
目前会话管理在设备上实现的具体功能如下:
· 支持对各协议报文创建会话、更新会话状态以及根据协议状态设置老化时间。
· 支持应用层协议的端口映射(参见“安全配置指导”中的“APR”),允许为应用层协议自定义对应的非通用端口号,同时可以根据应用层协议设置不同会话老化时间。
· 支持ICMP/ICMPv6差错报文的映射,可以根据ICMP/ICMPv6差错报文携带的信息查找原始的会话。
· 支持设置长连接会话,保证指定的会话在一段较长的时间内不会被老化。
· 支持应用层协议(如FTP)的控制通道和动态数据通道的会话管理。
会话管理支持的配置包括:协议状态的会话老化时间、应用层协议的会话老化时间、长连接会话规则及删除会话、会话业务热备份及会话统计等。这些配置可根据实际应用需求选择进行,配置无先后顺序的要求,相互不关联。
长连接老化时间仅在TCP会话进入稳态(TCP-EST状态)时生效。在会话稳态时,长连接老化时间具有最高的优先级,其次为应用层协议老化时间,最后为协议状态老化时间。
当会话数目过多时,建议不要将协议状态老化时间设置得过短,否则会造成设备响应速度过慢。
以下配置用于实现根据会话所处协议状态来设置会话表项的老化时间。处于某协议状态的会话,如果在该协议状态老化时间内未被任何报文匹配,则会由于老化而被系统自动删除。
表1-1 配置各协议状态的会话老化时间
操作 |
命令 |
说明 |
进入系统视图 |
system-view |
- |
配置各协议状态的会话老化时间 |
session aging-time state { fin | icmp-reply | icmp-request | rawip-open | rawip-ready | syn | tcp-close | tcp-est | tcp-time-wait | udp-open | udp-ready } time-value |
缺省情况下,各协议状态的会话老化时间为: · FIN:30秒 · ICMP-REPLAY:30秒 · ICMP-REQUEST:60秒 · RAWIP-OPEN:30秒 · RAWIP-READY:60秒 · SYN:30秒 · TCP-CLOSE:2秒 · TCP-EST:3600秒 · TCP-TIME-WAIT:2秒 · UDP-OPEN:30秒 · UDP-READY:60秒 |
· 当会话数目过多时,建议不要将应用层协议会话的老化时间设置得过短,否则会造成设备响应速度过慢。
· 老化时间的修改需要结合实际的使用场景,避免过大或过小,从而影响会话协议报文的正常交互。例如,FTP协议的会话老化时间若小于FTP保活报文发送的间隔,会造成FTP连接无法正常建立。
对于进入稳定状态的会话(TCP会话进入TCP-EST状态,UDP会话进入UDP-READY状态),还可以根据会话所属的应用层协议或应用设置老化时间。此类会话表项如果在一定时间内未被任何报文匹配,则会按照设置的应用层协议或应用会话老化时间老化。对于进入稳定状态的其它应用层协议的会话表项,则仍然遵循协议状态的会话老化时间进行老化。
此功能中的应用层协议或应用由APR模块定义,有关APR功能的详细介绍请参见“安全配置指导”中的“APR”。
表1-2 配置应用层协议或应用的会话老化时间
操作 |
命令 |
说明 |
进入系统视图 |
system-view |
- |
配置应用层协议或应用的会话老化时间 |
session aging-time application application-name time-value |
缺省情况下,部分协议的会话老化时间如下,单位为秒: · DNS:1 · FTP:3600 · GTP-CONTROL:60 · GTP-USER:60 · GPRS-DATA:60 · GPRS-SIG:60 · H225、H245:3600 · RAS、SIP:300 · RTSP:3600 · TFTP:60 · ILS:3600 · MGCP-CALLAGENT:60 · MGCP-GATEWAY:60 · PPTP:3600 · RSH:60 · SCCP:3600 · SQLNET:600 · XDMCP:3600 · BOOTPC:120 · BOOTPS:120 · FTP-DATA:240 · HTTPS:600 · L2TP:120 · NETBIOS-DGM:3600 · NETBIOS-NS:3600 · NETBIOS-SSN:3600 · NTP:120 · QQ:120 · RIP:120 · SNMP:120 · SNMPTRAP:120 · STUN:600 · SYSLOG:120 · TACACS-DS:120 · WHO:120 其它预定义应用层协议和自定义应用层协议的缺省会话老化时间为1200秒 |
针对进入TCP-EST状态的TCP会话,用户可以根据需要将符合指定特征的TCP会话设置为长连接会话。长连接会话的老化时间不会随着状态的变迁而更改,可以将其设置得比普通会话的老化时间更长,或者设置成永不老化。被设置成永不老化的长连接会话,只有当会话的发起方或响应方主动发起关闭连接请求或管理员手动删除该会话时,才会被删除。
系统支持配置多条长连接会话规则。
表1-3 配置长连接会话规则
操作 |
命令 |
说明 |
进入系统视图 |
system-view |
- |
配置长连接会话规则 |
session persistent acl [ ipv6 ] acl-number [ aging-time time-value ] |
缺省情况下,无长连接会话规则 |
在IRF组网环境中,当开启会话业务热备份功能的情况下,如果需要配置NAT业务,则必须保证NAT业务配置在IRF成员设备的全局接口上,例如聚合口、冗余口;如果在物理接口上配置了NAT业务,则建议关闭会话业务热备份功能。
会话业务热备功能实现了多台设备之间会话以及基于会话的业务(NAT、ALG、ASPF)的动态表项的热备份。互为备份的两台设备(通常为企业中心网关设备)对外提供一个虚拟IP地址与对端设备(通常为企业分支网关设备)进行通信。当一台设备出现故障时,利用相关冗余设备协商机制将当前设备上的业务流量切换到备份设备上继续进行业务的处理和转发,整个流量切换过程对于对端设备完全透明,不需要对端设备添加任何额外的配置。由于对动态表项进行了热备份,因此当业务流量从发生故障的设备切换到另一台设备后,并不会导致业务中断,可实现业务的平滑切换。
设备同时还支持会话业务的自动热备份功能。自动热备份功能是指系统自动备份启用了ALG功能的某些应用产生的会话表和关联表,这些应用包括H323、SIP和ILS。
开启会话业务热备份功能后,缺省情况下,DNS和HTTP协议的会话备份功能处于关闭状态,其它应用协议的会话备份功能处于开启状态。
对于DNS和HTTP类型的应用协议,通常在很少的报文交互之后就会断开连接,当发生主备切换造成当前连接中断时,客户端会立即重新发起请求,用户通常感知不到连接异常。因此,在大多数情况下这些应用协议不需要进行会话备份。如果用户明确知道当前的HTTP会话或者DNS会话将会持续较长的连接时间,或者确实希望对这两个应用协议创建的会话进行备份,可以通过该命令开启DNS或者HTTP的会话备份功能。
表1-4 配置会话业务热备份
操作 |
命令 |
说明 |
进入系统视图 |
system-view |
- |
开启会话业务热备份功能 |
session synchronization enable [ asymmetric ] |
缺省情况下,会话业务热备功能处于关闭状态 |
开启指定类型会话业务热备份功能 |
session synchronization { dns | http }* |
缺省情况下,DNS、HTTP应用协议的会话备份功能处于关闭状态 |
开启软件快速转发的会话统计功能之后,设备将对经软件快速转发收到和发送的基于会话的业务报文数目和报文字节数进行统计。基于单播会话的报文统计信息可通过display session table命令查看,基于单播报文类型的报文统计信息可通过display session statistics命令查看;基于组播会话的报文统计信息可通过display session table multicast命令查看,基于组播报文类型的报文统计信息可通过display session statistics multicast命令查看。
表1-5 开启软件快速转发的会话统计
操作 |
命令 |
说明 |
进入系统视图 |
system-view |
- |
开启软件快速转发的会话统计功能 |
session statistics enable |
缺省情况下,软件快速转发的会话统计功能的开启状态与设备的型号有关,请参考命令手册 |
开启会话数目的Top排名统计功能之后,设备将对基于会话的业务进行会话数目统计,分别基于源地址和目的地址对新建会话数目进行排序。会话数目的Top排名统计信息可以通过display session top-statistics命令查看。
表1-6 配置会话数目的Top排名统计功能
操作 |
命令 |
说明 |
进入系统视图 |
system-view |
- |
开启会话数目的Top排名统计功能 |
session top-statistics enable |
缺省情况下,会话数目的Top排名统计功能处于关闭状态 |
在非对称路径网络中,若设备上未开启会话业务热备份功能,则需要将会话状态机的模式配置为宽松模式,可以避免设备异常丢包。
在对称路径网络中,建议保持缺省状态,即严格模式。
表1-7 配置会话状态机为宽松模式
操作 |
命令 |
说明 |
进入系统视图 |
system-view |
- |
配置会话状态机为宽松模式 |
session state-machine mode loose |
缺省情况下,会话状态机为严格模式 |
会话日志是为满足网络管理员安全审计的需要,对用户的访问信息、用户IP地址的转换信息、用户的网络流量信息等进行记录,并可采用日志的格式发送给日志主机或者输出到信息中心。
存活时间或收发数目达到一定阈值的会话才会以日志的形式进行记录并输出,该阈值包括以下两种类型:
· 时间阈值:当一个会话存在的时间达到设定的时间阈值时,输出会话日志。
· 流量阈值:分为报文数阈值和字节数阈值两种。当一个会话收发的报文数或字节数达到设定的流量阈值时,输出会话日志。为使流量阈值能触发输出会话日志,必须开启软件快速转发的会话统计功能;否则,会话会由于无法统计报文的流量信息而不能通过流量阈值触发输出会话日志。
同时配置了时间阈值和流量阈值的情况下,只要有一个阈值到达,就会输出相应的会话日志,并将所有的阈值统计信息清零。
同时只能有一种流量阈值有效,以最后一次配置的阈值类型为准,例如,先配置报文数阈值再配置字节数阈值,则当前有效的阈值是字节数阈值,只会输出达到字节数阈值的会话日志。
开启会话日志功能后,若开启了新建会话日志功能和删除会话日志功能,则在会话表创建和删除时分别输出一次会话日志;否则在会话表创建和删除时不会输出会话日志。
需要注意的是:会话日志功能和Flow日志功能的相关配置必须同时配置后才能生成会话日志信息。有关Flow日志模块的相关配置请参见“网络管理和监控配置指导”中的“Flow日志”。
表1-8 配置会话日志功能
操作 |
命令 |
说明 |
进入系统视图 |
system-view |
- |
(可选)配置输出会话日志的时间阈值 |
session log time-active time-value |
缺省情况下,未配置输出会话日志的时间阈值 |
(可选)配置输出会话日志的流量阈值 |
session log { bytes-active bytes-value | packets-active packets-value } |
缺省情况下,未配置输出会话日志的流量阈值 |
(可选)开启新建会话日志功能 |
session log flow-begin |
缺省情况下,新建会话日志功能处于关闭状态 |
(可选)开启删除会话日志功能 |
session log flow-end |
缺省情况下,删除会话日志功能处于关闭状态 |
进入接口视图 |
interface interface-type interface-number |
- |
开启会话日志功能 |
session log enable { ipv4 | ipv6 } [ acl acl-number ] { inbound | outbound } |
缺省情况下,会话日志功能处于关闭状态 |
session log time-active、session log { bytes-active | packets-active }、session log flow-begin和session log flow-end以上命令至少选其一。
在完成上述配置后,在任意视图下执行display命令可以显示配置后会话的运行情况,通过查看显示信息验证配置的效果。
在用户视图下执行reset命令可以清除会话统计信息。
表1-9 会话管理显示和维护
操作 |
命令 |
显示应用层协议的会话老化时间 |
display session aging-time application |
显示各协议状态的会话老化时间 |
display session aging-time state |
显示IPv4单播会话表信息 |
display session table ipv4 [ slot slot-number ] [ [ responder ] {source-ip start-source-ip [ end-source-ip ] | destination-ip start-destination-ip [ end-destination-ip ] | protocol { dccp | icmp | raw-ip | sctp | tcp | udp | udp-lite } | source-port source-port | destination-port destination-port | vpn-instance vpn-name }* ] [ verbose ] |
显示IPv6单播会话表信息 |
display session table ipv6 [ slot slot-number ] [ source-ip start-source-ip [ end-source-ip ] ] [ destination-ip start-destination-ip [ end-destination-ip ] ] [ protocol { dccp | icmpv6 | raw-ip | sctp | tcp | udp | udp-lite } ] [ source-port source-port ] [ destination-port destination-port ] [ vpn-instance vpn-name ] [ verbose ] |
根据五元组显示IPv4单播会话统计信息 |
display session statistics ipv4 { source-ip source-ip | destination-ip destination-ip | protocol { dccp | dns | ftp | gtp | h323 I http | icmp | ils | mgcp | nbt | pptp | raw-ip | rsh | rtsp | sccp | sctp | sip | smtp | sqlnet | ssh | tcp | telnet | tftp | udp | udp-lite | xdmcp } | source-port source-port | destination-port destination-port } * [ slot slot-number ] |
根据五元组显示IPv6单播会话统计信息 |
display session statistics ipv6 { source-ip source-ip | destination-ip destination-ip | protocol { dccp | dns | ftp | gtp | h323 I http | icmpv6 | ils | mgcp | nbt | pptp | raw-ip | rsh | rtsp | sccp | sctp | sip | smtp | sqlnet | ssh | tcp | telnet | tftp | udp | udp-lite | xdmcp } | source-port source-port | destination-port destination-port } * [ slot slot-number ] |
显示单播会话统计信息 |
display session statistics [ summary ] [ slot slot-number ] |
显示IPv4组播会话表信息 |
display session table multicast ipv4 [ slot slot-number ] [ source-ip start-source-ip [ end-source-ip ] ] [ destination-ip start-destination-ip [ end-destination-ip ] ] [ protocol { dccp | icmp | raw-ip | sctp | tcp | udp | udp-lite } ] [ source-port source-port ] [ destination-port destination-port ] [ verbose ] |
显示IPv6组播会话表信息 |
display session table multicast ipv6 [ slot slot-number ] [ source-ip start-source-ip [ end-source-ip ] ] [ destination-ip start-destination-ip [ end-destination-ip ] ] [ protocol { dccp | icmpv6 | raw-ip | sctp | tcp | udp | udp-lite } ] [ source-port source-port ] [ destination-port destination-port ] [ verbose ] |
显示组播会话统计信息 |
display session statistics multicast [ slot slot-number ] |
显示关联表信息 |
display session relation-table { ipv4 | ipv6 } [ slot slot-number ] |
显示会话数目的Top 10排名统计信息 |
display session top-statistics { last-1-hour | last-24-hours | last-30-days } |
删除IPv4单播会话表项 |
reset session table ipv4 [ slot slot-number ] [ source-ip source-ip ] [ destination-ip destination-ip ] [ protocol { dccp | icmp | raw-ip | sctp | tcp | udp | udp-lite } ] [ source-port source-port ] [ destination-port destination-port ] [ vpn-instance vpn-instance-name ] |
删除IPv6单播会话表项 |
reset session table ipv6 [ slot slot-number ] [ source-ip source-ip ] [ destination-ip destination-ip ] [ protocol { dccp | icmpv6 | raw-ip | sctp | tcp | udp | udp-lite } ] [ source-port source-port ] [ destination-port destination-port ] [ vpn-instance vpn-instance-name ] |
删除所有单播会话项 |
reset session table [ slot slot-number ] |
清除单播会话统计信息 |
reset session statistics [ slot slot-number ] |
删除IPv4组播会话表项 |
reset session table multicast ipv4 [ slot slot-number ] [ source-ip source-ip ] [ destination-ip destination-ip ] [ protocol { dccp | icmp | raw-ip | sctp | tcp | udp | udp-lite } ] [ source-port source-port ] [ destination-port destination-port ] [ vpn-instance vpn-instance-name ] |
删除IPv6组播会话表项 |
reset session table multicast ipv6 [ slot slot-number ] [ source-ip source-ip ] [ destination-ip destination-ip ] [ protocol { dccp | icmpv6 | raw-ip | sctp | tcp | udp | udp-lite } ] [ source-port source-port ] [ destination-port destination-port ] [ vpn-instance vpn-instance-name ] |
删除所有组播会话项 |
reset session table multicast [ slot slot-number ] |
清除组播会话统计信息 |
reset session statistics multicast [ slot slot-number ] |
删除关联表项 |
reset session relation-table [ ipv4 | ipv6 ] [ slot slot-number ] |
不同款型规格的资料略有差异, 详细信息请向具体销售和400咨询。H3C保留在没有任何通知或提示的情况下对资料内容进行修改的权利!