<html><head></head><body style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space; "><div><span class="Apple-style-span" style="border-collapse: separate; color: rgb(0, 0, 0); font-family: Verdana; font-size: 12px; font-style: normal; font-variant: normal; font-weight: normal; letter-spacing: normal; line-height: normal; orphans: 2; text-align: auto; text-indent: 0px; text-transform: none; white-space: normal; widows: 2; word-spacing: 0px; -webkit-border-horizontal-spacing: 0px; -webkit-border-vertical-spacing: 0px; -webkit-text-decorations-in-effect: none; -webkit-text-size-adjust: auto; -webkit-text-stroke-width: 0; "><div><span class="Apple-style-span" style="font-family: Helvetica; font-size: medium; ">On Nov 16, 2009, at 11:46 PM, aihua zhang wrote:</span></div></span></div><div><br class="Apple-interchange-newline"><blockquote type="cite">HI,<div>      Thanks for your help! Now I'm analysis the lib function providing by the bind . bind software has three data format:struct format, wire format and the text format, from my understanding, it presents the RR in different three <a href="http://types.in/">types.in</a> them text format is the string type storing in the db,   but i don't understand the wire format ,is that mean the data receive from the network and storing in the buffer ? and another question is struct format using environment is what ? </div>
<div></div></blockquote><div><br></div><div>This is mostly beyond my expertise, but I guess that wire format is the binary format used in the UDP packet. Struct format probably relates to the return value of the stub resolver library functions.</div><div><div><span class="Apple-style-span" style="border-collapse: separate; color: rgb(0, 0, 0); font-family: Verdana; font-size: 12px; font-style: normal; font-variant: normal; font-weight: normal; letter-spacing: normal; line-height: normal; orphans: 2; text-indent: 0px; text-transform: none; white-space: normal; widows: 2; word-spacing: 0px; -webkit-border-horizontal-spacing: 0px; -webkit-border-vertical-spacing: 0px; -webkit-text-decorations-in-effect: none; -webkit-text-size-adjust: auto; -webkit-text-stroke-width: 0px; "><div><br></div><div>Chris Buxton</div><div>Professional Services</div><div>Men & Mice</div><div><font class="Apple-style-span" face="Helvetica"><span class="Apple-style-span" style="font-size: medium;"><font class="Apple-style-span" face="Verdana"><br></font></span></font></div></span></div></div><blockquote type="cite"><div>Best regards!<br><br><div class="gmail_quote">2009/11/17 Chris Buxton <span dir="ltr"><<a href="mailto:cbuxton@menandmice.com">cbuxton@menandmice.com</a>></span><br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex;">
<div><div></div><div class="h5">On Nov 15, 2009, at 11:35 PM, aihua zhang wrote:<br>
<br>
> HI,<br>
>       here is my understanding about the stub resolver and full resolver:<br>
>          stub resolver,used by client and independent name server. application will call the routine of the lwreslib(such as lwres_getrdatabyname()) and the lwresd will handle the request using the lightweight protcol. when lwresd received the request it will render it and  send it to the name server listed in the resolv.conf. here is my confused:<br>

>           1. I find the helper document written:"the full resolver is part of the caching name server or reolver demon the stub resolver talks to " ,  can i unstand  all request from the stub resolver handled by  the full resolver in the name server . if not which module handle this kind request<br>

>           2. if the request tackle by the full resolver , the client.h of the named module handle which type?<br>
<br>
</div></div>The job of the stub resolver is to be a DNS client. Applications on<br>
client machines use the stub resolver, typically (part of) a dynamic<br>
library of some sort, to interface with the DNS as well as other name<br>
resolution systems, such as /etc/hosts.<br>
<br>
The stub resolver in BIND 9 is, I believe, somehow based on or<br>
intertwined with lwresd. However, it is not the only stub resolver<br>
implementation out there.<br>
<br>
The job of the full resolver is to recurse through the DNS name<br>
hierarchy in response to requests. It is almost always a service that<br>
gets requests via the DNS protocol. For example, the BIND 9 name server<br>
can act as a full resolver, when configured as a caching name server.<br>
However, it's perfectly possible (but highly unusual) for the (full)<br>
resolver to replace the stub resolver, taking requests from clients via<br>
a library function call and doing its own recursion.<br>
<br>
The typical resolution process works like this:<br>
<br>
1. An application invokes the stub resolver as function call, from a<br>
   library.<br>
2. The stub resolver, possibly after consulting /etc/hosts, ldap, nis+,<br>
   etc., sends a recursive DNS query to a DNS server via the network.<br>
   If necessary, the stub resolver will retransmit the query, query<br>
   another DNS server, etc., until either it gets an answer or gives up.<br>
3. The DNS server, acting as a full resolver (a caching name server),<br>
   consults its cache and then, if necessary, performs recursion (asks<br>
   other name servers, traversing the DNS name hierarchy) in order to<br>
   find the answer.<br>
4. The caching name server (full resolver) sends an answer back to the<br>
   stub resolver in the form of a DNS message.<br>
5. The stub resolver function returns a data structure to the<br>
   application.<br>
<br>
However, again, this is only the most typical procedure. Variations are<br>
quite possible, including removing the stub resolver entirely.<br>
<font color="#888888"><br>
Chris Buxton<br>
Professional Services<br>
Men & Mice<br>
<br>
</font></blockquote></div><br><br clear="all"><br>-- <br><br><br><br>
</div>
</blockquote></div><br></body></html>