Skip to content

joyanhui/ikuai-bypass

Repository files navigation

iKuai Bypass

ikuai 可以通过分流规则 把openwrt或者其他路由作为爱快的上级虚拟运营商,同时作为ikuai的下级路由,再把openwrt的出口流量绑回到爱快实际的运营商,实现无感分流:国内网站访问速度更好、不用单独配置网关、openwrt炸了不影响正常上网、openwrt恢复后网络自愈。查看具体实现方式 或者查看 恩山eezz 或者下文 分流模式的简单说明。 这种方式比传统用openwrt的作为旁路由的指定网关的方案,或者only openwrt的方案更加稳定,速度更好。 缺点是 网络top看起来有一些复杂,非开箱即用
但是因为大家喜闻乐见的分流规则数据可能几万条,在ikuai上维护更新比较麻烦,这个工具就是为了自动从订阅地址更新爱快的分流规则的域名分流和运营商分流。

如有问题或建议都可以提issues,我会尽快处理。给个star我会很开心。

分流模式简单说明

通常是爱快+opensrt的双路由方式,ikuai可以是物理机也可以是虚拟机。openwrt同样可以是物理机也可以是虚拟机,也可以是lxc/docker也可以部署到爱快内。
ikuai需要分配3个网口(分别绑定到wan1 wan2 lan1),openwrt需要2个(wan和lan)。可以是物理网卡也可以是虚拟网卡。

点击这里展开查看详细图文说明 图文说明

主要修改点

  • 两个协程并发处理运营商/IP分流和域名分流,更新速度更快。
  • 更新成功后再删除旧规则,原版会先删除,如果更新失败就全部丢了,这也是自己下手修改的主要原因。
  • 支持清理模式,单次更新模式,先更新一次再等计划任务触发模式,等待计划任务触发模式。
  • 支持域名分流规则直接导出为爱快可导入的txt格式 [#5]
  • 支持无docker运行,当然也支持docker运行。
  • 编译了 linux macos windows freebsd 系统下arm5-7 arm64 mipsle mips64le ppc64le amd64 386 架构二进制,当然也支持openwrt、老毛子和有shell权限其他系统。

参数说明

  • -c : 配置文件路径 默认为config.yml 可用相对路径或者绝对路径
  • -r : 运行模式 默认为cron
    • cron : 先运行一次 而后等待计划任务触发
    • nocrononce1: 忽略配置文件的cron定时配置配置 运行一次然后就退出结束
    • cronAft : 先不运行等计划任务触发
    • clean : 清理模式 默认可选附加参数为 -tag cleanAll
    • exportDomainSteamToTxt : 导出域名分流规则到txt文件模式 方便手动从爱快导入 默认可选附加参数为 -exportPath /tmp
  • -tag : 备注信息 清理模式下的附加参数
    • 默认为cleanAll(即清理所有备注中包含IKUAI_BYPASS字符的规则)
    • 单独指定备注的关键词 可以不添写IKUAI_BYPASS_前缀 例如-r clean -tag ipcn-r clean -tag IKUAI_BYPASS_ipcn
  • -exportPath : 导出域名分流规则的路径

更新日志

  • 2024-03-23 增加域名分流规则导出为爱快兼容的可导入的txt文件 [5#2016320900]
  • 2024-03-23 尝试修复列表太多导致爱快处理超时的问题 [#5]
  • 2024-03-07 openwrt服务安装脚本增加无代理环境安装
  • 2024-02-25 增加去广告功能演示规则 [参考]
  • 2024-02-7 添加一个openwrt下开机自动运行 [参考脚本]
  • 2024-02-1 优化清理模式的提示信息,增加once1模式等同于nocron模式
  • 2024-02-1 某一分组规则更新失败导致相关的旧规则被删除的bug [#3]
  • 2024-02-1 清理模式增加附加参数-tag 可以清理全部备注名包含IKUAI_BYPASS的分流规则,或者指定备注名全程或者后缀名的分流规则
  • 旧的更新记录没啥价值也未单独记,小工具代码简单,请参考commit记录

todo list

  • 在性能受限制的爱快上域名分流过多导致爱快接口超时,进一步导致ikuai-bypass出错的bug [#5]

简要使用说明

从 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(推荐openwrt内直接运行)

下载 linux-xxx.zip,unzip 后在shell运行。 建议把ikuai-bypass作为服务安装到openwrt [参考安装脚本]

docker

下载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 docker下

因为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

windows

请在 releases 里面点击 show all xx assets 可以看到windows的包 下载解压cmd下cd到解压后的目录运行里面的exe程序。
或许因ikuai-bypass需要获取在线数据,并使用了upx压缩,也没有另外加壳,部分杀软可能会报毒或者安全风险,[#6] 请自行决定是否信任,或者安装go环境后git clone后自行编译。我没有WIN环境,也不打算解决此类问题。

macos下

下载 darwin-arm64.zip 或者darwin-amd64.zip,unzip 后在shell运行。其他参考上文linux

v0.1.15 升级0.2版

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 #先运行一次 而后等待计划任务触发 

我自用过的环境

单网口/双网口

  • pve宿主 kvm 运行ikuai,然后opewrt在kvm/lxc下,ikuai-bypass 部署在openwrt。
  • windows宿主 + vmware 桥接网卡爱快 ,openwrt在vmware的ikuai内的vm内,ikuai-bypass 部署在openwrt。
  • windows宿主 + hyperv 桥接网卡爱快,openwrt在vbox的ikuai内的vm内,ikuai-bypass 使用instsrv+srvany部署到windows。
  • nixos宿主 + virtualbox 桥接网卡爱快,openwrt在vbox的ikuai内的vm内,ikuai-bypass 部署在openwrt。

其他相关说明

https://dev.leiyanhui.com/route/ikuai-bypass-joyanhui/

致谢

About

爱快分流规则维护:更完善更灵活的方式,自动或定时将通用在线规则整理到到爱快的自定义运营商、域名分流、广告屏蔽等

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published