Go to file
2024-10-04 14:20:10 +08:00
.github ci: better release 2024-08-31 23:38:31 +08:00
adapter feat: add direct-nameserver and direct-nameserver-follow-policy in dns section 2024-10-04 14:20:10 +08:00
common chore: better apply tcp keepalive to listeners 2024-09-25 15:10:53 +08:00
component feat: add direct-nameserver and direct-nameserver-follow-policy in dns section 2024-10-04 14:20:10 +08:00
config feat: add direct-nameserver and direct-nameserver-follow-policy in dns section 2024-10-04 14:20:10 +08:00
constant chore: code cleanup 2024-09-27 21:42:06 +08:00
context chore: hello mihomo 2023-11-03 21:58:21 +08:00
dns feat: add direct-nameserver and direct-nameserver-follow-policy in dns section 2024-10-04 14:20:10 +08:00
docker chore: hello mihomo 2023-11-03 21:58:21 +08:00
docs feat: add direct-nameserver and direct-nameserver-follow-policy in dns section 2024-10-04 14:20:10 +08:00
hub feat: add direct-nameserver and direct-nameserver-follow-policy in dns section 2024-10-04 14:20:10 +08:00
listener chore: reset resolver's connection after default interface changed 2024-09-27 20:36:00 +08:00
log chore: some internal types support encoding.TextUnmarshaler 2024-09-19 18:36:24 +08:00
ntp fix(ntp): simplify NTP service initialization and error handling 2024-01-17 16:14:25 +08:00
rules chore: support ETag for update geo 2024-09-22 13:57:57 +08:00
test chore: drop support of eBPF 2024-08-16 14:15:36 +08:00
transport fix: hysteria1 outbound should be closed when proxy removed 2024-08-26 18:47:54 +08:00
tunnel chore: better atomic using 2024-10-02 14:45:06 +08:00
.gitignore chore: update gitignore 2023-01-14 18:10:22 +08:00
.golangci.yaml chore: hello mihomo 2023-11-03 21:58:21 +08:00
android_tz.go chore: Replace android timezone implementation 2024-03-10 02:24:28 +08:00
check_amd64.sh chore: add docker workflow 2022-04-28 14:18:54 +08:00
Dockerfile chore: reduce image size 2024-07-31 13:04:30 +08:00
flake.lock chore: update flake lock 2022-12-15 13:25:18 +08:00
flake.nix chore: hello mihomo 2023-11-03 21:58:21 +08:00
go.mod feat: add external-controller-cors can config allow-origins and allow-private-network 2024-09-29 17:13:43 +08:00
go.sum feat: add external-controller-cors can config allow-origins and allow-private-network 2024-09-29 17:13:43 +08:00
LICENSE License: use GPL 3.0 2019-10-18 11:12:35 +08:00
main.go chore: no longer used net.DefaultResolver when dns section is disabled, now is equally only "system://" 2024-10-02 14:45:06 +08:00
Makefile chore: drop support of eBPF 2024-08-16 14:15:36 +08:00
Meta.png [readme] 2021-12-09 17:54:53 +08:00
README.md Update README.md 2024-05-04 18:41:08 +08:00

Meta Kennel
Meta Kernel

Another Mihomo Kernel.

Features

  • Local HTTP/HTTPS/SOCKS server with authentication support
  • VMess, VLESS, Shadowsocks, Trojan, Snell, TUIC, Hysteria protocol support
  • Built-in DNS server that aims to minimize DNS pollution attack impact, supports DoH/DoT upstream and fake IP.
  • Rules based off domains, GEOIP, IPCIDR or Process to forward packets to different nodes
  • Remote groups allow users to implement powerful rules. Supports automatic fallback, load balancing or auto select node based off latency
  • Remote providers, allowing users to get node lists remotely instead of hard-coding in config
  • Netfilter TCP redirecting. Deploy Mihomo on your Internet gateway with iptables.
  • Comprehensive HTTP RESTful API controller

Dashboard

A web dashboard with first-class support for this project has been created; it can be checked out at metacubexd.

Configration example

Configuration example is located at /docs/config.yaml.

Docs

Documentation can be found in mihomo Docs.

For development

Requirements: Go 1.20 or newer

Build mihomo:

git clone https://github.com/MetaCubeX/mihomo.git
cd mihomo && go mod download
go build

Set go proxy if a connection to GitHub is not possible:

go env -w GOPROXY=https://goproxy.io,direct

Build with gvisor tun stack:

go build -tags with_gvisor

IPTABLES configuration

Work on Linux OS which supported iptables

# Enable the TPROXY listener
tproxy-port: 9898

iptables:
  enable: true # default is false
  inbound-interface: eth0 # detect the inbound interface, default is 'lo'

Debugging

Check wiki to get an instruction on using debug API.

Credits

License

This software is released under the GPL-3.0 license.