2025年4月12日 星期六 乙巳(蛇)年 正月十三 设为首页 加入收藏
rss
您当前的位置:首页 > 计算机 > 系统应用 > macOS

MacOS使用PF实现iptables的端口转发功能

时间:05-22来源:作者:点击数:35

准备web服务

使用Flask启动一个简单的web服务

  • from flask import Flask
  • app = Flask(__name__)
  • @app.route('/')
  • def hello_world():
  • return 'Hello World!'
  • if __name__ == '__main__':
  • app.run(port=5000)

浏览器访问:http://127.0.0.1:5000/

通过pf实现端口转发

将所有端口8080的请求,都转发到127.0.0.1:5000,类似Nginx的反向代理

1、开启IPv4 的转发

  • # 开启 IPv4 的转发
  • $ sudo sysctl -w net.inet.ip.forwarding=1
  • # 查看当前端口转发功能状态
  • sudo sysctl -a | grep forward
  • net.inet.ip.forwarding: 1
  • net.inet6.ip6.forwarding: 0

2、添加转发配置文件

  • sudo vim /etc/pf.anchors/http
  • rdr pass on lo0 inet proto tcp from any to any port 8080 -> 127.0.0.1 port 5000
  • rdr pass on en0 inet proto tcp from any to any port 8080 -> 127.0.0.1 port 5000

查看到的网络名称

  • $ ifconfig -a
  • # lo0 是本机ipv4地址 eg: 127.0.0.1
  • # en0 是局域网ipv4地址 eg: 192.168.0.100

检查正确性

  • $ sudo pfctl -vnf /etc/pf.anchors/http

3、修改pf配置文件

  • sudo vim /etc/pf.conf

增加如下配置

  • # 在 rdr-anchor "com.apple/*" 下添加
  • rdr-anchor "http-forwarding"
  • # 在 load anchor "com.apple" from "/etc/pf.anchors/com.apple" 下添加
  • load anchor "http-forwarding" from "/etc/pf.anchors/http"

重启pf服务

  • sudo pfctl -ef /etc/pf.conf

浏览器访问:http://127.0.0.1:8080/

其他命令

  • # 启用pf服务
  • $ sudo pfctl -e
  • # 强制重启PF服务
  • $ sudo pfctl -E
  • # 关闭PF
  • $ sudo pfctl -d
方便获取更多学习、工作、生活信息请关注本站微信公众号城东书院 微信服务号城东书院 微信订阅号
推荐内容
相关内容
栏目更新
栏目热门