在 Mac 和 Linux 上部署 frp, 来实现内网穿透, 使得外网可以访问内网的服务, 例如家里的 NAS, 服务器等等.
什么是 frp
frp 是一个快速反向代理, 可以帮助您将内部网络服务暴露到公共网络, 例如家庭网络中的 NAS, 服务器等等.
- GitHub页面: https://github.com/fatedier/frp
- 官方文档: https://gofrp.org/docs/
- GitHub Releases: https://github.com/fatedier/frp/releases
安装 frp
首先从 frp 的 GitHub Releases 页面下载 frp 的客户端和服务端程序.
如下图:
其中
frp_0.x.x_darwin_amd64.tar.gz
是 Mac 版本的客户端程序,frp_0.x.x_linux_amd64.tar.gz
是 Linux 版本的客户端程序.
解压后包含以下文件:
frpc
客户端程序frps
服务端程序frps.toml
服务端配置文件frpc.toml
客户端配置文件LICENSE
许可证文件
服务端: 具有公网 IP 的Linux服务器
下载对应 frp 的服务端程序
解压缩至任一目录
修改
frps.toml
配置文件1
2# frps.toml
bindPort = 7000运行
./frps -c frps.toml
启动服务端
客户端: Mac
下载对应 frp 的客户端程序
解压缩至任一目录
修改
frpc.toml
配置文件1
2
3
4
5
6
7
8
9
10# frpc.toml
serverAddr = "x.x.x.x"
serverPort = 7000
[[proxies]]
name = "ssh"
type = "tcp"
localIP = "127.0.0.1"
localPort = 22
remotePort = 6000运行
./frpc -c frpc.toml
启动客户端
分别配置守护进程
服务端: Linux
可以完全参考官方文档, 使用systemd方便地控制 frps 服务端的启动、停止、配置后台运行以及开机自启动
客户端: Mac
MAC上可以使用launchd
来配置守护进程, 使得 frpc 客户端程序在后台运行.
创建一个 plist 文件, 例如
frpc.plist
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
<plist version="1.0">
<dict>
<key>Label</key>
<string>frpc</string>
<key>ProgramArguments</key>
<array>
<string>/Users/xxxx/frp/frpc</string>
<string>-c</string>
<string>/Users/xxxx/frp/frpc.toml</string>
</array>
<key>KeepAlive</key>
<true/>
<key>RunAtLoad</key>
<true/>
</dict>
</plist>其中
/Users/xxxx/frp/
为 frp 的安装目录,frpc.toml
为 frpc 的配置文件根据需求该文件存到对应目录
~/Library/LaunchAgents/
仅当前用户/Library/LaunchAgents/
所有用户/Library/LaunchDaemons/
系统级别
- 加载配置文件
1 | sudo chown root ~/Library/LaunchAgents/frpc.plist |
- 启动服务
1 | launchctl start frpc |
- 查看服务状态
1 | launchctl list | grep frpc |
或者打开mac monitor查看是否有frpc
进程
- 其他命令
1 | launchctl stop frpc # 停止服务 |