简介

frp 是一个可用于内网穿透的高性能的反向代理开源应用,支持 tcp, udp 协议,为 http 和 https 应用协议提供了额外的能力,且尝试性支持了点对点穿透。

architecture.png

frp 使用Go 语言开发,得益于此,我们使用非常简单,只需要添加执行权限就可以运行了。如果需要将它运行在后台,作为服务的运行的话,就需要我们对系统有一定的了解了,下面我简单介绍一下,如何将 frp安装为系统服务

注意:在安装服务之前,请确保你的 frp 已经参照官方文档进行了正确的配置。

windows

若要将 frp 安装为 windows 的服务,我们需要借助第三方的开源工具 nssm 来实现,以下是操作步骤:

  1. nssm 官网下载对应的工具,并解压到 D盘根目录

  2. 以管理员方式运行 cmd, 直接输入 d 按回车 切换到d盘

  3. 在cmd中运行 命令.nssm.exe install frpc ,此时会弹出 Gui

  4. GUI 中选择你的frp路径,以及在 Arguments 中 正确的填入 -c 完整配置文件路径,如图:

    image-20200803144527495

  5. 点击 install service 后,cmd会提示:Service "frpc" installed successfully! 表示安装完成

以上就是将frpc 安装为windows服务的操作步骤了,如果是 frps 也是同样的操作,就不再赘述了。

Linux

相比 Windows,Linux 其实更简单,只需要将启动脚本放到相应的目录并加上执行权限就可以了

以下以 frpc 为例

init.d

建议使用 后面的 systemd 来管理

操作步骤:

  1. 将 frpc 文件写入在到 /etc/init.d/frpc, 并添加执行权限: chmod +x /etc/init.d/frpc

  2. 添加开机启动:

    • Centos: chkconfig frpc on
    • Debian: update-rc.d frpc defaults
  3. 启动:service frpc start

  4. 停止:service frpc stop

  5. 重启:service frpc restart

  6. 查看状态:service frpc status

     1
     2
     3
     4
     5
     6
     7
     8
     9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    
    ## File: /etc/init.d/frpc  
    #!/bin/sh  
    #  
    # frps:    FRP-Client Daemon  
    #  
    # description:  FRP-Client Daemon  
    # 请按实际情况修改  
    PID_FILE=/run/frpc.pid  
    CONFIG_FILE=/etc/frpc.ini  
    FRPC_File=/usr/local/frp/frpc  
      
    start()  
    {  
    if [ ! -f $PID_FILE ]; then  
        echo -n $"Starting FRP client..."  
        nohup $FRPC_File -c $CONFIG_FILE < /dev/null > /dev/null 2> /dev/null &  
        echo $! > $PID_FILE  
        echo ""  
    else  
        PID=$(cat $PID_FILE)  
        if [ ! -f /proc/$PID/cmdline ]; then  
      
            echo -n $"Starting FRP client..."  
            nohup $FRPC_File -c $CONFIG_FILE < /dev/null > /dev/null 2> /dev/null &  
            echo $! > $PID_FILE  
            echo ""  
        else  
            echo "FRP client is already running..."  
        fi  
    fi;  
    }  
    stop()  
    {  
    if [[ -f $PID_FILE ]]; then  
        echo -n $"Shutting down FRP client..."  
        kill -9 $(cat $PID_FILE)  
        rm -f $PID_FILE  
        echo ""  
    else  
        echo "FRP client is not running..."  
    fi;  
    }  
    status()  
    {  
    if [ -f $PID_FILE ]; then  
        PID=$(cat $PID_FILE)  
        if [ -f /proc/$PID/cmdline ]; then  
            echo "FRP client is running..."  
        else  
            echo "FRP client is not running..."  
            rm -f $PID_FILE  
        fi  
    else  
        echo "FRP client is not running..."  
    fi;  
    }  
    [ -f $FRPC_File ] || exit 1  
    # See how we were called.  
    case "$1" in  
    start)  
        start  
        ;;  
    stop)  
        stop  
        ;;  
    status)  
        status  
        ;;  
    restart)  
        stop  
        sleep 3  
        start  
        ;;  
    *)  
    echo $"Usage: $0 {start|stop|status|restart}"  
    exit 1  
    esac  
    exit 0  

systemd

frpc.service 放到 /lib/systemd/system 后,执行以下命令就可以了:

  1. 重载命令:systemctl daemon-reload
  2. 添加开机启动:systemctl enable frpc
  3. 启动 frpc: systemctl start frpc
  4. 查看 frpc 状态: systemctl status frpc
  5. 重启 frpc : systemctl restart frpc

     1
     2
     3
     4
     5
     6
     7
     8
     9
    10
    11
    12
    13
    14
    15
    16
    17
    
    # 说明:如果是 frps 只需要修改相应的名字和路径就可以了  
    # frpc.service  
    [Unit]  
    Description=FRP Client Daemon  
    After=network.target  
    Wants=network.target  
      
    [Service]  
    Type=simple  
    # 注意修改 frpc 和 frpc.ini的路径  
    ExecStart=/usr/local/frpc/frpc -c /usr/local/frpc/frpc.ini  
    Restart=always  
    RestartSec=20s  
    User=nobody  
      
    [Install]  
    WantedBy=multi-user.target  

注意

  1. 对于暴露到外网的端口,请务必使用强密码,最好生成20位的随机密码,在线生成随机密码

  2. 实在要使用弱密码,请配合 frp 的 stcp 使用

参考:

  1. https://gist.github.com/fenying/7684afbe24f20e07201fa790aec1511c