注意:千萬(wàn)不要圖省事直接使用ROOT用戶運(yùn)行Node.js服務(wù)!這將帶來(lái)無(wú)法預(yù)計(jì)的安全問(wèn)題!
但是使用80端口作為HTTP默認(rèn)端口這一習(xí)慣是從MS時(shí)代就延續(xù)至今的,怎么辦呢?網(wǎng)上有人滔滔不絕地說(shuō)用NginX做反向代理之類的,其實(shí)我覺(jué)得沒(méi)必要這么夸張,只需要使用ROOT用戶做一個(gè)普通端口與80端口的數(shù)據(jù)轉(zhuǎn)發(fā)就好了,使用iptables語(yǔ)句如下:
#從上面語(yǔ)句輸出的列表中找到自己之前綁定轉(zhuǎn)發(fā)的端口的記錄的行號(hào),然后用下面這句刪掉這條記錄來(lái)刪除轉(zhuǎn)發(fā),而且最蛋疼的是你不能指定轉(zhuǎn)發(fā)規(guī)則的特征來(lái)刪除記錄,你只能告訴它“刪除第幾行”。
iptables -t nat -D PREROUTING 行號(hào)
3.使用ArchLinux的童鞋們需要注意了,可能由于內(nèi)核缺少模塊(是iptables還是nat來(lái)著?)而不能用上述語(yǔ)句來(lái)設(shè)置綁定轉(zhuǎn)發(fā)端口,需要重新編譯內(nèi)核或者模塊。
介于以上蛋疼問(wèn)題,我寫(xiě)了一個(gè)腳本,來(lái)實(shí)現(xiàn)自動(dòng)刪除記錄和自動(dòng)綁定:
#Delete all old bindings
for line_num in $(iptables --line-numbers --list PREROUTING -t nat|grep dpt:http|awk '{print $1}')
do
LINES="$line_num $LINES"
done
for line in $LINES
do
iptables -t nat -D PREROUTING $line
done
unset LINES
#Make a new binding
iptables -t nat -A PREROUTING -p tcp --dport 80 -j REDIRECT --to-port $1
echo "Port 80 is bound with $1 !"
exit 1
fi
fi
fi
echo "Please input ONE PORT NUMBER!"
標(biāo)簽:巴彥淖爾 許昌 淘寶邀評(píng) 邵陽(yáng) 金昌 赤峰 婁底 馬鞍山
巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《shell腳本轉(zhuǎn)發(fā)80端口數(shù)據(jù)包給Node.js服務(wù)器》,本文關(guān)鍵詞 shell,腳本,轉(zhuǎn)發(fā),端口,數(shù)據(jù),;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。