在 Mac 和 Linux 上部署 frp, 实现内网穿透
在 Mac 和 Linux 上部署 frp, 来实现内网穿透, 使得外网可以访问内网的服务, 例如家里的 NAS, 服务器等等.
frp 是一个快速反向代理, 可以帮助您将内部网络服务暴露到公共网络, 例如家庭网络中的 NAS, 服务器等等.
首先从 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
许可证文件下载对应 frp 的服务端程序
解压缩至任一目录
修改 frps.toml
配置文件
# frps.toml
bindPort = 7000
运行 ./frps -c frps.toml
启动服务端
下载对应 frp 的客户端程序
解压缩至任一目录
修改 frpc.toml
配置文件
# 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
启动客户端
可以完全参考官方文档, 使用systemd方便地控制 frps 服务端的启动、停止、配置后台运行以及开机自启动
MAC上可以使用launchd
来配置守护进程, 使得 frpc 客户端程序在后台运行.
创建一个 plist 文件, 例如 frpc.plist
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC -//Apple Computer//DTD PLIST 1.0//EN
http://www.apple.com/DTDs/PropertyList-1.0.dtd >
<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/
系统级别sudo chown root ~/Library/LaunchAgents/frpc.plist
launchctl load -w ~/Library/LaunchAgents/frpc.plist
launchctl start frpc
launchctl list | grep frpc
或者打开mac monitor查看是否有frpc
进程
launchctl stop frpc # 停止服务
launchctl unload ~/Library/LaunchAgents/frpc.plist # 卸载服务
文章作者: Alan Zeng
原始链接: https://alanzeng.com/blogs/47620/
版权说明:本博客所有文章除特别声明外,均采用 BY-NC-SA 4.0许可协议。获得许可后,要求转载时注明文章出处和网站链接,谢谢!