我的Linux服务器iptables防火墙规则Shell脚本

  1. #!/bin/bash
  2. IPT="/sbin/iptables"
  3. SPAMLIST="blockedip"
  4. SPAMDROPMSG="BLOCKED IP DROP"
  5. echo "Starting IPv4 Wall..."
  6. $IPT -F
  7. $IPT -X
  8. $IPT -t nat -F
  9. $IPT -t nat -X
  10. $IPT -t mangle -F
  11. $IPT -t mangle -X
  12. modprobe ip_conntrack
  13. [ -f /root/scripts/blocked.ips.txt ] && BADIPS=$(egrep -v -E "^#|^$" /root/scripts/blocked.ips.txt)
  14. PUB_IF="eth0"
  15. #unlimited
  16. $IPT -A INPUT -i lo -j ACCEPT
  17. $IPT -A OUTPUT -o lo -j ACCEPT
  18. # DROP all incomming traffic
  19. $IPT -P INPUT DROP
  20. $IPT -P OUTPUT DROP
  21. $IPT -P FORWARD DROP
  22. if [ -f /root/scripts/blocked.ips.txt ];
  23. then
  24. # create a new iptables list
  25. $IPT -N $SPAMLIST
  26. for ipblock in $BADIPS
  27. do
  28.  $IPT -A $SPAMLIST -s $ipblock -j LOG --log-prefix "$SPAMDROPMSG"
  29.  $IPT -A $SPAMLIST -s $ipblock -j DROP
  30. done
  31. $IPT -I INPUT -j $SPAMLIST
  32. $IPT -I OUTPUT -j $SPAMLIST
  33. $IPT -I FORWARD -j $SPAMLIST
  34. fi
  35. # Block sync
  36. $IPT -A INPUT -i ${PUB_IF} -p tcp ! --syn -m state --state NEW -m limit --limit 5/m --limit-burst 7 -j LOG --log-level 4 --log-prefix "Drop Sync"
  37. $IPT -A INPUT -i ${PUB_IF} -p tcp ! --syn -m state --state NEW -j DROP
  38. # Block Fragments
  39. $IPT -A INPUT -i ${PUB_IF} -f -m limit --limit 5/m --limit-burst 7 -j LOG --log-level 4 --log-prefix "Fragments Packets"
  40. $IPT -A INPUT -i ${PUB_IF} -f -j DROP
  41. # Block bad stuff
  42. $IPT -A INPUT -i ${PUB_IF} -p tcp --tcp-flags ALL FIN,URG,PSH -j DROP
  43. $IPT -A INPUT -i ${PUB_IF} -p tcp --tcp-flags ALL ALL -j DROP
  44. $IPT -A INPUT -i ${PUB_IF} -p tcp --tcp-flags ALL NONE -m limit --limit 5/m --limit-burst 7 -j LOG --log-level 4 --log-prefix "NULL Packets"
  45. $IPT -A INPUT -i ${PUB_IF} -p tcp --tcp-flags ALL NONE -j DROP # NULL packets
  46. $IPT -A INPUT -i ${PUB_IF} -p tcp --tcp-flags SYN,RST SYN,RST -j DROP
  47. $IPT -A INPUT -i ${PUB_IF} -p tcp --tcp-flags SYN,FIN SYN,FIN -m limit --limit 5/m --limit-burst 7 -j LOG --log-level 4 --log-prefix "XMAS Packets"
  48. $IPT -A INPUT -i ${PUB_IF} -p tcp --tcp-flags SYN,FIN SYN,FIN -j DROP #XMAS
  49. $IPT -A INPUT -i ${PUB_IF} -p tcp --tcp-flags FIN,ACK FIN -m limit --limit 5/m --limit-burst 7 -j LOG --log-level 4 --log-prefix "Fin Packets Scan"
  50. $IPT -A INPUT -i ${PUB_IF} -p tcp --tcp-flags FIN,ACK FIN -j DROP # FIN packet scans
  51. $IPT -A INPUT -i ${PUB_IF} -p tcp --tcp-flags ALL SYN,RST,ACK,FIN,URG -j DROP
  52. # Allow full outgoing connection but no incomming stuff
  53. $IPT -A INPUT -i eth0 -m state --state ESTABLISHED,RELATED -j ACCEPT
  54. $IPT -A OUTPUT -o eth0 -m state --state NEW,ESTABLISHED,RELATED -j ACCEPT
  55. # Allow ssh
  56. $IPT -A INPUT -p tcp --destination-port 22 -j ACCEPT
  57. # allow incomming ICMP ping pong stuff
  58. $IPT -A INPUT -p icmp --icmp-type 8 -m state --state NEW,ESTABLISHED,RELATED -j ACCEPT
  59. $IPT -A OUTPUT -p icmp --icmp-type 0 -m state --state ESTABLISHED,RELATED -j ACCEPT
  60. # Allow port 53 tcp/udp (DNS Server)
  61. $IPT -A INPUT -p udp --dport 53 -m state --state NEW,ESTABLISHED,RELATED -j ACCEPT
  62. $IPT -A OUTPUT -p udp --sport 53 -m state --state ESTABLISHED,RELATED -j ACCEPT
  63. $IPT -A INPUT -p tcp --destination-port 53 -m state --state NEW,ESTABLISHED,RELATED -j ACCEPT
  64. $IPT -A OUTPUT -p tcp --sport 53 -m state --state ESTABLISHED,RELATED -j ACCEPT
  65. # Open port 80
  66. $IPT -A INPUT -p tcp --destination-port 80 -j ACCEPT
  67. ##### Add your rules below ######
  68. ##### END your rules ############
  69. # Do not log smb/windows sharing packets - too much logging
  70. $IPT -A INPUT -p tcp -i eth0 --dport 137:139 -j REJECT
  71. $IPT -A INPUT -p udp -i eth0 --dport 137:139 -j REJECT
  72. # log everything else and drop
  73. $IPT -A INPUT -j LOG
  74. $IPT -A FORWARD -j LOG
  75. $IPT -A INPUT -j DROP
  76. exit 0
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值