更新时间:2022-04-12 13:36:16
Regular resolution of domain name is based on the DNS protocol, and the local DNS server will resolve the domain into a real server address. The resolution relies completely on the local DNS servers, which are vulnerable to hijacking from ISPs or attackers. In terms of scheduling, CDN providers identify the locations and the corresponding ISPs based on the local DNS IP, which is not the real user IP and is of low accuracy.
In response to this situation, CDNetworks rolls out HTTPDNS to resolve domains using CDNetworks HTTPDNS clusters instead of local DNS servers, effectively preventing DNS hijacking. The scheduling is based on real user IP, so it is of higher accuracy.
It is applicable to scenarios in which anti-hijacking and scheduling accuracy are needed.
HTTPDNS transmits resolution results over HTTP instead of the traditional DNS protocol, effectively circumventing the hijack and malfunction in the DNS layer. A client launches a request of “DNS query” to CDNetworks HTTPDNS clusters, and CDNetworks HTTPDNS clusters will search the DNS result in the CDN internal scheduling system (which is Global System Load Balancing to be accurate) based on the domain and the IP information carried in the request, and then respond the client the with optimum PoP IP address. After the client gets the best PoP IP address, it will send the HTTP request to the optimum PoP IP address.
Figure 1 Workflow of HTTPDNS
The HTTPDNS service can only be used by customers who have their own terminals, and the HTTPDNS SDK needs to be installed in user’s terminals to replace the DNS request. The HTTP DNS feature can be realized in two methods:
1) If the client initiates a HTTP request:
The request URL includes: the accelerated domain to be queried for + end-user IP address.
URL in the form of:
curl “http://server ip/v1/httpdns/clouddns?ws_domain= www.example.com &ws_ret_type=json&ws_cli_IP=1.1.1.1 "
server IP: The CDNetworks HTTPDNS cluster IP address, and we use anycast IP:220.242.54.8 abroad;
ws_domain: The domain requested by the end-user;
ws_cli_IP: The client IP address, which can be left empty. (If it is empty, HTTPDNS will automatically obtain the connection IP as the client IP.)
ws_ret_type: The format of return packets. If the parameter value is json, then the return packet is in the json format, and return traditional IP TTL format if the request does not carry the parameter.
2) If the client initiates a HTTPS request:
URL in the form of:
curl –H “host: edge.wshttpdns.com” "https://[server IP/server domain name]/v1/httpdns/ws_domain=www.example.com& ws_ret_type=json&ws_cli_IP=1.1.1.1" –k
Host: Customers must host to our server address: “edge.wshttpdns.com”
Server IP: The CDNetworks HTTPDNS cluster IP address, we use anycast IP:220.242.54.8 abroad;
ws_domain: The domain requested by the end-user;
ws_cli_IP: The client IP address, which can be left empty. (If it is empty, HTTPDNS will automatically obtain the connection IP as the client IP.)
ws_ret_type: The format of return packets. If the parameter value is json, then the return packet is in json format; if the request does not carry the parameter, the return packets will be in the traditional IP TTL format.
Besides, CDNetworks HTTPDNS supports a multi-domain query, which means multiple domain requests can be made through the same HTTPDNS request (the requested domains are separated by the semicolon). And the response will be the A records of these domains. The HTTP request URL format is as follows: http://service IP/?ws_domain=www. example1.com;www. example2.com&ws_ret_type=json