shell腳本轉(zhuǎn)發(fā)80端口數(shù)據(jù)包給Node.js服務(wù)器
注意:千萬不要圖省事直接使用ROOT用戶運(yùn)行Node.js服務(wù)!這將帶來無法預(yù)計(jì)的安全問題!
但是使用80端口作為HTTP默認(rèn)端口這一習(xí)慣是從MS時(shí)代就延續(xù)至今的,怎么辦呢?網(wǎng)上有人滔滔不絕地說用NginX做反向之類的,其實(shí)我覺得沒必要這么夸張,只需要使用ROOT用戶做一個(gè)普通端口與80端口的數(shù)據(jù)轉(zhuǎn)發(fā)就好了,使用iptables語句如下:
使用以上這條語句需要注意以下幾點(diǎn):
1.這條語句是臨時(shí)性的,服務(wù)器重啟后失效。
2.如果執(zhí)行過這類語句之后,又想把80端口綁定轉(zhuǎn)發(fā)到其他端口上去的話,你要先使用
#查看目前端口轉(zhuǎn)發(fā)規(guī)則
iptables --line-numbers --list PREROUTING -t nat
#從上面語句輸出的列表中找到自己之前綁定轉(zhuǎn)發(fā)的端口的記錄的行號(hào),然后用下面這句刪掉這條記錄來刪除轉(zhuǎn)發(fā),而且是你不能指定轉(zhuǎn)發(fā)規(guī)則的特征來刪除記錄,你只能告訴它“刪除第幾行”。
iptables -t nat -D PREROUTING 行號(hào)
3.使用ArchLinux的童鞋們需要注意了,可能由于內(nèi)核缺少模塊(是iptables還是nat來著?)而不能用上述語句來設(shè)置綁定轉(zhuǎn)發(fā)端口,需要重新編譯內(nèi)核或者模塊。
介于以上問題,我寫了一個(gè)腳本,來實(shí)現(xiàn)自動(dòng)刪除記錄和自動(dòng)綁定:
if [ $# = 1 ]; then
if [ $1 -ge 0 ]; then
if [ $1 -le 65535 ]; then
#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!"
只需要將上面代碼保存為文件(如bind80)并添加執(zhí)行權(quán)限,使用如下指令即可清除之前的記錄并將新端口進(jìn)行綁定轉(zhuǎn)發(fā):
sudo bind80 端口號(hào)
相關(guān)文章
Shell腳本獲取國(guó)內(nèi)各大運(yùn)營(yíng)商網(wǎng)段腳本分享
這篇文章主要介紹了Shell腳本獲取國(guó)內(nèi)各大運(yùn)營(yíng)商網(wǎng)段腳本分享,本文使用亞太地區(qū)網(wǎng)絡(luò)信息記錄作為數(shù)據(jù)源,然后使用Shell腳本分析國(guó)內(nèi)的網(wǎng)段,需要的朋友可以參考下2014-12-12
詳解Shell編程之if語句實(shí)戰(zhàn)(小結(jié))
本篇文章主要介紹了詳解Shell編程之if語句實(shí)戰(zhàn)(小結(jié)),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-02-02
shell 使用數(shù)組作為函數(shù)參數(shù)的方法(詳解)
下面小編就為大家?guī)硪黄猻hell 使用數(shù)組作為函數(shù)參數(shù)的方法(詳解)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-04-04
shell腳本從SVN推送到多臺(tái)服務(wù)器的代碼
shell 腳本從SVN推送到多臺(tái)服務(wù)器,需要的朋友可以參考下2013-02-02
實(shí)現(xiàn)MySQL定時(shí)批量檢查表repair和優(yōu)化表optimize table的shell腳本
這篇文章主要介紹了實(shí)現(xiàn)MySQL定時(shí)批量檢查表repair和優(yōu)化表optimize table的shell腳本,非常實(shí)用,需要的朋友可以參考下2014-07-07
實(shí)現(xiàn)shell終端代碼分享(可用戶登錄 實(shí)現(xiàn)系統(tǒng)命令)
實(shí)現(xiàn)shell終端代碼分享,實(shí)現(xiàn)用戶登錄,系統(tǒng)命令使用,大家參考實(shí)現(xiàn)吧2013-12-12
Linux下查找后門程序 CentOS 查后門程序的shell腳本
這篇文章主要介紹了Linux下查找后門程序 CentOS 查后門程序的shell腳本,需要的朋友可以參考下2014-09-09
一天一個(gè)shell命令 文本操作系列-comm命令用法
這篇文章主要介紹了linux系統(tǒng)下的comm命令是一個(gè)非常實(shí)用的文件對(duì)比命令,需要的朋友可以參考下2016-05-05
Shell腳本注冊(cè)到Linux系統(tǒng)服務(wù)實(shí)例
這篇文章主要介紹了Shell腳本注冊(cè)到Linux系統(tǒng)服務(wù)實(shí)例,本文給出一個(gè)可以作為L(zhǎng)inux服務(wù)的腳本實(shí)例,及加入服務(wù)的方法等步驟,需要的朋友可以參考下2015-05-05

