PC Client -> Gateway with glider running(linux box) -> Upstream Forwarders -> Internet
- A transparent proxy server
- A dns forwarding server
- A ipset manager
so you don't need any dns server in your network.
ipset create glider hash:net
verbose=True
# as a redir proxy
listen=redir://:1081
# as a dns forwarding server
dns=:53
dnsserver=8.8.8.8:53
dnsserver=8.8.4.4:53
# specify rule files
rules-dir=rules.d
# add your forwarders
forward=http://forwarder1:8080,socks5://forwarder2:1080
forward=http://1.1.1.1:8080
strategy=rr
check=http://www.msftconnecttest.com/connecttest.txt#expect=200
# specify a different dns server(if need)
dnsserver=208.67.222.222:53
# as a ipset manager
ipset=glider
# specify destinations
include=office.list
domain=example1.com
domain=example2.com
# matches ip
ip=1.1.1.1
ip=2.2.2.2
# matches a ip net
cidr=192.168.100.0/24
cidr=172.16.100.0/24
# destinations list
domain=mycompany.com
domain=mycompany1.com
ip=4.4.4.4
ip=5.5.5.5
cidr=172.16.101.0/24
cidr=172.16.102.0/24
iptables -t nat -I PREROUTING -p tcp -m set --match-set glider dst -j REDIRECT --to-ports 1081
iptables -t nat -I OUTPUT -p tcp -m set --match-set glider dst -j REDIRECT --to-ports 1081
Set server's nameserver to glider:
echo nameserver 127.0.0.1 > /etc/resolv.conf
Use the linux server's ip as your dns server.
When client requesting to access http://example1.com (in office.rule), the whole process:
DNS Resolving:
- client sends a udp dns request to linux server, and glider will receive the request(as it listens on the default dns port :53)
- upstream dns server choice: glider will lookup it's rule config and find out the dns server to use for this domain(matched "example1.com" in office.rule, so 208.67.222.222:53 will be chosen)
- glider uses the forwarder in office.rule to ask 208.67.222.222:53 for the resolve answers(dns over proxy).
- glider updates it's office rule config, adds the resolved ip address to it.
- glider adds the resolved ip into ipset "glider", and return the dns answer to client.
Destination Accessing:
- client sends http request to the resolved ip of example1.com.
- linux gateway server will get the request.
- iptabes matches the ip in ipset "glider" and redirect this request to :1081(glider)
- glider finds the ip in office rule, and then choose a forwarder in office.rule to complete the request.