This commit is contained in:
juewuy
2020-07-08 21:07:59 +08:00
2 changed files with 78 additions and 4 deletions

View File

@@ -1,2 +1,76 @@
# clash_tun-for-Miwifi
在小米AX3600/AX1800/AX5等路由器上使用clash_tun模式做透明代理
=====
PS
--
支持ss,v2ray,trojan但不支持ssr也不支持订阅需要自行编辑config.yaml以配置服务器<br>
小米路由内置的openwrt默认阉割了对tproxy的支持所以使用redir模式做透明代理时无法转发udp流量只能采用tun模式转发udp流量<br>
tun模式对udp的转发支持非常好而且延迟非常低小米官方内置的tx网游加速器其实就是使用的tun模式<br>
clash对tun模式的官方文档内容不是很完善折腾了好几天也没搞懂怎么使用真实ip模式进行透明代理故只能采用配置相对简单的fake-ip模式<br>
fake-ip模式在数据向dns查询时默认会返回例如198.18.0.x这样的虚拟ip地址故部分必须验证真实ip地址的网站或app可能会受影响<br>
系统默认的dnsmasq会强行劫持所有53端口流量所以必须修改dnsmasq的默认端口以让流量经过clash内置的dns服务以使用fake-ip模式<br>
fake-ip+tun模式的透明代理方式可能适用于大部分同样采用openwrt内核的路由器或者软路由有需求的可以自行斟酌使用<br>
使用依赖:
--
请确认路由器或设备已经开启ssh并获取root权限小米AX系列可参考https://www.right.com.cn/forum/thread-4032490-1-1.html<br>
ssh工具或telent工具例如puttybitvise<br>
scp工具如winscp内置了putty注意小米AX系列没有内置sftp服务而是内置了scp服务<br>
使用方式:
--
下载clash.zip https://github.com/juewuy/clash_tun-for-Miwifi/raw/master/clash.zip 并解压<br>
根据自己需求参考备注修改config.yaml配置文件`重要!!!`<br>
也可以自行下载或更新clash-tun模式核心文件并重命名为clash https://github.com/Dreamacro/clash/releases/tag/premium 小米AX系列都是armv7架构其他路由器请自查<br>
将clash文件夹以及内部4个文件通过winSCP上传到路由器/etc文件夹下最终应该是/etc/clash/……)<br>
在ssh中用root用户执行下方的相应命令即可理论上非root用户也可以运行请参考官方文档自行研究<br>
启用后可以通过 http://clash.razord.top 管理clash内置规则无需其他额外设置即可正常使用<br>
也可以自行配置http代理端口7890或者sock5代理端口7891速度比tun模式更快但是相对延迟可能略高<br>
```sh
#首次启用clash
mv /etc/clash/clashservice /etc/init.d/clash #将clash服务文件移动到系统目录
chmod 777 /etc/clash/clash #授予权限
chmod 777 /etc/init.d/clash #授予权限
service clash enable #启用clash开机启动
service clash start #启动clash服务
sed -i "8iport=5335" /etc/dnsmasq.conf #修改dnsmasq监听端口为5335
service dnsmasq restart #重启dnsmasq服务报错“cp: can't stat '/etc/dnsmasq.d/*'……”可无视)
```
```sh
#启用clash透明网关
service clash enable #启用clash开机启动
service clash start #启动clash服务
sed -i "8iport=5335" /etc/dnsmasq.conf #修改dnsmasq监听端口为5335
service dnsmasq restart #重启dnsmasq服务报错“cp: can't stat '/etc/dnsmasq.d/*'……”可无视)
```
```sh
#停止clash透明网关
service clash disable #禁用clash开机启动
service clash stop #停止clash服务
sed -i '/port=5335/d' /etc/dnsmasq.conf #重置dnsmasq监听端口为默认值port:53)
service dnsmasq restart #重启dnsmasq服务报错“cp: can't stat '/etc/dnsmasq.d/*'……”可无视,不放心可重启系统)
```
```sh
#卸载clash相关文件卸载前请先配合“停止clash透明网关”使用
rm -rf /etc/clash #删除clash文件夹及文件
rm /etc/init.d/clash #删除clash开机启动文件
```
已知问题:
--
a部分软件不会经过clash例如telegram可以通过设置软件内置sock5或http代理解决<br>
btun模式的CPU耗用较高速度不是很理想而且会影响全局流量所有tcp和udp流量都会经过tun虚拟网卡和clashax1800实测带宽在60M左右。不过p2p流量通常不会进入tun故下载速度应该不受影响<br>
c由于使用了clash的fake-ip模式部分网站可能会出现验证错误待确认<br>
d由于变相禁用了dnsmasq的dns解析服务且clash不支持内置hostsmiwifi.com或www.miwifi.com 无法打开路由器管理界面只能使用192.168.31.1进入app不受影响<br>
e由于同样使用了tun模式虚拟网卡clash服务可能会和小米路由器内置的tx网游加速器冲突请谨慎同时使用<br>
f不支持订阅由于clash本身不支持对v2raysstrojan等协议的订阅所以订阅只能通过更新clash的配置文件config.yaml来进行有条件的可以自行写更新脚本<br>
g不支持ssrclash官方不支持ssr而支持ssr的clashr又不支持tun……<br>
h全局模式代理无效原因不明同样的配置文件在pc端或者安卓上都可以使用全局模式怀疑是tun模式的bug
参考:
--
https://lancellc.gitbook.io/clash/start-clash/clash-tun-mode<br>
https://comzyh.gitbook.io/clash/<br>
https://h-cheung.gitlab.io/post/使用_clash_和路由表实现透明代理/<br>

View File

@@ -11,7 +11,7 @@ mode: Rule
# 设置日志输出级别 silent / info / warning / error / debug 越高越倾向于调试
log-level: info
# clash 的 RESTful API 网页调试端口
external-controller: 127.0.0.1:9090
external-controller: 0.0.0.0:9090
# RESTful API 的口令 (可选)
# secret: ""
# external-ui: clash-dashboard
@@ -102,12 +102,12 @@ proxies: #代理节点配置,参考下列规则修改
server: 9.99.99.99
port: 6666
cipher: chacha20-ietf-poly1305
password: "123"
password: "asdf1234"
#udp: true
- name: "Trojan"
type: trojan
server: tyu.abc.xyz
server: 123.abc.xyz
port: 443
password: asdf1234
skip-cert-verify: true
@@ -1592,4 +1592,4 @@ rules:
- IP-CIDR,119.28.28.28/32,DIRECT,no-resolve
# GeoIP China
- GEOIP,CN,DIRECT
- MATCH,PROXY
- MATCH,PROXY