-
-
Notifications
You must be signed in to change notification settings - Fork 2.8k
TUN 模式
对于不遵循系统代理的软件,TUN 模式可以接管其流量并交由 CFW 处理,在 Windows 中,TUN 模式性能比 TAP 模式好
注意
近期大部分浏览器默认已经开启“安全 DNS”功能,此功能会影响 TUN 模式劫持 DNS 请求导致反推域名失败,请在浏览器设置中关闭此功能以保证 TUN 模式正常运行
启动 TUN 模式需要进行如下操作:
-
点击
General
中Service Mode
右边Manage
,在打开窗口中安装服务模式,安装完成应用会自动重启,Service Mode 右边地球图标变为绿色
即安装成功(无法安装参考:这里) -
点击
General
中TUN Mode
右边开关启动 TUN 模式
NOTICE
如果使用system作为 TUN stack,需要同时在系统防火墙中将 clash core 放行,方法如下:
在0.19.27及以上版本中,点击 Clash Core 版本号前的图标,并在 UAC 弹窗(若有)中允许运行,CFW 将自动配置对应的防火墙规则。
成功配置防火墙规则后该图标作为指示灯亮起。
在 Scoop (opens new window)版上使用此功能需要
0.20.3
及以上版本,并且每次更新 CFW 后都需要更新防火墙规则。如果要通过 Scoop 安装脚本实现自动更新规则,可以参考:manifest (opens new window) script
NOTICE
由于查询防火墙权限受限等原因,指示灯可能无法正常工作,请以系统防火墙列表及 Clash 网卡运行状态为准。
这里提供一个可用于自查的 PowerShell 脚本(可能需要管理员权限):
#Requires -Version 3 #Requires -Modules NetSecurity $List = Get-NetFirewallRule -Enabled True -Action Allow -Description 'Work with Clash for Windows.' | Where-Object { > 'Clash Core' -eq $_.DisplayName } $Report = foreach ($Rule in $List) { $Program = (Get-NetFirewallApplicationFilter -AssociatedNetFirewallRule $Rule).Program [pscustomobject] @{ Enabled = $Rule.Enabled Action = $Rule.Action Protocol = (Get-NetFirewallPortFilter -AssociatedNetFirewallRule $Rule).Protocol Program = $Program IsPathValid = Test-Path -PathType Leaf -LiteralPath $Program } } $Report Pause
以 x86-64 版本为例,如果输出类似以下内容,那么规则添加成功(请自行验证 Program 路径的有效性):
Enabled : True Action : Allow Protocol : TCP Program : C:\Program Files\Clash for Windows\resources\static\files\win\x64\clash-win64.exe IsPathValid : True Enabled : True Action : Allow Protocol : UDP Program : C:\Program Files\Clash for Windows\resources\static\files\win\x64\clash-win64.exe IsPathValid : True
启动 TUN 模式需要进行如下操作:
- 点击
General
中Service Mode
右边Manage
,在打开窗口中安装服务模式,安装完成应用会自动重启,Service Mode 右边地球图标变为绿色
即安装成功 - 点击
General
中TUN Mode
右边开关启动 TUN 模式
TIP
若要将此 Mac 设置为代理网关,打开 IP 转发即可:
sudo sysctl -w net.inet.ip.forwarding=1
这种做法将在机器下次重启后失效,如果想要永久保存,编辑文件
/etc/sysctl.conf
,配置下面变量:net.inet.ip.forwarding=1 net.inet6.ip6.forwarding=1
或者使用 LaunchDaemons 进行配置:
- 新建
network.forwarding.plist
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd"> <plist version="1.0"> <dict> <key>Label</key> <string>Network Forwarding</string> <key>UserName</key> <string>root</string> <key>GroupName</key> <string>wheel</string> <key>ProgramArguments</key> <array> <string>/usr/sbin/sysctl</string> <string>-w</string> <string>net.inet.ip.forwarding=1</string> <string>net.inet6.ip6.forwarding=1</string> </array> <key>KeepAlive</key> <false/> <key>RunAtLoad</key> <true/> </dict> </plist>
将文件添加进
/Library/LaunchDaemons
sudo launchctl load /Library/LaunchDaemons/network.forwarding.plist
启动 TUN 模式需要进行如下操作:
-
点击
General
中Service Mode
右边Manage
,在打开窗口中安装服务模式,安装完成应用会自动重启(某些系统需要手动重启 APP),Service Mode 右边地球图标变为绿色
即安装成功 -
点击
General
中TUN Mode
右边开关启动 TUN 模式
NOTICE
如熟悉使用代码启动,也可以使用 mixin 功能进行其他配置