mirror of
https://github.com/nadoo/glider.git
synced 2025-02-23 17:35:40 +08:00
doc: update README and help info
This commit is contained in:
parent
6b4d2582ca
commit
124e1a3013
36
README.md
36
README.md
@ -16,17 +16,19 @@ we can set up local listeners as proxy servers, and forward requests to internet
|
|||||||
|
|
||||||
## Features
|
## Features
|
||||||
Listen(local proxy server):
|
Listen(local proxy server):
|
||||||
- Socks5 proxy
|
- Socks5 proxy(tcp&udp)
|
||||||
- Http proxy
|
- Http proxy(tcp)
|
||||||
- SS proxy
|
- SS proxy(tcp&udp)
|
||||||
- Linux transparent proxy(iptables redirect)
|
- Linux transparent proxy(iptables redirect)
|
||||||
- TCP tunnel
|
- TCP tunnel
|
||||||
|
- UDP tunnel
|
||||||
- UDP over TCP tunnel
|
- UDP over TCP tunnel
|
||||||
|
- DNS Tunnel(udp2tcp)
|
||||||
|
|
||||||
Forward(upstream proxy server):
|
Forward(upstream proxy server):
|
||||||
- Socks5 proxy
|
- Socks5 proxy(tcp)
|
||||||
- Http proxy
|
- Http proxy(tcp)
|
||||||
- SS proxy
|
- SS proxy(tcp&udp&uot)
|
||||||
|
|
||||||
DNS Forwarding Server(udp2tcp):
|
DNS Forwarding Server(udp2tcp):
|
||||||
- Listen on UDP and forward dns requests to remote dns server in TCP via forwarders
|
- Listen on UDP and forward dns requests to remote dns server in TCP via forwarders
|
||||||
@ -48,8 +50,7 @@ General:
|
|||||||
|
|
||||||
TODO:
|
TODO:
|
||||||
|
|
||||||
- [x] UDP tunnel
|
- [ ] Socks5 UDP client
|
||||||
- [x] UDP over TCP Tunnel (client <--udp--> glider/uottun <--tcp--> glider/ss <--udp--> target)
|
|
||||||
- [ ] Transparent UDP proxy (iptables tproxy)
|
- [ ] Transparent UDP proxy (iptables tproxy)
|
||||||
- [ ] DNS Cache
|
- [ ] DNS Cache
|
||||||
- [ ] TUN/TAP device support
|
- [ ] TUN/TAP device support
|
||||||
@ -90,19 +91,27 @@ glider -config CONFIGPATH -listen :8080 -verbose
|
|||||||
|
|
||||||
## Usage
|
## Usage
|
||||||
```bash
|
```bash
|
||||||
glider v0.3.1 usage:
|
glider v0.5.0 usage:
|
||||||
-checkduration int
|
-checkduration int
|
||||||
proxy check duration(seconds) (default 30)
|
proxy check duration(seconds) (default 30)
|
||||||
-checkwebsite string
|
-checkwebsite string
|
||||||
proxy check HTTP(NOT HTTPS) website address, format: HOST[:PORT], default port: 80 (default "www.apple.com")
|
proxy check HTTP(NOT HTTPS) website address, format: HOST[:PORT], default port: 80 (default "www.apple.com")
|
||||||
-config string
|
-config string
|
||||||
config file path
|
config file path
|
||||||
|
-dns string
|
||||||
|
dns forwarder server listen address
|
||||||
|
-dnsserver value
|
||||||
|
remote dns server
|
||||||
-forward value
|
-forward value
|
||||||
forward url, format: SCHEMA://[USER|METHOD:PASSWORD@][HOST]:PORT[,SCHEMA://[USER|METHOD:PASSWORD@][HOST]:PORT]
|
forward url, format: SCHEMA://[USER|METHOD:PASSWORD@][HOST]:PORT[,SCHEMA://[USER|METHOD:PASSWORD@][HOST]:PORT]
|
||||||
|
-ipset string
|
||||||
|
ipset name
|
||||||
-listen value
|
-listen value
|
||||||
listen url, format: SCHEMA://[USER|METHOD:PASSWORD@][HOST]:PORT
|
listen url, format: SCHEMA://[USER|METHOD:PASSWORD@][HOST]:PORT
|
||||||
-rulefile value
|
-rulefile value
|
||||||
rule file path
|
rule file path
|
||||||
|
-rules-dir string
|
||||||
|
rule file folder
|
||||||
-strategy string
|
-strategy string
|
||||||
forward strategy, default: rr (default "rr")
|
forward strategy, default: rr (default "rr")
|
||||||
-verbose
|
-verbose
|
||||||
@ -115,10 +124,11 @@ Available Schemas:
|
|||||||
http: http proxy
|
http: http proxy
|
||||||
redir: redirect proxy. (used on linux as a transparent proxy with iptables redirect rules)
|
redir: redirect proxy. (used on linux as a transparent proxy with iptables redirect rules)
|
||||||
tcptun: a simple tcp tunnel
|
tcptun: a simple tcp tunnel
|
||||||
|
udptun: a simple udp tunnel
|
||||||
dnstun: listen on udp port and forward all dns requests to remote dns server via forwarders(tcp)
|
dnstun: listen on udp port and forward all dns requests to remote dns server via forwarders(tcp)
|
||||||
|
|
||||||
Available schemas for different modes:
|
Available schemas for different modes:
|
||||||
listen: mixed ss socks5 http redir tcptun dnstun
|
listen: mixed ss socks5 http redir tcptun udptun dnstun
|
||||||
forward: ss socks5 http
|
forward: ss socks5 http
|
||||||
|
|
||||||
Available methods for ss:
|
Available methods for ss:
|
||||||
@ -160,6 +170,12 @@ Examples:
|
|||||||
glider -listen tcptun://:80=2.2.2.2:80 -forward ss://method:pass@1.1.1.1:8443
|
glider -listen tcptun://:80=2.2.2.2:80 -forward ss://method:pass@1.1.1.1:8443
|
||||||
-listen on :80 and forward all requests to 2.2.2.2:80 via remote ss server.
|
-listen on :80 and forward all requests to 2.2.2.2:80 via remote ss server.
|
||||||
|
|
||||||
|
glider -listen udptun://:53=8.8.8.8:53 -forward ss://method:pass@1.1.1.1:8443
|
||||||
|
-listen on :53 and forward all udp requests to 8.8.8.8:53 via remote ss server.
|
||||||
|
|
||||||
|
glider -listen uottun://:53=8.8.8.8:53 -forward ss://method:pass@1.1.1.1:8443
|
||||||
|
-listen on :53 and forward all udp requests via udp over tcp tunnel.
|
||||||
|
|
||||||
glider -listen socks5://:1080 -listen http://:8080 -forward ss://method:pass@1.1.1.1:8443
|
glider -listen socks5://:1080 -listen http://:8080 -forward ss://method:pass@1.1.1.1:8443
|
||||||
-listen on :1080 as socks5 server, :8080 as http proxy server, forward all requests via remote ss server.
|
-listen on :1080 as socks5 server, :8080 as http proxy server, forward all requests via remote ss server.
|
||||||
|
|
||||||
|
9
conf.go
9
conf.go
@ -141,11 +141,12 @@ func usage() {
|
|||||||
fmt.Fprintf(os.Stderr, " http: http proxy\n")
|
fmt.Fprintf(os.Stderr, " http: http proxy\n")
|
||||||
fmt.Fprintf(os.Stderr, " redir: redirect proxy. (used on linux as a transparent proxy with iptables redirect rules)\n")
|
fmt.Fprintf(os.Stderr, " redir: redirect proxy. (used on linux as a transparent proxy with iptables redirect rules)\n")
|
||||||
fmt.Fprintf(os.Stderr, " tcptun: a simple tcp tunnel\n")
|
fmt.Fprintf(os.Stderr, " tcptun: a simple tcp tunnel\n")
|
||||||
|
fmt.Fprintf(os.Stderr, " udptun: a simple udp tunnel\n")
|
||||||
fmt.Fprintf(os.Stderr, " dnstun: listen on udp port and forward all dns requests to remote dns server via forwarders(tcp)\n")
|
fmt.Fprintf(os.Stderr, " dnstun: listen on udp port and forward all dns requests to remote dns server via forwarders(tcp)\n")
|
||||||
fmt.Fprintf(os.Stderr, "\n")
|
fmt.Fprintf(os.Stderr, "\n")
|
||||||
|
|
||||||
fmt.Fprintf(os.Stderr, "Available schemas for different modes:\n")
|
fmt.Fprintf(os.Stderr, "Available schemas for different modes:\n")
|
||||||
fmt.Fprintf(os.Stderr, " listen: mixed ss socks5 http redir tcptun dnstun\n")
|
fmt.Fprintf(os.Stderr, " listen: mixed ss socks5 http redir tcptun udptun dnstun\n")
|
||||||
fmt.Fprintf(os.Stderr, " forward: ss socks5 http\n")
|
fmt.Fprintf(os.Stderr, " forward: ss socks5 http\n")
|
||||||
fmt.Fprintf(os.Stderr, "\n")
|
fmt.Fprintf(os.Stderr, "\n")
|
||||||
|
|
||||||
@ -192,6 +193,12 @@ func usage() {
|
|||||||
fmt.Fprintf(os.Stderr, " "+app+" -listen tcptun://:80=2.2.2.2:80 -forward ss://method:pass@1.1.1.1:8443\n")
|
fmt.Fprintf(os.Stderr, " "+app+" -listen tcptun://:80=2.2.2.2:80 -forward ss://method:pass@1.1.1.1:8443\n")
|
||||||
fmt.Fprintf(os.Stderr, " -listen on :80 and forward all requests to 2.2.2.2:80 via remote ss server.\n")
|
fmt.Fprintf(os.Stderr, " -listen on :80 and forward all requests to 2.2.2.2:80 via remote ss server.\n")
|
||||||
fmt.Fprintf(os.Stderr, "\n")
|
fmt.Fprintf(os.Stderr, "\n")
|
||||||
|
fmt.Fprintf(os.Stderr, " "+app+" -listen udptun://:53=8.8.8.8:53 -forward ss://method:pass@1.1.1.1:8443\n")
|
||||||
|
fmt.Fprintf(os.Stderr, " -listen on :53 and forward all udp requests to 8.8.8.8:53 via remote ss server.\n")
|
||||||
|
fmt.Fprintf(os.Stderr, "\n")
|
||||||
|
fmt.Fprintf(os.Stderr, " "+app+" -listen uottun://:53=8.8.8.8:53 -forward ss://method:pass@1.1.1.1:8443\n")
|
||||||
|
fmt.Fprintf(os.Stderr, " -listen on :53 and forward all udp requests via udp over tcp tunnel.\n")
|
||||||
|
fmt.Fprintf(os.Stderr, "\n")
|
||||||
fmt.Fprintf(os.Stderr, " "+app+" -listen socks5://:1080 -listen http://:8080 -forward ss://method:pass@1.1.1.1:8443\n")
|
fmt.Fprintf(os.Stderr, " "+app+" -listen socks5://:1080 -listen http://:8080 -forward ss://method:pass@1.1.1.1:8443\n")
|
||||||
fmt.Fprintf(os.Stderr, " -listen on :1080 as socks5 server, :8080 as http proxy server, forward all requests via remote ss server.\n")
|
fmt.Fprintf(os.Stderr, " -listen on :1080 as socks5 server, :8080 as http proxy server, forward all requests via remote ss server.\n")
|
||||||
fmt.Fprintf(os.Stderr, "\n")
|
fmt.Fprintf(os.Stderr, "\n")
|
||||||
|
Loading…
Reference in New Issue
Block a user