⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 rfc2782.txt

📁 著名的RFC文档,其中有一些文档是已经翻译成中文的的.
💻 TXT
📖 第 1 页 / 共 2 页
字号:
Network Working Group                                     A. GulbrandsenRequest for Comments: 2782                            Troll TechnologiesObsoletes: 2052                                                 P. VixieCategory: Standards Track                   Internet Software Consortium                                                               L. Esibov                                                         Microsoft Corp.                                                           February 2000       A DNS RR for specifying the location of services (DNS SRV)Status of this Memo   This document specifies an Internet standards track protocol for the   Internet community, and requests discussion and suggestions for   improvements.  Please refer to the current edition of the "Internet   Official Protocol Standards" (STD 1) for the standardization state   and status of this protocol.  Distribution of this memo is unlimited.Copyright Notice   Copyright (C) The Internet Society (2000).  All Rights Reserved.Abstract   This document describes a DNS RR which specifies the location of the   server(s) for a specific protocol and domain.Overview and rationale   Currently, one must either know the exact address of a server to   contact it, or broadcast a question.   The SRV RR allows administrators to use several servers for a single   domain, to move services from host to host with little fuss, and to   designate some hosts as primary servers for a service and others as   backups.   Clients ask for a specific service/protocol for a specific domain   (the word domain is used here in the strict RFC 1034 sense), and get   back the names of any available servers.   Note that where this document refers to "address records", it means A   RR's, AAAA RR's, or their most modern equivalent.Gulbrandsen, et al.         Standards Track                     [Page 1]RFC 2782                       DNS SRV RR                  February 2000Definitions   The key words "MUST", "MUST NOT", "SHOULD", "SHOULD NOT" and "MAY"   used in this document are to be interpreted as specified in [BCP 14].   Other terms used in this document are defined in the DNS   specification, RFC 1034.Applicability Statement   In general, it is expected that SRV records will be used by clients   for applications where the relevant protocol specification indicates   that clients should use the SRV record. Such specification MUST   define the symbolic name to be used in the Service field of the SRV   record as described below. It also MUST include security   considerations. Service SRV records SHOULD NOT be used in the absence   of such specification.Introductory example   If a SRV-cognizant LDAP client wants to discover a LDAP server that   supports TCP protocol and provides LDAP service for the domain   example.com., it does a lookup of      _ldap._tcp.example.com   as described in [ARM].  The example zone file near the end of this   memo contains answering RRs for an SRV query.   Note: LDAP is chosen as an example for illustrative purposes only,   and the LDAP examples used in this document should not be considered   a definitive statement on the recommended way for LDAP to use SRV   records. As described in the earlier applicability section, consult   the appropriate LDAP documents for the recommended procedures.The format of the SRV RR   Here is the format of the SRV RR, whose DNS type code is 33:        _Service._Proto.Name TTL Class SRV Priority Weight Port Target        (There is an example near the end of this document.)   Service        The symbolic name of the desired service, as defined in Assigned        Numbers [STD 2] or locally.  An underscore (_) is prepended to        the service identifier to avoid collisions with DNS labels that        occur in nature.Gulbrandsen, et al.         Standards Track                     [Page 2]RFC 2782                       DNS SRV RR                  February 2000        Some widely used services, notably POP, don't have a single        universal name.  If Assigned Numbers names the service        indicated, that name is the only name which is legal for SRV        lookups.  The Service is case insensitive.   Proto        The symbolic name of the desired protocol, with an underscore        (_) prepended to prevent collisions with DNS labels that occur        in nature.  _TCP and _UDP are at present the most useful values        for this field, though any name defined by Assigned Numbers or        locally may be used (as for Service).  The Proto is case        insensitive.   Name        The domain this RR refers to.  The SRV RR is unique in that the        name one searches for is not this name; the example near the end        shows this clearly.   TTL        Standard DNS meaning [RFC 1035].   Class        Standard DNS meaning [RFC 1035].   SRV records occur in the IN        Class.   Priority        The priority of this target host.  A client MUST attempt to        contact the target host with the lowest-numbered priority it can        reach; target hosts with the same priority SHOULD be tried in an        order defined by the weight field.  The range is 0-65535.  This        is a 16 bit unsigned integer in network byte order.   Weight        A server selection mechanism.  The weight field specifies a        relative weight for entries with the same priority. Larger        weights SHOULD be given a proportionately higher probability of        being selected. The range of this number is 0-65535.  This is a        16 bit unsigned integer in network byte order.  Domain        administrators SHOULD use Weight 0 when there isn't any server        selection to do, to make the RR easier to read for humans (less        noisy).  In the presence of records containing weights greater        than 0, records with weight 0 should have a very small chance of        being selected.        In the absence of a protocol whose specification calls for the        use of other weighting information, a client arranges the SRV        RRs of the same Priority in the order in which target hosts,Gulbrandsen, et al.         Standards Track                     [Page 3]RFC 2782                       DNS SRV RR                  February 2000        specified by the SRV RRs, will be contacted. The following        algorithm SHOULD be used to order the SRV RRs of the same        priority:        To select a target to be contacted next, arrange all SRV RRs        (that have not been ordered yet) in any order, except that all        those with weight 0 are placed at the beginning of the list.        Compute the sum of the weights of those RRs, and with each RR        associate the running sum in the selected order. Then choose a        uniform random number between 0 and the sum computed        (inclusive), and select the RR whose running sum value is the        first in the selected order which is greater than or equal to        the random number selected. The target host specified in the        selected SRV RR is the next one to be contacted by the client.        Remove this SRV RR from the set of the unordered SRV RRs and        apply the described algorithm to the unordered SRV RRs to select        the next target host.  Continue the ordering process until there        are no unordered SRV RRs.  This process is repeated for each        Priority.   Port        The port on this target host of this service.  The range is 0-        65535.  This is a 16 bit unsigned integer in network byte order.        This is often as specified in Assigned Numbers but need not be.   Target        The domain name of the target host.  There MUST be one or more        address records for this name, the name MUST NOT be an alias (in        the sense of RFC 1034 or RFC 2181).  Implementors are urged, but        not required, to return the address record(s) in the Additional        Data section.  Unless and until permitted by future standards        action, name compression is not to be used for this field.        A Target of "." means that the service is decidedly not        available at this domain.Domain administrator advice   Expecting everyone to update their client applications when the first   server publishes a SRV RR is futile (even if desirable).  Therefore   SRV would have to coexist with address record lookups for existing   protocols, and DNS administrators should try to provide address   records to support old clients:      - Where the services for a single domain are spread over several        hosts, it seems advisable to have a list of address records at        the same DNS node as the SRV RR, listing reasonable (if perhapsGulbrandsen, et al.         Standards Track                     [Page 4]RFC 2782                       DNS SRV RR                  February 2000        suboptimal) fallback hosts for Telnet, NNTP and other protocols        likely to be used with this name.  Note that some programs only        try the first address they get back from e.g. gethostbyname(),        and we don't know how widespread this behavior is.      - Where one service is provided by several hosts, one can either        provide address records for all the hosts (in which case the        round-robin mechanism, where available, will share the load        equally) or just for one (presumably the fastest).      - If a host is intended to provide a service only when the main        server(s) is/are down, it probably shouldn't be listed in        address records.      - Hosts that are referenced by backup address records must use the        port number specified in Assigned Numbers for the service.      - Designers of future protocols for which "secondary servers" is        not useful (or meaningful) may choose to not use SRV's support        for secondary servers.  Clients for such protocols may use or        ignore SRV RRs with Priority higher than the RR with the lowest        Priority for a domain.   Currently there's a practical limit of 512 bytes for DNS replies.   Until all resolvers can handle larger responses, domain   administrators are strongly advised to keep their SRV replies below   512 bytes.   All round numbers, wrote Dr. Johnson, are false, and these numbers   are very round: A reply packet has a 30-byte overhead plus the name   of the service ("_ldap._tcp.example.com" for instance); each SRV RR   adds 20 bytes plus the name of the target host; each NS RR in the NS   section is 15 bytes plus the name of the name server host; and   finally each A RR in the additional data section is 20 bytes or so,   and there are A's for each SRV and NS RR mentioned in the answer.   This size estimate is extremely crude, but shouldn't underestimate   the actual answer size by much.  If an answer may be close to the   limit, using a DNS query tool (e.g. "dig") to look at the actual   answer is a good idea.The "Weight" field   Weight, the server selection field, is not quite satisfactory, but   the actual load on typical servers changes much too quickly to be   kept around in DNS caches.  It seems to the authors that offering   administrators a way to say "this machine is three times as fast as   that one" is the best that can practically be done.Gulbrandsen, et al.         Standards Track                     [Page 5]RFC 2782                       DNS SRV RR                  February 2000   The only way the authors can see of getting a "better" load figure is   asking a separate server when the client selects a server and   contacts it.  For short-lived services an extra step in the   connection establishment seems too expensive, and for long-lived   services, the load figure may well be thrown off a minute after the   connection is established when someone else starts or finishes a   heavy job.   Note: There are currently various experiments at providing relative   network proximity estimation, available bandwidth estimation, and   similar services.  Use of the SRV record with such facilities, and in   particular the interpretation of the Weight field when these   facilities are used, is for further study.  Weight is only intended   for static, not dynamic, server selection.  Using SRV weight for   dynamic server selection would require assigning unreasonably short   TTLs to the SRV RRs, which would limit the usefulness of the DNS   caching mechanism, thus increasing overall network load and   decreasing overall reliability.  Server selection via SRV is only   intended to express static information such as "this server has a   faster CPU than that one" or "this server has a much better network   connection than that one".The Port number   Currently, the translation from service name to port number happens   at the client, often using a file such as /etc/services.   Moving this information to the DNS makes it less necessary to update   these files on every single computer of the net every time a new   service is added, and makes it possible to move standard services out   of the "root-only" port range on unix.Usage rules   A SRV-cognizant client SHOULD use this procedure to locate a list of   servers and connect to the preferred one:        Do a lookup for QNAME=_service._protocol.target, QCLASS=IN,        QTYPE=SRV.        If the reply is NOERROR, ANCOUNT>0 and there is at least one        SRV RR which specifies the requested Service and Protocol in        the reply:            If there is precisely one SRV RR, and its Target is "."            (the root domain), abort.Gulbrandsen, et al.         Standards Track                     [Page 6]

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -