When I first learned about DNS, I thought it couldn't be that complicated. It's just some DNS records stored on a server. What's the big deal? But textbooks only explain how DNS works, but they don't tell you how many ways DNS can break your system in practice. This isn't just a caching problem! So I posted a question on Twitter asking for DNS problems people were having, especially those that didn’t seem to have anything to do with DNS at first. (“Always DNS problems” meme) I’m not going to discuss how to solve or avoid these problems in this post, but I will include some links to places where you can find solutions to the problems. Problem: Slow network requestsIf your network is slower than expected, it's because something is causing the DNS resolver to be slow. This could be due to things like the resolver being overloaded or having a memory leak. I had this problem with my router's DNS forwarder, which made all my DNS requests very slow. I fixed it by restarting my router. Problem: DNS timeoutSome users mentioned that their network requests took more than 2 seconds or even 30 seconds due to DNS query timeouts. This is similar to the "slow network requests" issue, but worse because the DNS request will consume several seconds. Sophie Haskins has a blog post about Kubernetes DNS timeouts A Kube DNS pitfall experience. Problem: ndots settings Some netizens mentioned that there will be problems when setting Below is the If you use the above configuration file and want to query the domain name
Basically, it checks if Therefore, each time you initiate a DNS query, you have to wait until the first four queries fail before you can get the final query result. Problem: Difficulty determining the DNS resolver used by the systemThis isn't a problem in itself, but when you have DNS problems, it's usually something to do with the DNS resolver. I don't have a one-size-fits-all method for determining the DNS resolver. Here are the methods I know of:
I vaguely remember this being more confusing on MacOS, and I'm not sure why. Problem: DNS server returns NXDOMAIN instead of NOERRORThis is a problem I once encountered where Nginx could not resolve the domain name.
The problem was that the DNS server was supposed to return Having written this problem myself, I understand why this happens - it's easy to assume that "there is no record to query, so Problem: Automatic DNS cachingIf you visit a domain before the DNS record for that domain has been generated, the absence of the record will be cached. This can be quite surprising the first time you encounter it - I only learned about it last year. The cached TTL is the TTL of the domain's Start of Authority (SOA) record - for example, for Problem: Nginx caches DNS records foreverIf you use the following configuration in Nginx: Nginx will only resolve There are many well-known solutions to this problem, but since this article is not about Nginx, I am not going to go into it. But it will definitely surprise you the first time you encounter it. Here is a blog post about this issue happening with AWS load balancers. Problem: Java caches DNS records foreverA similar problem to the above, but it only occurs on Java: It is said that this is related to your Java configuration. "The default TTL setting of the JVM may cause the DNS record to be refreshed only when the JVM is restarted." I haven't encountered this problem yet, but my friends who often write Java have encountered this problem. Of course, any software can have issues with permanently caching DNS, but I've heard it often happens with Nginx and Java. Problem: Forgotten /etc/hosts records This is another caching problem: the records in What's confusing is that the Problem: Email not sent/going to spamEmail is sent and authenticated via DNS (MX records, SPF records, DKIM records), so some email issues are actually DNS issues. Problem: Invalid for internationalized domain namesYou can register domain names using non-ASCII characters or even emoticons, such as 拉屎网https://💩.la. DNS can handle internationalized domain names because Although there are standards for handling internationalized domain names in the DNS, many software do not handle internationalized domain names well. Julian Squires's Get rid of emojis in Chrome is a very interesting example. Problem: TCP DNS is blocked by the firewallSomeone mentioned that some firewalls will allow UDP on port 53, but block TCP. However, many DNS queries require TCP on port 53, which can cause intermittent problems that are difficult to troubleshoot. Problem: musl does not support TCP DNS Many applications use I'm still not sure about this, and my understanding below may be wrong:
Article about this problem: DNS resolution issues on Alpine Linux. Problem: getaddrinfo does not support round-robin DNS Round robin DNS is a load balancing technique, where each DNS query will get a different IP address. Obviously, if you use You may not realize at all that this may cause load balancing problems when you switch from This problem can be very subtle, and if you are not programming in C, these function calls are hidden behind various call libraries, and you may not be aware of the change at all. So a seemingly harmless upgrade may cause your DNS load balancing to fail. Here are some articles discussing this:
Problem: Race condition when starting the serviceSomeone mentioned a problem with Kubernetes DNS: they had two containers that started at the same time, and immediately tried to resolve each other's address. Since Kubernetes DNS had not changed, the DNS query would fail. This failure would be cached, so subsequent queries would continue to fail. Final ThoughtsI've only listed the tip of the DNS iceberg, and I'm looking forward to hearing about other issues and links that I haven't mentioned. I'd like to know how these issues actually occur and how they can be resolved. |
<<: Benefits of Fiber Optic Networks: Learn What It Is and Why It Matters
>>: Five-minute technical talk | Semantic communication technology helps build a safe countryside
There are two common I2C errors: I2C ACK error, I...
TmhHost recently launched the Hong Kong CN2 high-...
[Guangzhou, China, August 5, 2020] Huawei's &...
In March of this year, when the COVID-19 epidemic...
Today we will talk about why computer networks ar...
In today's digital economy era, it has become...
RackNerd has also released several Double 11 prom...
Patch panels are important network components tha...
The launch of 5G isn’t all that far away, with ro...
[[250378]] 1. WiFi Penetration Through Walls: Que...
Ovum said that the recent decision by 3GPP to acc...
[[255035]] On January 7, Tencent Cloud Vice Presi...
With the emergence of ChatGPT, we have entered a ...
When it comes to Bluetooth technology, most peopl...