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 #卸载服务
END

本文标题:Frp部署脚本及文档

本文作者:宇宙最帅的男人

本文链接:https://lolicp.com/linux/2021159.html

版权声明:转载或者引用本文内容请注明来源及原作者,本文著作权归作者 (宇宙最帅的男人) 所有。

除非另有说明,本作品采用知识共享署名-非商业性使用-相同方式共享 4.0 国际许可协议

最后修改:2021 年 06 月 15 日
如果觉得我的文章对你有用,请随意赞赏