我为DNS解析构建了一个小帮助类:
public class DNSService {
private static Properties env;
private static final String CNAME_ATTRIB = "CNAME";
private static String[] CNAME_ATTRIBS = { CNAME_ATTRIB };
static {
env = new Properties();
env.put(Context.INITIAL_CONTEXT_FACTORY, "com.sun.jndi.dns.DnsContextFactory");
}
public static String getCNAME(String host) throws NamingException {
return getCNAME(new InitialDirContext(env), host);
}
private static String getCNAME(InitialDirContext idc, String host) throws NamingException {
String cname = host;
Attributes attrs = idc.getAttributes(host, CNAME_ATTRIBS);
Attribute attr = attrs.get(CNAME_ATTRIB);
if (attr != null) {
int count = attr.size();
if (count == 1) {
cname = getCNAME(idc, (String) attr.get(0));
} else {
StringBuilder sb = new StringBuilder();
for (int i = 0; i < count; i++) {
sb.append("-> " + attr.get(i) + "\n");
}
throw new NamingException("Unexpected count while looking for CNAME of " + host + ". Expected 1. Got " + count + ".\n"
+ sb.toString());
}
}
return cname;
}
}
此类由不同的线程使用。但是,这个类产生的结果在两个线程调用之间略有不同。
例如,在我得到这些结果的同一天:
<Date> <Hour> <Thread Name> <Host> <Canonical Name>
02/12/2012 09:51 thread-1 www.site.com www.site.com
02/12/2012 12:06 thread-2 www.site.com time.microsoft.akadns.net.
为什么我会使用time.microsoft.akadns.net.
获得最终的规范名称?
有时第二次调用可以获得多个这样的规范名称:
qq.com.edgesuite.net.
a1574.b.akamai.net.
为什么两次通话之间的结果如此不同?为什么每次通话都没有一个CNAME?
答案 0 :(得分:1)
也许主机使用DNS解析作为一种负载平衡?例如,请查看亚马逊的官方文档:
http://aws.amazon.com/en/route53/faqs/
它谈论WRR和Elastic Load Balance。也许你的数据混合了一些负载平衡,根据负载考虑因素解决你对不同后端的请求,这就是你得到不同答案的原因