close
來源 http://phorum.vbird.org/viewtopic.php?f=2&t=16590
1. 首先 建立一個script, sshd_httpd.sh 在 /usr/local/virus/iptables
代碼:
#!/bin/sh
# 2005/01/15 ver4 by Boolean@HC Email:boolean@xx
# 2009/10/06 ver5 by Boolean Email:boolean@boolean.twbbs.org
#
# 檔案存放的路徑
basedir="/usr/local/virus/iptables"
# log 存放的地方
sshlog="/var/log/secure"
httplog="/var/log/httpd/error_log"
# mail for
mailfor="boolean"
# 登入錯誤訊息
faildMsg="sshd.*Failed password"
faildMsgInvalid="sshd.*Failed password for invalid user"
# 登入幾次失敗 就擋掉
loginCountFail=3
#定義白名單. 現在已從sshd抓到的block名單,目前firewall的抵擋名單
nodenyip="$basedir/wip.txt"
sshd_block="$basedir/sshd_block_ip_now"
httpd_block="$basedir/httpd_block_ip_now"
block_ip="$basedir/block_ip"
tmp_sshd="/tmp/sshd"
tmp_httpd="/tmp/httpd"
denyfile="$basedir/iptables.deny"
#先抓sshd錯誤IP,灌入block名單
cat "$sshlog" | grep "sshd.*Failed password for" | grep -v "invalid" > /tmp/ssh_tmp.log
cat "$sshlog" | grep "sshd.*Failed password for invalid user" > /tmp/ssh_tmp2.log
cat "$httplog" | grep "File does not exist:" > /tmp/httpd_tmp.log
cat /tmp/httpd_tmp.log | cut -d " " -f8 | cut -d "]" -f1 > $tmp_httpd
cat /tmp/ssh_tmp.log | cut -d " " -f11 > $tmp_sshd
cat /tmp/ssh_tmp.log | cut -d " " -f12 >> $tmp_sshd
cat /tmp/ssh_tmp2.log | cut -d " " -f14 >> $tmp_sshd
#順便抓取 secure.1 ,
declare -i lognumber=1
for (( m=1 ; m<=$lognumber ; m=m+1 ));
do
if [ -f "$sshlog.$m" ]; then
cat "$sshlog.$m" | grep "sshd.*Failed password for" | grep -v "invalid" >> /tmp/ssh_tmp.log
cat "$sshlog.$m" | grep "sshd.*Failed password for invalid user" >> /tmp/ssh_tmp2.log
cat /tmp/ssh_tmp.log | cut -d " " -f11 >> $tmp_sshd
cat /tmp/ssh_tmp.log | cut -d " " -f12 >> $tmp_sshd
cat /tmp/ssh_tmp2.log | cut -d " " -f14 >> $tmp_sshd
else
echo "檔案 $sshlog.$m 並不存在 !!!!"
fi
if [ -f "$httplog.$m" ]; then
cat "$httplog.$m" | grep "File does not exist:" >> /tmp/httpd_tmp.log
cat /tmp/httpd_tmp.log | cut -d " " -f8 | cut -d "]" -f1 >> $tmp_httpd
else
echo "檔案 $httplog.$m 並不存在 !!!!"
fi
done
#SSHD section:利用for 迴圈去跑 drop ip , if 失敗次數小於3次
number_sshd=`cat $tmp_sshd | sort | uniq`
for ip in $number_sshd ;
do
# 計算此IP登入幾次失敗
count=`cat $tmp_sshd | grep "$ip" | wc -l`
# 如果登入失敗次數大於 預設值 則執行 drop
if [ "$count" -gt "$loginCountFail" ] ; then
touch "$sshd_block"
echo "$ip" >> "$sshd_block"
fi
done
#HTTPD section:利用for 迴圈去跑 drop ip , if 失敗次數小於3次
number_httpd=`cat $tmp_httpd | sort | uniq`
for ip in $number_httpd ;
do
# 計算此IP登入幾次失敗
count=`cat $tmp_httpd | grep "$ip" | wc -l`
# 如果登入失敗次數大於 預設值 則執行 drop
if [ "$count" -gt "$loginCountFail" ] ; then
touch "$httpd_block"
echo "$ip" >> "$httpd_block"
fi
done
#抓取目前已抵擋名單
if [ -f "$denyfile" ];then
cat $denyfile | cut -d " " -f 7 >> $block_ip
rm -rf $denyfile
else
echo "不存在 $denyfile ,Script會依需要自動建立"
fi
cat $sshd_block | sort | uniq > /tmp/ip
cat $httpd_block | sort | uniq >> /tmp/ip
cat $block_ip | sort | uniq >> /tmp/ip
cat /tmp/ip | sort | uniq > $block_ip
target=`cat $block_ip`
if [ "$target" = "" ]; then
echo "目前沒有添加需要被阻擋IP的需要"
else
for i in $target ;
do
target1=`cat $nodenyip | grep $i`
if [ "$target1" = "" ]; then
if [ -f "$denyfile" ]; then
echo "/sbin/iptables -A INPUT -i "'$EXTIF'" -s $i -j DROP #auto" >> $denyfile
else
echo "/sbin/iptables -A INPUT -i "'$EXTIF'" -s $i -j DROP #auto" > $denyfile
fi
echo "<<添加>>IP: $i Add to $denyfile"
else
echo "<<去除>>According to the $nodenyip ,drop the IP: $i"
fi
done
fi
cat $denyfile | sort | uniq > $denyfile
rm -rf $tmp_sshd
rm -rf $tmp_httpd
rm -rf /tmp/ssh*
rm -rf /tmp/http*
./iptables.rule
2.接下來,就是Copy鳥哥的scripts, 去建立 iptables.rule 在 /usr/local/virus/iptables
代碼:
# 2005/01/15 ver4 by Boolean@HC Email:boolean@xx
# 2009/10/06 ver5 by Boolean Email:boolean@boolean.twbbs.org
#
# 檔案存放的路徑
basedir="/usr/local/virus/iptables"
# log 存放的地方
sshlog="/var/log/secure"
httplog="/var/log/httpd/error_log"
# mail for
mailfor="boolean"
# 登入錯誤訊息
faildMsg="sshd.*Failed password"
faildMsgInvalid="sshd.*Failed password for invalid user"
# 登入幾次失敗 就擋掉
loginCountFail=3
#定義白名單. 現在已從sshd抓到的block名單,目前firewall的抵擋名單
nodenyip="$basedir/wip.txt"
sshd_block="$basedir/sshd_block_ip_now"
httpd_block="$basedir/httpd_block_ip_now"
block_ip="$basedir/block_ip"
tmp_sshd="/tmp/sshd"
tmp_httpd="/tmp/httpd"
denyfile="$basedir/iptables.deny"
#先抓sshd錯誤IP,灌入block名單
cat "$sshlog" | grep "sshd.*Failed password for" | grep -v "invalid" > /tmp/ssh_tmp.log
cat "$sshlog" | grep "sshd.*Failed password for invalid user" > /tmp/ssh_tmp2.log
cat "$httplog" | grep "File does not exist:" > /tmp/httpd_tmp.log
cat /tmp/httpd_tmp.log | cut -d " " -f8 | cut -d "]" -f1 > $tmp_httpd
cat /tmp/ssh_tmp.log | cut -d " " -f11 > $tmp_sshd
cat /tmp/ssh_tmp.log | cut -d " " -f12 >> $tmp_sshd
cat /tmp/ssh_tmp2.log | cut -d " " -f14 >> $tmp_sshd
#順便抓取 secure.1 ,
declare -i lognumber=1
for (( m=1 ; m<=$lognumber ; m=m+1 ));
do
if [ -f "$sshlog.$m" ]; then
cat "$sshlog.$m" | grep "sshd.*Failed password for" | grep -v "invalid" >> /tmp/ssh_tmp.log
cat "$sshlog.$m" | grep "sshd.*Failed password for invalid user" >> /tmp/ssh_tmp2.log
cat /tmp/ssh_tmp.log | cut -d " " -f11 >> $tmp_sshd
cat /tmp/ssh_tmp.log | cut -d " " -f12 >> $tmp_sshd
cat /tmp/ssh_tmp2.log | cut -d " " -f14 >> $tmp_sshd
else
echo "檔案 $sshlog.$m 並不存在 !!!!"
fi
if [ -f "$httplog.$m" ]; then
cat "$httplog.$m" | grep "File does not exist:" >> /tmp/httpd_tmp.log
cat /tmp/httpd_tmp.log | cut -d " " -f8 | cut -d "]" -f1 >> $tmp_httpd
else
echo "檔案 $httplog.$m 並不存在 !!!!"
fi
done
#SSHD section:利用for 迴圈去跑 drop ip , if 失敗次數小於3次
number_sshd=`cat $tmp_sshd | sort | uniq`
for ip in $number_sshd ;
do
# 計算此IP登入幾次失敗
count=`cat $tmp_sshd | grep "$ip" | wc -l`
# 如果登入失敗次數大於 預設值 則執行 drop
if [ "$count" -gt "$loginCountFail" ] ; then
touch "$sshd_block"
echo "$ip" >> "$sshd_block"
fi
done
#HTTPD section:利用for 迴圈去跑 drop ip , if 失敗次數小於3次
number_httpd=`cat $tmp_httpd | sort | uniq`
for ip in $number_httpd ;
do
# 計算此IP登入幾次失敗
count=`cat $tmp_httpd | grep "$ip" | wc -l`
# 如果登入失敗次數大於 預設值 則執行 drop
if [ "$count" -gt "$loginCountFail" ] ; then
touch "$httpd_block"
echo "$ip" >> "$httpd_block"
fi
done
#抓取目前已抵擋名單
if [ -f "$denyfile" ];then
cat $denyfile | cut -d " " -f 7 >> $block_ip
rm -rf $denyfile
else
echo "不存在 $denyfile ,Script會依需要自動建立"
fi
cat $sshd_block | sort | uniq > /tmp/ip
cat $httpd_block | sort | uniq >> /tmp/ip
cat $block_ip | sort | uniq >> /tmp/ip
cat /tmp/ip | sort | uniq > $block_ip
target=`cat $block_ip`
if [ "$target" = "" ]; then
echo "目前沒有添加需要被阻擋IP的需要"
else
for i in $target ;
do
target1=`cat $nodenyip | grep $i`
if [ "$target1" = "" ]; then
if [ -f "$denyfile" ]; then
echo "/sbin/iptables -A INPUT -i "'$EXTIF'" -s $i -j DROP #auto" >> $denyfile
else
echo "/sbin/iptables -A INPUT -i "'$EXTIF'" -s $i -j DROP #auto" > $denyfile
fi
echo "<<添加>>IP: $i Add to $denyfile"
else
echo "<<去除>>According to the $nodenyip ,drop the IP: $i"
fi
done
fi
cat $denyfile | sort | uniq > $denyfile
rm -rf $tmp_sshd
rm -rf $tmp_httpd
rm -rf /tmp/ssh*
rm -rf /tmp/http*
./iptables.rule
2.接下來,就是Copy鳥哥的scripts, 去建立 iptables.rule 在 /usr/local/virus/iptables
代碼:
#!/bin/bash
#
# ========================================================
# 程式說明:
# 歡迎使用 iptables.rule 這個 script 來建立您的防火牆!
# 這支 script 還需要您的額外設定方可適合您的主機環境!
# 基本規則定義為『拒絕所有,開放特定』的模式!
#
# 強烈建議:
# 不了解 Linux 防火牆機制 iptables 的朋友使用這支 script
# 可能會不太瞭解每個指令列的意義,果真如此的話,
# 歡迎參考底下幾個網頁:
# http://www.study-area.org/linux/servers/linux_nat.htm
# http://linux.vbird.org/linux_server/0240network-secure-1.php
# http://linux.vbird.org/linux_server/0250simple_firewall.php
#
# 使用說明:
# 確定這個程式僅有 Linux 的斷行字元:
# dos2unix iptables.rule
# 請先將這個 scripts 的權限更改為可執行:
# chmod 755 iptables.rule
# 在將這個程式放置在 /usr/local/virus/iptables 目錄下:
# mkdir -p /usr/local/virus/iptables
# mv /完整的路徑/iptables.rule /usr/local/virus/iptables
# 執行測試:
# /usr/local/virus/iptables/iptables.rule
# iptables -L -n (這個動作在檢查防火牆規則)
# 將底下這一行加入 /etc/rc.d/rc.local 當中
# /usr/local/virus/iptables/iptables.rule
# 取消防火牆:
# iptables -F
# iptables -X
# iptables -t nat -F
# iptables -t nat -X
#
# ========================================================
# 版權宣告:
# 這支程式為 GPL 授權,任何人皆可使用,
# 然,若使用本 scripts 發生問題時,本人不負任何責任
# VBird <vbird@mail.vbird.idv.tw>
# ========================================================
#
# 歷史紀錄:
# 2002/08/20 VBird 首次釋出
# 2003/04/26 VBird 加入砍站軟體的相關執行檔案!
# 2003/08/25 VBird 修改 INPUT 的 Policy 成為 DROP
# 2006/09/13 VBird 重新修訂,加入一些核心參數 /proc/sys/net/ipv4/*
# 2006/09/15 VBird 加入關於 NAT 主機後端伺服器的轉址功能。
# 2006/09/30 VBird 加入每個設定項目的英文說明!!
# 2006/11/08 VBird 參考朋友們發現的 PPPoE 導致 MTU 的問題,增加一條規則!在 NAT 的部分。
#
###########################################################################################
# 請先輸入您的相關參數,不要輸入錯誤了!
# English: Please input your networks parameters ( including your LAN NIC )
EXTIF="eth0" # 這個是可以連上 Public IP 的網路介面,也可能是 ppp0
# This is your NIC, connect to internet. Such as ppp0...
INIF="" # 內部 LAN 的連接介面;若無 LAN ,填寫成 INIF=""
# This is your LAN NIC. If you don't have a LAN, input INIF="" please.
INNET="192.168.1.0/24" # 若有兩個以上的網域,可以用 INNET="192.168.1.0/24 192.168.100.0/24"
# 若無內部網域介面,請填寫成 INNET=""
# This is your LAN's Network. If you have to private network,
# input as INNET="192.168.1.0/24 192.168.100.0/24".
export EXTIF INIF INNET
# 個人化設定啊!請自行填寫您自己想要預先啟動的一些基礎資料。
# These settings is about yourself's paramters.
allowname='no.bbs.org' # 允許登入本機的 hostname ,必須是 Internet 找的到的 hostname。
allowip=""
if [ "$allowname" != "" ]; then
for siteiptmp in `echo $allowname`
do
siteip=`/usr/bin/host $siteiptmp 168.95.1.1 | grep address|tail -n 1 | awk '{print $4}'`
testip=`echo $siteip | grep [^0-9.]`
if [ "$testip" == "" ]; then
allowip="$allowip $siteip"
fi
done
fi
export allowip
# 第一部份,針對本機的防火牆設定!#########################################################
# First, your server's firewall settings.
# 1. 先設定好核心的網路功能:
# 1. the kernel's firewall settings.
# 開啟 TCP Flooding 的 DoS 攻擊抵擋機制,但這個設定不適合 loading 已經很高的主機!!!
# TCP Flooding's setting. this setting is no good for high loading servers
echo "1" > /proc/sys/net/ipv4/tcp_syncookies
# 取消 ping 廣播的回應;
# unset reply of ping.
echo "1" > /proc/sys/net/ipv4/icmp_echo_ignore_broadcasts
# 開啟逆向路徑過濾,以符合 IP 封包與網路介面的設定;
#
for i in /proc/sys/net/ipv4/conf/*/rp_filter; do
echo "1" > $i
done
# 開啟記錄有問題的封包
# record some problems packets.
for i in /proc/sys/net/ipv4/conf/*/log_martians; do
echo "1" > $i
done
# 取消來源路由,這個設定值是可以取消的;
for i in /proc/sys/net/ipv4/conf/*/accept_source_route; do
echo "0" > $i
done
# 取消重新宣告路徑的功能。
for i in /proc/sys/net/ipv4/conf/*/accept_redirects; do
echo "0" > $i
done
# 取消傳送重新宣告路徑的功能。
for i in /proc/sys/net/ipv4/conf/*/send_redirects; do
echo "0" > $i
done
# 2. 清除規則、設定預設政策及開放 lo 與相關的設定值
# 2. clear rule, set the policy rule and allow lo connect.
PATH=/sbin:/usr/sbin:/bin:/usr/bin:/usr/local/sbin:/usr/local/bin; export PATH
iptables -F
iptables -X
iptables -Z
iptables -P INPUT DROP
iptables -P OUTPUT ACCEPT
iptables -P FORWARD ACCEPT
iptables -A INPUT -i lo -j ACCEPT
iptables -A INPUT -m state --state RELATED -j ACCEPT
# 3. 啟動額外的防火牆 script 模組
# 3. other shell scripts, written by VBird.
# 預設抵擋的主機
if [ -f /usr/local/virus/iptables/iptables.deny ]; then
sh /usr/local/virus/iptables/iptables.deny
fi
# 預設開放的主機
if [ -f /usr/local/virus/iptables/iptables.allow ]; then
sh /usr/local/virus/iptables/iptables.allow
fi
# 透過 WWW 砍站軟體分析的抵擋機制
if [ -f /usr/local/virus/httpd-err/iptables.http ]; then
sh /usr/local/virus/httpd-err/iptables.http
fi
iptables -A INPUT -m state --state ESTABLISHED -j ACCEPT
# 4. 允許某些類型的 ICMP 封包進入
# 4. allow some types of ICMP
AICMP="0 3 3/4 4 11 12 14 16 18"
for tyicmp in $AICMP
do
iptables -A INPUT -i $EXTIF -p icmp --icmp-type $tyicmp -j ACCEPT
done
# 5. 允許某些服務的進入
iptables -A INPUT -p TCP -i $EXTIF --dport 22 -j ACCEPT # SSH
iptables -A INPUT -p TCP -i $EXTIF --dport 25 -j ACCEPT # SMTP
# iptables -A INPUT -p UDP -i $EXTIF --dport 161 -j ACCEPT # SNMP-MRTG
# iptables -A INPUT -p TCP -i $EXTIF --dport 53 -j ACCEPT # DNS
iptables -A INPUT -p TCP -i $EXTIF --dport 80 -j ACCEPT # WWW
# iptables -A INPUT -p TCP -i $EXTIF --dport 110 -j ACCEPT # POP3
iptables -A INPUT -p TCP -i $EXTIF --dport 443 -j ACCEPT # HTTPS
iptables -A INPUT -p TCP -i $EXTIF --dport 3128 -j ACCEPT # Squid
iptables -A INPUT -p TCP -i $EXTIF --dport 5900 -j ACCEPT # VNC
# 第二部份,針對後端主機的防火牆設定!#########################################################
# Second, the NAT settings.
# 1. 先載入一些有用的模組
# 1. loading some good modules of iptables.
modules="ip_tables iptable_nat ip_nat_ftp ip_nat_irc ip_conntrack ip_conntrack_ftp ip_conntrack_irc"
for mod in $modules
do
testmod=`lsmod | grep "^${mod} " | awk '{print $1}'`
if [ "$testmod" == "" ]; then
modprobe $mod
fi
done
# 2. 清除 NAT table 的規則吧!
# 2. clean NAT table's rule
iptables -F -t nat
iptables -X -t nat
iptables -Z -t nat
iptables -t nat -P PREROUTING ACCEPT
iptables -t nat -P POSTROUTING ACCEPT
iptables -t nat -P OUTPUT ACCEPT
# 3. 開放成為路由器,且為 IP 分享器!
# 3. NAT server's settings
if [ "$INIF" != "" ]; then
iptables -A INPUT -i $INIF -j ACCEPT
echo "1" > /proc/sys/net/ipv4/ip_forward
if [ "$INNET" != "" ]; then
for innet in $INNET
do
iptables -t nat -A POSTROUTING -s $innet -o $EXTIF -j MASQUERADE
done
fi
fi
# 如果你的 MSN 一直無法連線,或者是某些網站 OK 某些網站不 OK,可能是 MTU 的問題,
# 那你可以將底下這一行給他取消註解來啟動 MTU 限制範圍
# iptables -A FORWARD -p tcp -m tcp --tcp-flags SYN,RST SYN -m tcpmss --mss 1400:1536 -j TCPMSS --clamp-mss-to-pmtu
# 4. NAT 主機後端的 LAN 內對外之伺服器設定
# iptables -t nat -A PREROUTING -p tcp -i $EXTIF --dport 80 -j DNAT --to 192.168.1.210:80 # WWW
3.可預先建立 wip.txt 白名單在 /usr/local/virus/iptables,免得擋到自己
例如 vi wip.txt
4.建立 iptables.allow 和 iptables.deny (follow 鳥哥的scripts..注意看第二項)
vi iptables.allow
代碼:
vi iptables.deny
5. 寫入 crontab中,定時執行
vi /etc/crontab
代碼:
#
# ========================================================
# 程式說明:
# 歡迎使用 iptables.rule 這個 script 來建立您的防火牆!
# 這支 script 還需要您的額外設定方可適合您的主機環境!
# 基本規則定義為『拒絕所有,開放特定』的模式!
#
# 強烈建議:
# 不了解 Linux 防火牆機制 iptables 的朋友使用這支 script
# 可能會不太瞭解每個指令列的意義,果真如此的話,
# 歡迎參考底下幾個網頁:
# http://www.study-area.org/linux/servers/linux_nat.htm
# http://linux.vbird.org/linux_server/0240network-secure-1.php
# http://linux.vbird.org/linux_server/0250simple_firewall.php
#
# 使用說明:
# 確定這個程式僅有 Linux 的斷行字元:
# dos2unix iptables.rule
# 請先將這個 scripts 的權限更改為可執行:
# chmod 755 iptables.rule
# 在將這個程式放置在 /usr/local/virus/iptables 目錄下:
# mkdir -p /usr/local/virus/iptables
# mv /完整的路徑/iptables.rule /usr/local/virus/iptables
# 執行測試:
# /usr/local/virus/iptables/iptables.rule
# iptables -L -n (這個動作在檢查防火牆規則)
# 將底下這一行加入 /etc/rc.d/rc.local 當中
# /usr/local/virus/iptables/iptables.rule
# 取消防火牆:
# iptables -F
# iptables -X
# iptables -t nat -F
# iptables -t nat -X
#
# ========================================================
# 版權宣告:
# 這支程式為 GPL 授權,任何人皆可使用,
# 然,若使用本 scripts 發生問題時,本人不負任何責任
# VBird <vbird@mail.vbird.idv.tw>
# ========================================================
#
# 歷史紀錄:
# 2002/08/20 VBird 首次釋出
# 2003/04/26 VBird 加入砍站軟體的相關執行檔案!
# 2003/08/25 VBird 修改 INPUT 的 Policy 成為 DROP
# 2006/09/13 VBird 重新修訂,加入一些核心參數 /proc/sys/net/ipv4/*
# 2006/09/15 VBird 加入關於 NAT 主機後端伺服器的轉址功能。
# 2006/09/30 VBird 加入每個設定項目的英文說明!!
# 2006/11/08 VBird 參考朋友們發現的 PPPoE 導致 MTU 的問題,增加一條規則!在 NAT 的部分。
#
###########################################################################################
# 請先輸入您的相關參數,不要輸入錯誤了!
# English: Please input your networks parameters ( including your LAN NIC )
EXTIF="eth0" # 這個是可以連上 Public IP 的網路介面,也可能是 ppp0
# This is your NIC, connect to internet. Such as ppp0...
INIF="" # 內部 LAN 的連接介面;若無 LAN ,填寫成 INIF=""
# This is your LAN NIC. If you don't have a LAN, input INIF="" please.
INNET="192.168.1.0/24" # 若有兩個以上的網域,可以用 INNET="192.168.1.0/24 192.168.100.0/24"
# 若無內部網域介面,請填寫成 INNET=""
# This is your LAN's Network. If you have to private network,
# input as INNET="192.168.1.0/24 192.168.100.0/24".
export EXTIF INIF INNET
# 個人化設定啊!請自行填寫您自己想要預先啟動的一些基礎資料。
# These settings is about yourself's paramters.
allowname='no.bbs.org' # 允許登入本機的 hostname ,必須是 Internet 找的到的 hostname。
allowip=""
if [ "$allowname" != "" ]; then
for siteiptmp in `echo $allowname`
do
siteip=`/usr/bin/host $siteiptmp 168.95.1.1 | grep address|tail -n 1 | awk '{print $4}'`
testip=`echo $siteip | grep [^0-9.]`
if [ "$testip" == "" ]; then
allowip="$allowip $siteip"
fi
done
fi
export allowip
# 第一部份,針對本機的防火牆設定!#########################################################
# First, your server's firewall settings.
# 1. 先設定好核心的網路功能:
# 1. the kernel's firewall settings.
# 開啟 TCP Flooding 的 DoS 攻擊抵擋機制,但這個設定不適合 loading 已經很高的主機!!!
# TCP Flooding's setting. this setting is no good for high loading servers
echo "1" > /proc/sys/net/ipv4/tcp_syncookies
# 取消 ping 廣播的回應;
# unset reply of ping.
echo "1" > /proc/sys/net/ipv4/icmp_echo_ignore_broadcasts
# 開啟逆向路徑過濾,以符合 IP 封包與網路介面的設定;
#
for i in /proc/sys/net/ipv4/conf/*/rp_filter; do
echo "1" > $i
done
# 開啟記錄有問題的封包
# record some problems packets.
for i in /proc/sys/net/ipv4/conf/*/log_martians; do
echo "1" > $i
done
# 取消來源路由,這個設定值是可以取消的;
for i in /proc/sys/net/ipv4/conf/*/accept_source_route; do
echo "0" > $i
done
# 取消重新宣告路徑的功能。
for i in /proc/sys/net/ipv4/conf/*/accept_redirects; do
echo "0" > $i
done
# 取消傳送重新宣告路徑的功能。
for i in /proc/sys/net/ipv4/conf/*/send_redirects; do
echo "0" > $i
done
# 2. 清除規則、設定預設政策及開放 lo 與相關的設定值
# 2. clear rule, set the policy rule and allow lo connect.
PATH=/sbin:/usr/sbin:/bin:/usr/bin:/usr/local/sbin:/usr/local/bin; export PATH
iptables -F
iptables -X
iptables -Z
iptables -P INPUT DROP
iptables -P OUTPUT ACCEPT
iptables -P FORWARD ACCEPT
iptables -A INPUT -i lo -j ACCEPT
iptables -A INPUT -m state --state RELATED -j ACCEPT
# 3. 啟動額外的防火牆 script 模組
# 3. other shell scripts, written by VBird.
# 預設抵擋的主機
if [ -f /usr/local/virus/iptables/iptables.deny ]; then
sh /usr/local/virus/iptables/iptables.deny
fi
# 預設開放的主機
if [ -f /usr/local/virus/iptables/iptables.allow ]; then
sh /usr/local/virus/iptables/iptables.allow
fi
# 透過 WWW 砍站軟體分析的抵擋機制
if [ -f /usr/local/virus/httpd-err/iptables.http ]; then
sh /usr/local/virus/httpd-err/iptables.http
fi
iptables -A INPUT -m state --state ESTABLISHED -j ACCEPT
# 4. 允許某些類型的 ICMP 封包進入
# 4. allow some types of ICMP
AICMP="0 3 3/4 4 11 12 14 16 18"
for tyicmp in $AICMP
do
iptables -A INPUT -i $EXTIF -p icmp --icmp-type $tyicmp -j ACCEPT
done
# 5. 允許某些服務的進入
iptables -A INPUT -p TCP -i $EXTIF --dport 22 -j ACCEPT # SSH
iptables -A INPUT -p TCP -i $EXTIF --dport 25 -j ACCEPT # SMTP
# iptables -A INPUT -p UDP -i $EXTIF --dport 161 -j ACCEPT # SNMP-MRTG
# iptables -A INPUT -p TCP -i $EXTIF --dport 53 -j ACCEPT # DNS
iptables -A INPUT -p TCP -i $EXTIF --dport 80 -j ACCEPT # WWW
# iptables -A INPUT -p TCP -i $EXTIF --dport 110 -j ACCEPT # POP3
iptables -A INPUT -p TCP -i $EXTIF --dport 443 -j ACCEPT # HTTPS
iptables -A INPUT -p TCP -i $EXTIF --dport 3128 -j ACCEPT # Squid
iptables -A INPUT -p TCP -i $EXTIF --dport 5900 -j ACCEPT # VNC
# 第二部份,針對後端主機的防火牆設定!#########################################################
# Second, the NAT settings.
# 1. 先載入一些有用的模組
# 1. loading some good modules of iptables.
modules="ip_tables iptable_nat ip_nat_ftp ip_nat_irc ip_conntrack ip_conntrack_ftp ip_conntrack_irc"
for mod in $modules
do
testmod=`lsmod | grep "^${mod} " | awk '{print $1}'`
if [ "$testmod" == "" ]; then
modprobe $mod
fi
done
# 2. 清除 NAT table 的規則吧!
# 2. clean NAT table's rule
iptables -F -t nat
iptables -X -t nat
iptables -Z -t nat
iptables -t nat -P PREROUTING ACCEPT
iptables -t nat -P POSTROUTING ACCEPT
iptables -t nat -P OUTPUT ACCEPT
# 3. 開放成為路由器,且為 IP 分享器!
# 3. NAT server's settings
if [ "$INIF" != "" ]; then
iptables -A INPUT -i $INIF -j ACCEPT
echo "1" > /proc/sys/net/ipv4/ip_forward
if [ "$INNET" != "" ]; then
for innet in $INNET
do
iptables -t nat -A POSTROUTING -s $innet -o $EXTIF -j MASQUERADE
done
fi
fi
# 如果你的 MSN 一直無法連線,或者是某些網站 OK 某些網站不 OK,可能是 MTU 的問題,
# 那你可以將底下這一行給他取消註解來啟動 MTU 限制範圍
# iptables -A FORWARD -p tcp -m tcp --tcp-flags SYN,RST SYN -m tcpmss --mss 1400:1536 -j TCPMSS --clamp-mss-to-pmtu
# 4. NAT 主機後端的 LAN 內對外之伺服器設定
# iptables -t nat -A PREROUTING -p tcp -i $EXTIF --dport 80 -j DNAT --to 192.168.1.210:80 # WWW
3.可預先建立 wip.txt 白名單在 /usr/local/virus/iptables,免得擋到自己
例如 vi wip.txt
代碼:
127.0.0.1
192.168.1.123
192.168.1.111
192.168.1.123
192.168.1.111
4.建立 iptables.allow 和 iptables.deny (follow 鳥哥的scripts..注意看第二項)
vi iptables.allow
代碼:
#!/bin/bash
# 底下則填寫你允許進入本機的其他網域或主機啊!
# iptables -A INPUT -i $EXTIF -s 192.168.1.0/24 -j ACCEPT
iptables -A INPUT -i $EXTIF -p TCP -s 192.168.1.0/24 --dport 1234 -j ACCEPT
# 底下則填寫你允許進入本機的其他網域或主機啊!
# iptables -A INPUT -i $EXTIF -s 192.168.1.0/24 -j ACCEPT
iptables -A INPUT -i $EXTIF -p TCP -s 192.168.1.0/24 --dport 1234 -j ACCEPT
vi iptables.deny
代碼:
/sbin/iptables -A INPUT -i $EXTIF -s 110.172.24.28 -j DROP #auto
/sbin/iptables -A INPUT -i $EXTIF -s 111.118.160.201 -j DROP #auto
/sbin/iptables -A INPUT -i $EXTIF -s 112.125.60.81 -j DROP #auto
/sbin/iptables -A INPUT -i $EXTIF -s 112.179.62.17 -j DROP #auto
/sbin/iptables -A INPUT -i $EXTIF -s 112.216.83.178 -j DROP #auto
/sbin/iptables -A INPUT -i $EXTIF -s 113.105.131.130 -j DROP #auto
/sbin/iptables -A INPUT -i $EXTIF -s 113.11.203.98 -j DROP #auto
# 請follow 這個格式去做
# 有auto的部分,是成是自動加入的
/sbin/iptables -A INPUT -i $EXTIF -s 111.118.160.201 -j DROP #auto
/sbin/iptables -A INPUT -i $EXTIF -s 112.125.60.81 -j DROP #auto
/sbin/iptables -A INPUT -i $EXTIF -s 112.179.62.17 -j DROP #auto
/sbin/iptables -A INPUT -i $EXTIF -s 112.216.83.178 -j DROP #auto
/sbin/iptables -A INPUT -i $EXTIF -s 113.105.131.130 -j DROP #auto
/sbin/iptables -A INPUT -i $EXTIF -s 113.11.203.98 -j DROP #auto
# 請follow 這個格式去做
# 有auto的部分,是成是自動加入的
5. 寫入 crontab中,定時執行
vi /etc/crontab
代碼:
#伺服器sshd&httpd安全
*/1 * * * * root /usr/local/virus/iptables/sshd_httpd.sh > /dev/null 2>&1
*/1 * * * * root /usr/local/virus/iptables/sshd_httpd.sh > /dev/null 2>&1
全站熱搜
留言列表