51Testing软件测试论坛

 找回密码
 (注-册)加入51Testing

QQ登录

只需一步,快速开始

微信登录,快人一步

手机号码,快捷登录

查看: 1558|回复: 4
打印 上一主题 下一主题

[求助] iptables在linux防火墙

[复制链接]

该用户从未签到

跳转到指定楼层
1#
发表于 2017-11-8 11:14:18 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
请问怎么设置??
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏
回复

使用道具 举报

  • TA的每日心情
    开心
    2024-7-10 10:58
  • 签到天数: 194 天

    连续签到: 1 天

    [LV.7]测试师长

    2#
    发表于 2017-11-8 13:45:42 | 只看该作者
    。。。你这个网上太多了 不过各个发行版有可能会不同
    回复 支持 反对

    使用道具 举报

  • TA的每日心情
    开心
    2018-5-3 18:09
  • 签到天数: 2 天

    连续签到: 1 天

    [LV.1]测试小兵

    3#
    发表于 2017-11-8 13:54:08 | 只看该作者
    1.删除已有规则

    在新设定iptables规则时,我们一般先确保旧规则被清除,用以下命令清除旧规则:

    iptables -F
    (or iptables --flush)


    2.设置chain策略

    对于filter table,默认的chain策略为ACCEPT,我们可以通过以下命令修改chain的策略:

    iptables -P INPUT DROP
    iptables -P FORWARD DROP
    iptables -P OUTPUT DROP
    以上命令配置将接收、转发和发出包均丢弃,施行比较严格的包管理。由于接收和发包均被设置为丢弃,当进一步配置其他规则的时候,需要注意针对INPUT和OUTPUT分别配置。当然,如果信任本机器往外发包,以上第三条规则可不必配置。



    3.屏蔽指定ip

    有时候我们发现某个ip不停的往服务器发包,这时我们可以使用以下命令,将指定ip发来的包丢弃:

    BLOCK_THIS_IP="x.x.x.x"
    iptables -A INPUT -i eth0 -p tcp -s "$BLOCK_THIS_IP" -j DROP
    以上命令设置将由x.x.x.x ip发往eth0网口的tcp包丢弃。



    4.配置服务项

    利用iptables,我们可以对日常用到的服务项进行安全管理,比如设定只能通过指定网段、由指定网口通过SSH连接本机:

    iptables -A INPUT -i eth0 -p tcp -s 192.168.100.0/24 --dport 22 -m state --state NEW,ESTABLESHED -j ACCEPT
    iptables -A OUTPUT -o eth0 -p tcp --sport 22 -m state --state ESTABLISHED -j ACCEPT
    若要支持由本机通过SSH连接其他机器,由于在本机端口建立连接,因而还需要设置以下规则:

    iptables -A INPUT -i eth0 -p tcp -s 192.168.100.0/24 --dport 22 -m state --state ESTABLESHED -j ACCEPT
    iptables -A OUTPUT -o eth0 -p tcp --sport 22 -m state --state NEW,ESTABLISHED -j ACCEPT
    类似的,对于HTTP/HTTPS(80/443)、pop3(110)、rsync(873)、MySQL(3306)等基于tcp连接的服务,也可以参照上述命令配置。



    对于基于udp的dns服务,使用以下命令开启端口服务:

    iptables -A OUTPUT -p udp -o eth0 --dport 53 -j ACCEPT
    iptables -A INPUT -p udp -i eth0 --sport 53 -j ACCEPT


    5.网口转发配置

    对于用作防火墙或网关的服务器,一个网口连接到公网,其他网口的包转发到该网口实现内网向公网通信,假设eth0连接内网,eth1连接公网,配置规则如下:

    iptables -A FORWARD -i eth0 -o eth1 -j ACCEPT


    6.端口转发配置

    对于端口,我们也可以运用iptables完成转发配置:

    iptables -t nat -A PREROUTING -p tcp -d 192.168.102.37 --dport 422 -j DNAT --to 192.168.102.37:22
    以上命令将422端口的包转发到22端口,因而通过422端口也可进行SSH连接,当然对于422端口,我们也需要像以上“4.配置服务项”一节一样,配置其支持连接建立的规则。



    7.DoS攻击防范

    利用扩展模块limit,我们还可以配置iptables规则,实现DoS攻击防范:

    iptables -A INPUT -p tcp --dport 80 -m limit --limit 25/minute --limit-burst 100 -j ACCEPT
    --litmit 25/minute 指示每分钟限制最大连接数为25

    --litmit-burst 100 指示当总连接数超过100时,启动 litmit/minute 限制



    8.配置web流量均衡

    我们可以将一台服务器作为前端服务器,利用iptables进行流量分发,配置方法如下:

    复制代码
    iptables -A PREROUTING -i eth0 -p tcp --dport 80 -m state --state NEW -m nth --counter 0 --every 3 --packet 0 -j DNAT --to-destination 192.168.1.101:80
    iptables -A PREROUTING -i eth0 -p tcp --dport 80 -m state --state NEW -m nth --counter 0 --every 3 --packet 0 -j DNAT --to-destination 192.168.1.102:80
    iptables -A PREROUTING -i eth0 -p tcp --dport 80 -m state --state NEW -m nth --counter 0 --every 3 --packet 0 -j DNAT --to-destination 192.168.1.103:80
    复制代码
    以上配置规则用到nth扩展模块,将80端口的流量均衡到三台服务器。



    9.将丢弃包情况记入日志

    使用LOG目标和syslog服务,我们可以记录某协议某端口下的收发包情况。拿记录丢包情况举例,可以通过以下方式实现。

    首先自定义一个chain:

    iptables -N LOGGING
    其次将所有接收包导入LOGGING chain中:

    iptables -A INPUT -j LOGGING
    然后设置日志前缀、日志级别:

    iptables -A LOGGING -m limit --limit 2/min -j LOG --log-prefix "IPTables Packet Dropped: " --log-level 7
    最后将包倒向DROP,将包丢弃:

    iptables -A LOGGING -j DROP
    另可以配置syslog.conf文件,指定iptables的日志输出。

    评分

    参与人数 1测试积点 +10 收起 理由
    lsekfe + 10 积极回复获得测试积点10 赶快去商城换取奖.

    查看全部评分

    回复 支持 反对

    使用道具 举报

    本版积分规则

    关闭

    站长推荐上一条 /1 下一条

    小黑屋|手机版|Archiver|51Testing软件测试网 ( 沪ICP备05003035号 关于我们

    GMT+8, 2024-11-27 19:49 , Processed in 0.072647 second(s), 24 queries .

    Powered by Discuz! X3.2

    © 2001-2024 Comsenz Inc.

    快速回复 返回顶部 返回列表