通过自定义运营商分流或者端口分流的方式实现非旁路由方式的自动分流,并定时更新规则。实现国内ip或者指定的ip或者指定的域名列表走直连或者经过openwrt等另外处理。 爱快有简单易用的分流功能可以实现诸多功能,但是因为大家喜闻乐见的分流规则数据可能几万条,在ikuai上维护更新比较麻烦,这个工具就是为了自动从订阅地址更新爱快的分流规则的域名分流和运营商分流。
如有bug反馈和建议都可以提issues,我会尽快处理。给个star我会很开心。
关于dns部分,建议用mosdns自建,这里有一个本人维护的支持自动更新相关规则文件的mosdns的docker.[joyanhui/mosdns].可以简单自动更新dns分流解析规则,广告屏蔽,以及ipv4优先等功能
ikuai 可以通过分流规则 让国内ip直连(或其他ip范围),非国内ip指定下一跳网关通常是openwrt。再把出口流量给上游运营商。实现方式参考[#7] 或者 [恩山y2kji] 或B站网友的教程
ikuai 可以通过分流规则 把openwrt或者其他路由作为爱快的上级虚拟运营商,同时作为ikuai的下级路由,再把openwrt的出口流量绑回到爱快实际的运营商,实现无感分流:国内网站访问速度更好、不用单独配置网关、openwrt炸了不影响正常上网、openwrt恢复后网络自愈。查看具体实现方式 或者查看 恩山eezz 或者下文 分流模式的简单说明。
这种方式比传统用openwrt的作为旁路由的指定网关的方案,或者only openwrt的方案更加稳定,速度更好。 缺点是 网络top看起来有一些复杂,非开箱即用
通常是爱快+openwrt的双路由方式,ikuai可以是物理机也可以是虚拟机。openwrt同样可以是物理机也可以是虚拟机,也可以是lxc/docker也可以部署到爱快内。
ikuai需要分配3个网口(分别绑定到wan1 wan2 lan1),openwrt需要2个(wan和lan)。可以是物理网卡也可以是虚拟网卡。
-c
: 配置文件路径 默认为当前目录下config.yml
可用相对路径或者绝对路径-m
: 是否启用ip分组和下一跳网关模式(端口分流)v2.0以后版本有效
ispdomain
: 使用isp和域名分流功能(默认,为了兼容v1.x版本) ipgroup
: 使用ip分组和下一跳网关模式(端口分流) ii
: 同时使用 上面两种模式-r
: 运行模式 默认为cron
cron
: 先运行一次 而后等待计划任务触发nocron
或 once
或 1
: 忽略配置文件的cron定时配置配置 运行一次然后就直接退出结束,适合调试使用或者使用系统自带的计划任务或serverless/函数计算等方式触发。cronAft
: 先不运行等计划任务触发clean
: 清理模式 默认可选附加参数为 -tag cleanAll
exportDomainSteamToTxt
: 导出域名分流规则到txt文件模式 方便手动从爱快导入 默认可选附加参数为 -exportPath /tmp
暂时只支持域名分流功能导出,-tag
: 备注信息 clean
清理模式下的附加参数
IKUAI_BYPASS
字符的规则) IKUAI_BYPASS_
前缀 例如-r clean -tag ipcn
或 -r clean -tag IKUAI_BYPASS_ipcn
-exportPath
: 导出域名分流规则的路径-login
: ikuai登陆地址和账户密码,优先级比配置文件的优先级更高。格式: http://10.1.1.1,admin,password
为空则使用配置文件内登陆信息-delOldRule
: 删除旧规则顺序,默认为 after
after
: 先更新规则成功后再删除旧规则before
: 先删除旧规则再更新新规则,如果更新失败会丢失规则 ip分组== 正在查询 备注为: IKUAI_BYPASS_ 的ip分组规则
的bug [#24] [#27]-delOldRule
[#15] v2.0.1以后版本有效-m
参数 once
或 1
模式等同于nocron模式-tag
可以清理全部备注名包含IKUAI_BYPASS
的分流规则,或者指定备注名全程或者后缀名的分流规则 从 Releases [下载] 解压后得到一个可执行文件ikuai-bypass
和一个通用配置文件 config.yml
[参考]
编辑一下config.yml
里面ikuai的地址用户名和密码,然后在可以访问到ikuai的设备上执行命令格式如下: ./ikuai-bypass -c /配置文件路径/config.yml -r 运行模式
即可。
example:
./ikuai-bypass
等同 ./ikuai-bypass -c config.yml -r cron
: 将根据配置文件的内容更新分流规则更新成功后删除旧的分流规则 并在配置文件的cron的时间按照计划任务 重新更新。
./ikuai-bypas -r clean
等同 ./ikuai-bypass -c config.yml -r clean -tag cleanAll
: 删除所有备注包含 IKUAI_BYPASS
的规则
./ikuai-bypas -r clean -tag IKUAI_BYPASS_ipcn
等同 ./ikuai-bypas -r clean -tag ipcn
: 删除备注为 IKUAI_BYPASS_ipcn
的分流规则
下载 linux-xxx.zip,unzip 后在shell运行。 建议把ikuai-bypass作为服务安装到openwrt [参考安装脚本]
下载linux版本,参考命令如下
mkdir ~/ikuai-bypass/ && cd ~/ikuai-bypass
# 下载amd64版本,如arm版本自行修改
wget -c https://github.com/joyanhui/ikuai-bypass/releases/download/v0.2.2/ikuai-bypass-linux-amd64.zip
unzip ikuai-bypass-linux-amd64.zip
# 编辑默认的 config.yml 略
# 创建容器 docker/podman
docker run -itd --name ikuai-bypass --privileged=true --restart=always \
-v ~/ikuai-bypass/:/opt/ikuai-bypass/ \
alpine:3.18.4 /opt/ikuai-bypass/ikuai-bypass -c /opt/ikuai-bypass/config.yml -r cron
因为ikuai 无法直接执行shell命令,实在懒得给这种小工具打包镜像,尤其是基于的golang根本没有外部依赖只是一个可执行文件。
如果您要在ikuai的docker内运行。请自行下载 linux版本。解压后 上传可执行文件和配置文件 到ikuai数据盘。例如/data0/ikuai-bypass/ikuai-bypass /data0/ikuai-bypass/config.yml
而后在ikuai的docker中随便下载一个通用的linux镜像,例如 alpine:3.18.4 。创建docker 目录挂载 /data0/ikuai-bypass/
到容器内 /opt/ikuai-bypass/
启动命令修改为:
chmod +x /opt/ikuai-bypass/ikuai-bypass && /opt/ikuai-bypass/ikuai-bypass -r cron -c /opt/ikuai-bypass/config.yml
如启动失败可尝试以下命令
/opt/ikuai-bypass/ikuai-bypass -c /opt/ikuai-bypass/config.yml -r cron
请在 releases 里面点击 show all xx assets
可以看到windows的包 下载解压cmd下cd到解压后的目录运行里面的exe程序。
或许因ikuai-bypass需要获取在线数据,并使用了upx压缩,也没有另外加壳,部分杀软可能会报毒或者安全风险,[#6] 请自行决定是否信任,或者安装go环境后git clone后自行编译。我没有WIN环境,也不打算解决此类问题。
下载 darwin-arm64.zip 或者darwin-amd64.zip,unzip 后在shell运行。其他参考上文linux
v0.2.x 以后规则的备注不再只有字符IKUAI_BYPASS
,会根据tag添加指定的后缀,所以升级到0.2.x后最好清理掉旧的分流规则重新添加。
另外新版配置文件中每条规则都多了一个 tag: 备注后缀
用于区分不同的规则 [参考]
./ikuai-bypass -c /路径/config.yml -r clean -tag cleanAll # 清理所有备注名包含`IKUAI_BYPASS`的分流规则
./ikuai-bypass -c /路径/config.yml -r cron #先运行一次 而后等待计划任务触发
单网口/双网口
https://dev.leiyanhui.com/route/ikuai-bypass-joyanhui/