207 lines
5.0 KiB
Bash
207 lines
5.0 KiB
Bash
#!/bin/bash
|
|
PATH=/bin:/sbin:/usr/bin:/usr/sbin:/usr/local/bin:/usr/local/sbin:~/bin
|
|
export PATH
|
|
#判断系统
|
|
if [[ -e /etc/debian_version ]]; then
|
|
OS=debian
|
|
GROUPNAME=nogroup
|
|
RCLOCAL='/etc/rc.local'
|
|
IPTABLES=`dpkg --get-selections | grep iptables`
|
|
elif [[ -e /etc/centos-release || -e /etc/redhat-release ]]; then
|
|
OS=centos
|
|
GROUPNAME=nobody
|
|
RCLOCAL='/etc/rc.d/rc.local'
|
|
IPTABLES=`rpm -qa |grep iptables`
|
|
else
|
|
echo "只支持Debian\Ubuntu\CentOS系统"
|
|
exit
|
|
fi
|
|
#检查依赖IPTABLES
|
|
if [ "$IPTABLES" == '' ]; then
|
|
if [[ "$OS" = 'debian' ]]; then
|
|
apt-get update
|
|
apt-get install iptables -y
|
|
else
|
|
yum install iptables -y
|
|
fi
|
|
fi
|
|
#检查目录
|
|
if [ ! -d "/usr/local/udptools" ]; then
|
|
echo "未安装udptools,请先安装."
|
|
exit
|
|
fi
|
|
if [ ! -d "/usr/local/udptools/pid" ]; then
|
|
mkdir /usr/local/udptools/pid
|
|
fi
|
|
if [ ! -d "/usr/local/udptools/log" ]; then
|
|
mkdir /usr/local/udptools/log
|
|
fi
|
|
if [ ! -d "/usr/local/udptools/conf" ]; then
|
|
mkdir /usr/local/udptools/conf
|
|
fi
|
|
|
|
buildServer()
|
|
{
|
|
echo "-s
|
|
# 服务器模式
|
|
-l 0.0.0.0:$LPORT
|
|
# 监听端口给UDP2RAW客户端
|
|
-r 127.0.0.1:$MPORT
|
|
# 连接UDPSpeeder端口
|
|
-k $PASSWD
|
|
# 密码
|
|
--cipher-mode xor
|
|
# 简单xor加密
|
|
--fix-gro
|
|
# 修复粘包" > /usr/local/udptools/conf/udp2raw-s${MPORT}.conf
|
|
echo "#!/bin/bash
|
|
PATH=/bin:/sbin:/usr/bin:/usr/sbin:/usr/local/bin:/usr/local/sbin:~/bin
|
|
export PATH
|
|
#进程名
|
|
PROG=Udp2Raw-Server-${MPORT}
|
|
#BIN路径
|
|
BIN_FILE=/usr/local/udptools/bin/udp2raw
|
|
#配置路径
|
|
CONFIG_FILE=/usr/local/udptools/conf/udp2raw-s${MPORT}.conf
|
|
#日志路径
|
|
LOG_FILE=/usr/local/udptools/log/udp2raw-s${MPORT}.log
|
|
#PID路径
|
|
PID_FILE=/usr/local/udptools/pid/udp2raw-s${MPORT}.pid
|
|
" > /usr/local/udptools/udp2raw-s${MPORT}.sh
|
|
cat >> /usr/local/udptools/udp2raw-s${MPORT}.sh <<EOF
|
|
checkSet(){
|
|
#获取监听端口
|
|
SERVER_PORT=`cat \$CONFIG_FILE | grep '\-l ' | awk -F ":" '{print $2}'`
|
|
#检查iptables规则
|
|
IPTALBES=`iptables -nvL | grep DROP | grep tcp | grep \$SERVER_PORT`
|
|
if [ ! -n "\$IPTALBES" ]; then
|
|
echo "Adding iptables rules."
|
|
#添加iptables规则
|
|
RULES=`\$BIN_FILE --conf-file \$CONFIG_FILE -g | grep iptables |grep -v rule`
|
|
\$RULES
|
|
fi
|
|
#赋权
|
|
setcap cap_net_raw+ep \$BIN_FILE
|
|
}
|
|
EOF
|
|
chmod +x /usr/local/udptools/udp2raw-s${MPORT}.sh
|
|
|
|
#判断服务模式
|
|
if pgrep systemd-journal > /dev/null; then
|
|
SYSTEMCTL=1
|
|
else
|
|
SYSTEMCTL=0
|
|
fi
|
|
echo $PASSWD
|
|
echo $RPORT
|
|
echo $MPORT
|
|
echo $LPORT
|
|
}
|
|
|
|
buildClient()
|
|
{
|
|
echo "-c
|
|
# 客户端模式
|
|
-l 127.0.0.1:$MPORT
|
|
# 监听端口给UdpSpeeder用
|
|
-r $REMOTEIP:$RPORT
|
|
# 连接UDP2RAW服务端
|
|
-k $PASSWD
|
|
# 密码
|
|
--cipher-mode xor
|
|
# 简单xor加密
|
|
--fix-gro
|
|
# 修复粘包" > /usr/local/udptools/conf/udp2raw-c${MPORT}.conf
|
|
|
|
#判断服务模式
|
|
if pgrep systemd-journal > /dev/null; then
|
|
SYSTEMCTL=1
|
|
else
|
|
SYSTEMCTL=0
|
|
fi
|
|
echo $PASSWD
|
|
echo $REMOTEIP
|
|
echo $RPORT
|
|
echo $MPORT
|
|
echo $LPORT
|
|
}
|
|
|
|
|
|
echo
|
|
echo "Which mode to run this?"
|
|
echo "你想运行在什么模式?"
|
|
echo " 1) Client(Default) - 客户端(默认)"
|
|
echo " 2) Server - 服务端"
|
|
read -p "Run Mode(运行模式) [1-2]: " -e -i 1 RUNMODE
|
|
case $RUNMODE in
|
|
1)
|
|
read -p "Udp2Raw Password(Udp2Raw密码): " PASSWD
|
|
echo""
|
|
read -p "Remote Udp2Raw IP(Udp2Raw远程IP): " REMOTEIP
|
|
echo""
|
|
while [[ ! "$RPORT" =~ [1-65535] ]];do
|
|
read -p "Remote Udp2Raw Port(Udp2Raw远程端口): " RPORT
|
|
echo""
|
|
done
|
|
while [[ ! "$MPORT" =~ [1-65535] ]];do
|
|
read -p "Middle Port(Udp2Raw与UDPSpeeder中间端口): " MPORT
|
|
CHECKMPORT=`netstat -ntl | grep $MPORT`
|
|
if [[ "$CHECKMPORT" != "" ]]; then
|
|
MPORT=0
|
|
echo "端口已被占用";
|
|
fi
|
|
echo""
|
|
done
|
|
while [[ ! "$LPORT" =~ [1-65535] ]];do
|
|
read -p "Listen Port(监听给本地其他业务用端口): " LPORT
|
|
CHECKLPORT=`netstat -ntl | grep $LPORT`
|
|
if [[ "$CHECKLPORT" != "" ]]; then
|
|
LPORT=0
|
|
echo "端口已被占用";
|
|
fi
|
|
if [ "$LPORT" == "$MPORT" ]; then
|
|
LPORT=0
|
|
echo "端口已被占用";
|
|
fi
|
|
echo""
|
|
done
|
|
|
|
buildClient
|
|
;;
|
|
2)
|
|
read -p "Udp2Raw Password(Udp2Raw密码): " PASSWD
|
|
echo""
|
|
while [[ ! "$RPORT" =~ [1-65535] ]];do
|
|
read -p "Other Server Port(本地其他业务端口): " RPORT
|
|
echo""
|
|
done
|
|
while [[ ! "$MPORT" =~ [1-65535] ]];do
|
|
read -p "Middle Port(Udp2Raw与UDPSpeeder中间端口): " MPORT
|
|
CHECKMPORT=`netstat -ntl | grep $MPORT`
|
|
if [[ "$CHECKMPORT" != "" ]]; then
|
|
MPORT=0
|
|
echo "端口已被占用";
|
|
fi
|
|
if [ "$MPORT" == "$RPORT" ]; then
|
|
MPORT=0
|
|
echo "端口已被占用";
|
|
fi
|
|
echo""
|
|
done
|
|
while [[ ! "$LPORT" =~ [1-65535] ]];do
|
|
read -p "Udp2Raw Listen Port(监听给远程UDP2RAW用): " LPORT
|
|
CHECKLPORT=`netstat -ntl | grep $LPORT`
|
|
if [[ "$CHECKLPORT" != "" ]]; then
|
|
LPORT=0
|
|
echo "端口已被占用";
|
|
fi
|
|
if [ "$LPORT" == "$MPORT" ]; then
|
|
LPORT=0
|
|
echo "端口已被占用";
|
|
fi
|
|
echo""
|
|
done
|
|
|
|
buildServer
|
|
;;
|
|
esac |