分类: 系统运维
2008-05-21 08:31:08
二、使用规则
用time-range 命令来指定时间范围的名称,然后用absolute命令或者一个或者多个 periodic命令来具体定义时间范围,IOS命令格式为:
time-range time-range-name absolute [start time date] [end time date] periodic days-of-the week hh:mm to [days-of-the week] hh:mm
我们分别来介绍一下每个命令和参数的详细情况:
time-range: 用来定义时间范围的命令
time-range-name: 时间范围名称,用来标识时间范围,以便于在后面的访问列表中引
absolute: 该命令用来指定绝对时间范围。它后面紧跟这start和 end两个关键字。 在这两个关键字后面的时间要以24小时制、hh:mm(小时:分钟)表示, 日期要按照日/月/年来表示。可以看到,他们两个可以都省略。 如果省略start及其后面的时间,那表示与之相联系的permit 或deny语句立即生效, 并一直作用到end处的时间为止;若省略如果省略end及其后面的时间, 那表示与之相联系的permit 或deny语句在start处表示的时间开始生效, 并且永远发生作用,当然把访问列表删除了的话就不会起作用了。
上面讲的就是命令和基本参数为了便于理解,下面我们来看两个例子。
如果要表示每天的早8点到晚8点就可以用这样的语句:
absolute start 8:00 end 20:00
再如,我们要使一个访问列表从2000年12月1日早5点开始起作用,直到2000年12月31日晚24点停止作用,语句如下
absolute start 5:00 1 December 2000 end 24:00 31 December 2000
这样一来,我们就可以用这种基于时间的访问列表来实现,而不用半夜跑到办公室去删除那个访问列表了, 这对于网络管理员来说应该是件好事吧。接下来,让我们看下一个periodic命令及其参数。 一个时间范围只能有一个absolute语句,但是可以有几个periodic语句。 :
periodic:主要是以星期为参数来定义时间范围的一个命令。它的参数主要有Monday、Tuesday、
Wednesday、Thursday、Friday、Saturday、Sunday中的一个或者几个的组合,
也可以是daily(每天)、weekday(周一到周五)或者weekend(周末)。
我们还是来看几个具体的例子。比如表示每周一到周五的早9点到晚10点半,就可以用:
periodic weekday 9:00 to 22:30
每周一早7点到周二的晚8点就可以用:
periodic Monday to Tuesday 20:00
好了,我们已经把这个时间范围如何定义弄清楚了,下面让我们看看如何在实际情况下应用这种基于时间的访问列表。
三、应用实例
例1:在如上图所示的网络中,路由器有两个以太网接口E0和E1, 分别连接着202.111.170.0和202.222.100.0两个子网络, 其中202.111.170.50和202.222.100.100分别是WEB服务器1和WEB服务器2。还有一个串口S1, 连入Internet。为了让202.111.170.0子网公司员工在工作时间不能进行WEB浏览, 从2000年12月1日1点到2000年12月31日晚24点这一个月中, 只有在周六早7点到周日晚10点才可以通过公司的网络访问Internet。 我们做如下的基于时间的访问控制列表来实现这样的功能:
Router# config t
Router(config)# interface ethernet 0
Router(config-if)#ip access-group 101 in
Router(config-if)#time-range http
Router(config-if)#absolute start 1:00 1 December 2000 end 24:00 31
December 2000 periodic Saturday 7:00 to Sunday 22:00
Router(config-if)#ip access-list 101 permit tcp any any eq 80 http
我们是在一个扩展访问列表的基础上再加上时间控制就达到了目的。因为是要控制WEB访问的协议, 所以必须要用扩展列表,也就是说,编号要在100-199之间。这些关于访问列表的基础知识, 请参考其他关于Cisco或者CCNA的基础文档。我们定义了这个时间范围名称是http,这样, 我们就在列表中的最后一句方便的引用了。有了以上的详细讲解,这个很好看懂了。我们再看下面一个例子。
例2:网络结构同上例,现在假设我们的访问要求变了,服务器WEB2(IP:202.222.100.100) 上放着的是新年贺岁版的公司主页,我们希望在2001年12月31日24:00点前, Internet的用户访问的是服务器WEB1(IP:202.111.170.50)上的主页内容,而不能访问WEB2上的内容。 在此之后的新年里,访问的是新年版主页而不能访问旧版本的主页。那么, 我们利用带有时间控制的访问列表来自动实现这个功能,而再也不用让网管员在新年半夜时手动删除了。列表内容如下:
Router# config t
Router(config)#interface serial 0
Router(config-if)#ip access-group web in
Router(config-if)#
time-range changewebabsolute end 24:00 31 December 2000
Router(config-if)#ip access-list extended web
permit tcp any host 202.111.170.50 eq 80 changeweb
deny tcp any host 202.222.100.100 eq 80 changeweb
permit tcp any host 202.222.100.100 eq 80
现在让我们分析一下这个访问控制列表。第一句是进入端口控制模式。第二句是应用名称访问列表web, 并且是用在Serial 0的入口方向,就是数据流入路由器的时候做协议控制分析。第三句, 定义一个时间范围名称是changeweb。第四句是定义扩展名称访问列表web。第五、六句是表示在新年前, 只能允许访问WEB1。第七句是允许所有到WEB2的web访问。 这样第七句不是在没有时间限制的情况下全部允许了WEB2的访问吗?那我们的目的是如何实现的呢?不要忘记, 路由器中访问控制列表的每个表项的顺序是很重要的,它是从上到下执行的,这样,在新年之前, 也就是第五、六句起左右的时候,访问WEB2的要求已经被禁止了,所以,第七句就没有用了,而在新年之后呢,, 第五、六句失效了,第七句才发挥它的作用。允许所有对WEB2的访问请求,那么,新年之后,还能访问WEB1服务器吗? 当然不能,因为我们第七句只允许访问WEB2,隐含的意思就是,其余的全部禁止。
好了,看到这儿,你不是觉的你的想法都被CISCO路由器实现了?合理有效的利用基于时间的访问控制列表, 可以更有效、更安全、更方便的保护我们的内部网络。这样你的网络才会更安全,网络管理员也会更轻松!