22期第十四周课堂练习

系统的INPUT和OUTPUT默认策略为DROP;

[root@localhost ~]# iptables -P INPUT DROP
[root@localhost ~]# iptables -P OUTPUT DROP

1、限制本地主机的web服务器在周一不允许访问;新请求的速率不能超过100个每秒;web服务器包含了admin字符串的页面不允许访问;web服务器仅允许响应报文离开本机;

 [root@localhost ~]# iptables -A OUTPUT -p tcp  -m state --state ESTABLISHED -j ACCEPT
 [root@localhost ~]# iptables -A INPUT -d 192.168.180.130 -p tcp --dport 80 -m time ! 
 --weekdays 1 -m limit --limit 100/second  -j ACCEPT
 [root@localhost ~]# iptables -I OUTPUT -s 192.168.180.130 -p tcp --sport 80 -m string 
 --algo bm --string "admin" -j REJECT

2、在工作时间,即周一到周五的8:30-18:00,开放本机的ftp服务给172.16.0.0网络中的主机访问;数据下载请求的次数每分钟不得超过5个;

[root@localhost /]# modprobe  nf_conntrack_ftp
[root@localhost /]# lsmod |grep ftp
nf_conntrack_ftp       12913  0 
nf_conntrack           79758  4 nf_conntrack_ftp,nf_conntrack_ipv4,nf_conntrack_ipv6,xt_state
[root@localhost /]# iptables -I  INPUT 1 -p tcp -s 172.16.0.0/16 -d 192.168.180.130  --dport 21 
-m time --timestart 8:30 --timestop 18:00 --weekdays 1,2,3,4,5 -m limit --limit  5/minute -m state 
--state NEW,ESTABLISHED -j ACCEPT
[root@localhost /]# iptables -I 2 INPUT  -d 192.168.180.130 -p tcp  -m state --state RELATE,ESTABLISHED 
-j ACCEPT
[root@localhost ~]# iptables -A OUTPUT -p tcp  -m state --state ESTABLISHED -j ACCEPT

3、开放本机的ssh服务给172.16.x.1-172.16.x.100中的主机,x为你的座位号,新请求建立的速率一分钟不得超过2个;仅允许响应报文通过其服务端口离开本机;

[root@localhost /]# iptables -A INPUT -p tcp -d 192.168.180.130 --dport 22 -m iprange --src-range 
172.16.4.1-172.16.4.100 -m limit --limit 2/m -j ACCEPT
[root@localhost /]# iptables -A OUTPUT -s 192.168.180.130  -p tcp --sport 22 -m state --state ESTABLISHED 
-j ACCEPT

4、拒绝TCP标志位全部为1及全部为0的报文访问本机;

[root@localhost /]# iptables -A INPUT -d 192.168.180.130 -p tcp --tcp-flags ALL ALL -j DROP
[root@localhost /]# iptables -A INPUT -d 192.168.180.130 -p tcp --tcp-flags ALL NONE -j DROP

5、允许本机ping别的主机;但不开放别的主机ping本机;

[root@localhost /]# iptables -A INPUT -d 192.168.180.130 -p icmp --icmp-type 0 -j ACCEPT
[root@localhost /]# iptables -A OUTPUT -s 192.168.180.130 -p icmp --icmp-type 8 -j ACCEPT

6、判断下述规则的意义:

  # iptables -N clean_in //创建自定义表

  # iptables -A clean_in -d 255.255.255.255 -p icmp -j DROP //拒绝所有的广播的icmp报文

  # iptables -A clean_in -d 172.16.255.255 -p icmp -j DROP  //拒绝到172.16.网段的广播icmp报文

  # iptables -A clean_in -p tcp ! –syn -m state –state NEW -j DROP  //拒绝第一次握手tcp状态不是new的连接

  # iptables -A clean_in -p tcp –tcp-flags ALL ALL -j DROP  //拒绝TCP标志位全部为1的连接

  # iptables -A clean_in -p tcp –tcp-flags ALL NONE -j DROP //拒绝TCP标志位全部为0的连接

  # iptables -A clean_in -d 172.16.100.7 -j RETURN  //目标是172.16.100.7的连接返回到clean_in链

  # iptables -A INPUT -d 172.16.100.7 -j clean_in  

  # iptables -A INPUT  -i lo -j ACCEPT //允许lo网口的连接进入

  # iptables -A OUTPUT -o lo -j ACCEPT  //允许lo网口的连接出去

  # iptables -A INPUT  -i eth0 -m multiport -p tcp –dports 53,113,135,137,139,445 -j DROP //拒绝从eth0网口访问端口53,113,135,147,139,445的邮件相关服务进入的tcp连接

  # iptables -A INPUT  -i eth0 -m multiport -p udp –dports 53,113,135,137,139,445 -j DROP //拒绝从eth0网口访问端口53,113,135,147,139,445的邮件相关服务进入的udp连接

  # iptables -A INPUT  -i eth0 -p udp –dport 1026 -j DROP //拒绝从eth0网卡协议是udp的106端口进入

  # iptables -A INPUT  -i eth0 -m multiport -p tcp –dports 1433,4899 -j DROP //拒绝从eth0网卡的tcp的1433,4899的端口进入 

  # iptables -A INPUT  -p icmp -m limit –limit 10/second -j ACCEPT //允许ping进入并且限制每秒请求速率为10

7、通过tcp_wrapper控制vsftpd仅允许172.16.0.0/255.255.0.0网络中的主机访问,但172.16.100.3除外;对所被被拒绝的访问尝试都记录在/var/log/tcp_wrapper.log日志文件中;

[root@localhost ~]# vim /etc/hosts.allow 
vsftpd:172.16. EXCEPT 172.16.100.3
[root@localhost ~]# vim /etc/hosts.deny
vsftpd: ALL :spawn /bin/echo $(date) login attempt from %c to %s, %d >> /var/log/tcp_wrapper.log

原创文章,作者:a295053193,如若转载,请注明出处:http://www.178linux.com/66182

(0)
a295053193a295053193
上一篇 2017-03-15
下一篇 2017-03-15

相关推荐

  • grep简述

    grep(Globel Search Regular Expression and Printing out the line) 它能使用正则表达式搜索文本,并把匹配的行打印出来。 grep包括grep、egrep和fgrep。 egrep表示扩展的grep,相比grep支持更多的匹配模式, “grep -E”相当于egrep。 fgrep是fast gre…

    2017-04-06
  • bash功能特性五 重定向和管道

    一、管道     使用“|”符号来实现管道功能;管道可以实现在一行中处理使用管道符号连接的多个命令,后面的命令使用前面命令的输出结果做为处理对象。 二、数据流重定向     数据输入和输出的类型:         标准输入(std…

    Linux干货 2015-04-21
  • 马哥教育网络班21期第1周课程练习 — 草稿

    1、描述计算机的组成及其功能。     计算机的主要组成部分包括:运算器、控制器、存储器、输入设备、输出设备。        按更常见的组件来讲:CPU = 运算器+控制器、 内存+硬盘 = 存储器、 I/O = 输入设备+输出设备  &n…

    Linux干货 2016-07-07
  • gzip压缩输出

    一、gzip介绍          gzip是GNU zip的缩写,它是一个GNU自由软件的文件压缩程序,也经常用来表示gzip这种文件格式。软件的作者是Jean-loup Gailly和Mark Adler。1992年10月31日第一次公开发布,版本号是0.1,目前的稳定版本是…

    Linux干货 2015-07-29
  • Linux系统网络属性管理

        每台计算机主机连入internet都必须给主机设定以个合法的IP地址。这些IP参数大概包括IP地址、子网掩码、网关、路由、DNS等。在Linux中,大多数命令配置网络配置都是临时生效,想要网络服务永久有效就必须写入配置文件中,所以有时候更改配置重启主机是为了让内核重读配置文件到内核中,因为配置文件属于用户空间的文件。大多数网络配置…

    Linux干货 2016-09-18
  • 关于shell脚本基础第二篇

                          shell脚本编程基础第二篇 read命令 使用read来把输入的值非配给一个或者多个shell变量,可以提示用户输入一些参数等,此时我们可以使用read命令来完成此功能 re…

    系统运维 2016-08-19