frp 是一个可用于内网穿透的高性能的反向代理应用,支持 tcp, udp 协议,为 http 和 https 应用协议提供了额外的能力,且尝试性支持了点对点穿透。
Frp安装及管理脚本内容:
#!/bin/bash
#frp管理脚本
#Frp安装路径
Frp_Path='/usr/local/frpd'
#Frps路径
Frps_Path="${Frp_Path}/frps"
#Frpc路径
Frpc_Path="${Frp_Path}/frpc"
#Frps配置文件路径
Frps_Conf="${Frp_Path}/frps.ini"
#Frpc配置文件路径
Frpc_Conf="${Frp_Path}/frpc.ini"
#Frp版本
Frp_Version_local="${Frp_Path}/.Frp_Version"
#Frp日志目录
Frp_Logs="${Frp_Path}/logs"
#Frp日志地址
Frps_Logs_File="${Frp_Logs}/frps.log"
#Frps server端口
Frps_Port='1281'
#Frpc 端口
Frpc_Port='10801'
#Frps 仪表盘地址
Frps_Dashboard_Addr='0.0.0.0'
#Frps 仪表盘端口
Frps_Dashboard_Port='1288'
#Frps 仪表盘用户名
Frps_Dashboard_User='adminis'
#Frps 仪表盘密码
Frps_Dashboard_Pwd='YMcc_duyonged'
#Frps 授权验证
Frps_Token='Uinux_ymcc_duyonge'
request_Page() {
Page_Content=$(curl -s https://github.com/fatedier/frp/releases)
Frp_Version=$(echo "${Page_Content}" |sed -n 's#.*/fatedier/frp/releases/tag/.*>\(.*\)<.*#\1#p' |head -1 )
#Frp解压路径
Frpd_Path="${Frp_Path}/frp_${Frp_Version/v}_linux_amd64"
Frp_File_Name="${Frp_Path}/${Frp_Version}.tar.gz"
Frp_Down_Url=$(echo "${Page_Content}" |sed -n "s#.*\(/fatedier/frp/releases/download/${Frp_Version}.*linux.*amd64.*\)\".*rel.*#https://github.com\1#p")
}
Frp_Init() {
#查询Frps进程
Frps_Auth_Check=$(/usr/bin/ps -C frps |awk '/frp/ {print $1}')
#查询Frpc进程
Frpc_Auth_Check=$(/usr/bin/ps -C frpc |awk '/frp/ {print $1}')
case $1 in
start)
#判断Frps服务是否启动
if [ ! -z "${Frps_Auth_Check}" ];then
echo -e '\033[31mFrps正在运行中..\033[0m'
else
#后台启动Frps服务
nohup ${Frps_Path} -c ${Frps_Conf} &> /dev/null &
sleep 0.1
Frps_Auth_Check=$(/usr/bin/ps -C frps |awk '/frp/ {print $1}')
if [ -z "${Frps_Auth_Check}" ];then
echo -e '\033[31mFrps启动失败!\033[0m'
else
echo -e '\033[32mFrps启动成功!\033[0m'
fi
fi
#判断Frpc服务是否启动
if [ -z "${Frpc_Auth_Check}" ];then
#后台启动Frpc服务
nohup ${Frpc_Path} -c ${Frpc_Conf} &> /dev/null &
Frpc_Auth_Check=$(/usr/bin/ps -C frpc |awk '/frp/ {print $1}')
if [ -z "${Frpc_Auth_Check}" ];then
echo -e '\033[31mFrpc启动失败!\033[0m'
else
echo -e '\033[32mFrpc启动成功!\033[0m'
fi
else
echo -e '\033[31mFrpc正在运行中..\033[0m'
fi
;;
stop)
if [ ! -z "${Frps_Auth_Check}" ];then
/usr/bin/kill -9 "${Frps_Auth_Check}"
echo -e '\033[32mFrps服务已停止!\033[0m'
else
echo -e "\033[31mFrps服务未启动!\033[0m"
fi
if [ ! -z "${Frpc_Auth_Check}" ];then
/usr/bin/kill -9 "${Frpc_Auth_Check}"
echo -e '\033[32mFrpc服务已停止!\033[0m'
else
echo -e "\033[31mFrpc服务未启动!\033[0m"
fi
;;
*)
echo -e '\033[31m请输入正确参数!\033[0m'
esac
}
Frp_Down() {
if \[ ! -d "${Frp_Path}" \];then
echo -e "\\033\[31m${Frp_Path} 不存在!\\033\[0m"
mkdir "${Frp_Path}"
if \[ ! -d "${Frp_Path}" \];then
echo -e "\\033\[31m${Frp_Path} 创建失败!\\033\[0m"
exit 1
fi
fi
Frpd_Down_Name=" ${Frp_File_Name#////}"
echo -ne "\\033\[36m${Frpd_Down_Name} 下载中..\\r\\033\[0m"
wget -q -O ${Frp_File_Name} ${Frp_Down_Url}
if \[ ! -f ${Frp_File_Name} \];then
echo -e "\\033\[31m${Frpd_Down_Name} \\r\\033\[0m下载失败!"
exit 1
else
echo -e "\\033\[32m${Frpd_Down_Name} \\r\\033\[0m下载成功!"
fi
cd ${Frp_Path}/
tar zxf ${Frp_File_Name}
if \[ -d ${Frpd_Path} \];then
echo -e "\\033\[32m${Frpd_Down_Name} \\033\[0m解压成功!"
else
echo -e "\\033\[31m${Frpd_Down_Name} \\033\[0m解压失败!"
echo "${Frp_Version}"
exit 1
fi
if \[ ! -f ${Frps_Conf} \];then
cp ${Frpd_Path}/frp\* ./
#检测Frps是否存在
if \[ ! -f "${Frps_Path}" \];then
echo -e "\\033\[31m${Frps_Path} 不存在!\\033\[0m"
#检测Frpc是否存在
elif \[ ! -f "${Frpc_Path}" \];then
# Frp_Installr install
echo -e "\\033\[31m${Frpc_Path} 不存在!\\033\[0m"
#检测Frps配置文件是否存在
elif \[ ! -f "${Frps_Conf}" \];then
echo -e "\\033\[31m${Frps_Conf} 不存在!\\033\[0m"
#检测Frpc配置文件是否存在
elif \[ ! -f "${Frpc_Conf}" \];then
echo -e "\\033\[31m${Frpc_Conf} 不存在!\\033\[0m"
else
echo -e "\\033\[32m文件拷贝成功!\\033\[0m"
fi
sed -i "s/(\^bind_port\[\[:space:\]\]=\[\[:space:\]\])./\\1${Frps_Port}/" ${Frps_Conf}
sed -i "$akcp_bind_port = ${Frps_Port}" ${Frps_Conf}
sed -i "$adashboard_addr = ${Frps_Dashboard_Addr}" ${Frps_Conf}
sed -i "$adashboard_port = ${Frps_Dashboard_Port}" ${Frps_Conf}
sed -i "$adashboard_user = ${Frps_Dashboard_User}" ${Frps_Conf}
sed -i "$adashboard_pwd = ${Frps_Dashboard_Pwd}" ${Frps_Conf}
sed -i "$atoken = ${Frps_Token}" ${Frps_Conf}
sed -i "$amax_ports_per_client = 0" ${Frps_Conf}
sed -i "$atcp_mux = true" ${Frps_Conf}
sed -i "$alog_file = ${Frps_Logs_File}" ${Frps_Conf}
sed -i "$alog_level = trace" ${Frps_Conf}
sed -i "$alog_max_days = 3" ${Frps_Conf}
if \[ -f ${Frpc_Conf} \];then
sed -i "s/(server_port = )./\\1${Frps_Port}/g" ${Frpc_Conf}
sed -i "3atoken = ${Frps_Token}" ${Frpc_Conf}
fi
else
cp ${Frpd_Path}/frps ${Frp_Path}
fi
rm -rf ${Frpd_Path}/
echo ${Frp_Version} \> ${Frp_Version_local}
if \[ ! -e ${Frp_Logs} \];then
mkdir -p ${Frp_Logs}
fi
}
Frp_Installr() {
request_Page
if \[ ! -e ${Frp_Path} \];then
mkdir ${Frp_Path}
fi
case $1 in
install)
if \[ ! -f "${Frps_Path}" \];then
cd ${Frp_Path}
Frp_Down
else
echo -e "\\033\[32m${Frps_Path} 已存在!\\033\[0m"
fi
;;
update)
if \[ ! -e ${Frp_Version_local} \] ;then
echo -e "\\033\[31m${Frp_Version_local}\\033\[0m 不存在!"
Frp_Installr install
elif \[ "$(cat ${Frp_Version_local})" = "${Frp_Version}" \] ;then
echo -e "已是最新版:\\033\[32m ${Frp_Version}\\033\[0m"
elif \[ ! "$(cat ${Frp_Version_local})" = "${Frp_Version}" \] ;then
Frp_Init stop
Frp_Down
fi
;;
\*)
echo -e "请输入正确参数: \\033\[31minstall \| update\\033\[0m"
esac
}
Uninstall() {
if \[ -f ${Frps_Conf} \];then
Frp_Init stop
cp ${Frps_Conf} /tmp/frps.ini.bak
rm -rf ${Frp_Path}
rm -rf /usr/local/bin/${0}
echo -e "\\033\[32mFrp已卸载\\033\[0m,配置文件保存至 /tmp/frps.ini.bak ."
else
echo -e "卸载失败,配置文件\\033\[31m ${Frps_Conf} \\033\[0m不存在!"
fi
}
`case $1 in
update)
Frp_Installr $1
;;
install)
Frp_Installr $1
;;
start)
Frp_Init $1
;;
stop)
Frp_Init $1
;;
restart)
Frp_Init stop
Frp_Init start
;;
uninstall)
Uninstall
;;
*)
echo '请输入正确参数(update|install|start|stop|restart|uninstall'
esac`
将脚本内容拷贝至/usr/local/sbin/frpd
cp ~/frpd.sh /usr/local/sbin/frpd
chmod +x /usr/local/sbin/frpd
脚本参数说明:
install #安装
update #更新最新版
start #启动服务
stop #停止服务
restart #重启服务
uninstall #卸载服务