home *** CD-ROM | disk | FTP | other *** search
/ Internet Info 1997 December / Internet_Info_CD-ROM_Walnut_Creek_December_1997.iso / rfc / rfc1498 < prev    next >
Text File  |  1993-08-04  |  25KB  |  564 lines

  1.  
  2.  
  3.  
  4.  
  5.  
  6.  
  7. Network Working Group                                        J. Saltzer
  8. Request for Comments: 1498       M.I.T. Laboratory for Computer Science
  9.                                                             August 1993
  10.  
  11.  
  12.            On the Naming and Binding of Network Destinations
  13.  
  14. Status of this Memo
  15.  
  16.    This memo provides information for the Internet community.  It does
  17.    not specify an Internet standard.  Distribution of this memo is
  18.    unlimited.
  19.  
  20. Abstract
  21.  
  22.    This brief paper offers a perspective on the subject of names of
  23.    destinations in data communication networks. It suggests two ideas:
  24.    First, it is helpful to distinguish among four different kinds of
  25.    objects that may be named as the destination of a packet in a
  26.    network.  Second, the operating system concept of binding is a useful
  27.    way to describe the relations among the four kinds of objects. To
  28.    illustrate the usefulness of this approach, the paper interprets some
  29.    more subtle and confusing properties of two real-world network
  30.    systems for naming destinations.
  31.  
  32. Note
  33.  
  34.    This document was originally published in: "Local Computer Networks",
  35.    edited by P. Ravasio et al., North-Holland Publishing Company,
  36.    Amsterdam, 1982, pp. 311-317.  Copyright IFIP, 1982.  Permission is
  37.    granted by IFIP for reproduction for non-commercial purposes.
  38.    Permission to copy without fee this document is granted provided that
  39.    the copies are not made or distributed for commercial advantage, the
  40.    IFIP copyright notice and the title of the publication and its date
  41.    appear, and notice is given that copying is by permission of IFIP. To
  42.    copy otherwise, or to republish, requires a specific permission.
  43.  
  44.    This research was supported in part by the Defense Advanced Research
  45.    Projects Agency of the United States Government and monitored by the
  46.    Office of Naval Research under contract number N00014-75-C-0661.
  47.  
  48. What is the Problem?
  49.  
  50.    Despite a very helpful effort of John Shoch [1] to impose some
  51.    organization on the discussion of names, addresses, and routes to
  52.    destinations in computer networks, these discussions continue to be
  53.    more confusing than one would expect. This confusion stems sometimes
  54.    from making too tight an association between various types of network
  55.  
  56.  
  57.  
  58. Saltzer                                                         [Page 1]
  59.  
  60. RFC 1498   On the Naming and Binding of Network Destinations August 1993
  61.  
  62.  
  63.    objects and the most common form for their names.  It also stems from
  64.    trying to discuss the issues with too few well-defined concepts at
  65.    hand.  This paper tries a different approach to develop insight, by
  66.    applying a perspective that has proven helpful in the corresponding
  67.    area of computer operating systems.
  68.  
  69.    Operating systems have a similar potential for confusion concerning
  70.    names and addresses, since there are file names, unique identifiers,
  71.    virtual and real memory addresses, page numbers, block numbers, I/O
  72.    channel addresses, disk track addresses, a seemingly endless list.
  73.    But most of that potential has long been rendered harmless by
  74.    recognizing that the concept of binding provides a systematic way to
  75.    think about naming [2]. (Shoch pointed out this opportunity to
  76.    exploit the operating system concept; in this paper we make it the
  77.    central theme.) In operating systems, it was apparent very early that
  78.    there were too many different kinds of identifiers and therefore one
  79.    does not get much insight by trying to make a distinction just
  80.    between names and addresses.  It is more profitable instead to look
  81.    upon all identifiers as examples of a single phenomenon, and ask
  82.    instead "where is the context in which a binding for this name (or
  83.    address, or indentifier, or whatever) will be found?", and "to what
  84.    object, identified by what kind of name, is it therein bound?"  This
  85.    same approach is equally workable in data communications networks.
  86.  
  87.    To start with, let us review Shoch's suggested terminology in its
  88.    broadest form:
  89.  
  90.         -  a name identifies what you want,
  91.         -  an address identifies where it is, and
  92.         -  an route identifies a way to get there.
  93.  
  94.    There will be no need to tamper with these definitions, but it will
  95.    be seen that they will leave a lot of room for interpretation.
  96.    Shoch's suggestion implies that there are three abstract concepts
  97.    that together provide an intellectual cover for discussion. In this
  98.    paper, we propose that a more mechanical view may lead to an easier-
  99.    to-think-with set of concepts. This more mechanical view starts by
  100.    listing the kinds of things one finds in a communication network.
  101.  
  102. Types of Network Destinations, and Bindings Among Them
  103.  
  104.    In a data communication network, when thinking about how to describe
  105.    the destination of a packet, there are several types of things for
  106.    which there are more than one instance, so one attaches names to them
  107.    to distinguish one instance from another. Of these several types,
  108.    four turn up quite often:
  109.  
  110.  
  111.  
  112.  
  113.  
  114. Saltzer                                                         [Page 2]
  115.  
  116. RFC 1498   On the Naming and Binding of Network Destinations August 1993
  117.  
  118.  
  119.     1. Service and Users. These are the functions that one uses, and
  120.        the clients that use them. Examples of services are one that
  121.        tells the time of day, one that performs accounting, or one
  122.        that forwards packets. An example of a client is a particular
  123.        desktop computer.
  124.  
  125.     2. Nodes. These are computers that can run services or user
  126.        programs. Some nodes are clients of the network, while others
  127.        help implement the network by running forwarding services.
  128.        (We will not need to distinguish between these two kinds of
  129.        nodes.)
  130.  
  131.     3. Network attachment points. These are the ports of a network, the
  132.        places where a node is attached. In many discussions about data
  133.        communication networks, the term "address" is an identifier of a
  134.        network attachment point.
  135.  
  136.     4. Paths. These run between network attachment points, traversing
  137.        forwarding nodes and communication links.
  138.  
  139.    We might note that our first step, the listing and characterization
  140.    of the objects of discussion, is borrowed from the world of abstract
  141.    data types. Our second step is to make two observations about the
  142.    naming of network objects, the first about form and the second about
  143.    bindings.
  144.  
  145.    First, one is free to choose any form of name that seems helpful --
  146.    binary identifiers, printable character strings, or whatever, and
  147.    they may be chosen from either a flat or hierarchical name space.
  148.    There may be more than one form of name for a single type of object.
  149.    A node might, for example, have both a hierarchical character string
  150.    name and a unique binary identifier.  There are two semantic traps
  151.    that one can fall into related to name form.  First, the word "name"
  152.    is, in the network world, usually associated with a printable
  153.    character string, while the word "address" is usually associated with
  154.    machine-interpretable binary strings. In the world of systems and
  155.    languages, the term "print name" is commonly used for the first and
  156.    "machine name" or "address" for the second, while "name" broadly
  157.    encompasses both forms. (In this paper we are using the broad meaning
  158.    of "name".)  The second semantic trap is to associate some
  159.    conventional form of name for a particular type of object as a
  160.    property of that type. For example, services might be named by
  161.    character strings, nodes by unique ID's, and network attachment
  162.    points named by hierarchical addresses.  When one participant in a
  163.    discussion assumes a particular name form is invariably associated
  164.    with a particular type of object and another doesn't, the resulting
  165.    conversation can be very puzzling to all participants.
  166.  
  167.  
  168.  
  169.  
  170. Saltzer                                                         [Page 3]
  171.  
  172. RFC 1498   On the Naming and Binding of Network Destinations August 1993
  173.  
  174.  
  175.    The second observation about the four types of network objects listed
  176.    above is that most of the naming requirements in a network can simply
  177.    and concisely be described in terms of bindings and changes of
  178.    bindings among the four types of objects. To wit:
  179.  
  180.     1. A given service may run at one or more nodes, and may need to move
  181.        from one node to another without losing its identity as a service.
  182.  
  183.     2. A given node may be connected to one or more network attachment
  184.        points, and may need to move from one attachment point to another
  185.        without losing its identity as a node.
  186.  
  187.     3. A given pair of attachment points may be connected by one or more
  188.        paths, and those paths may need to change with time without
  189.        affecting the identity of the attachment points.
  190.  
  191.    (This summary of network naming requirements is intentionally brief.
  192.    An excellent in-depth review of these requirements can be found in a
  193.    recent paper by Sunshine [3].)
  194.  
  195.    Each of these three requirements includes the idea of preserving
  196.    identity, whether of service, node or attachment point. To preserve
  197.    an identity, one must arrange that the name used for identification
  198.    not change during moves of the kind required. If the associations
  199.    among services, nodes, attachment points and routes are maintained as
  200.    lists of bindings this goal can easily be met. Whether or not all the
  201.    flexibility implied by these possibilities should be provided in a
  202.    particular network design is a matter of engineering judgment. A
  203.    judgment that a particular binding can be made at network design time
  204.    and will never need to be changed (e.g., a particular service might
  205.    always run at a particular node) should not be allowed to confuse the
  206.    question of what names and bindings are in principle present. In
  207.    principle, to send a data packet to a service one must discover three
  208.    bindings:
  209.  
  210.     1. find a node on which the required service operates,
  211.  
  212.     2. find a network attachment point to which that node is connected,
  213.  
  214.     3. find a path from this attachment point to that attachment point.
  215.  
  216.    There are, in turn, three conceptually distinct binding services that
  217.    the network needs to provide:
  218.  
  219.     1. Service name resolution, to identify the nodes that run the
  220.        service.
  221.  
  222.     2. Node name location, to identify attachment points that reach the
  223.  
  224.  
  225.  
  226. Saltzer                                                         [Page 4]
  227.  
  228. RFC 1498   On the Naming and Binding of Network Destinations August 1993
  229.  
  230.  
  231.        nodes found in 1.
  232.  
  233.     3. Route service, to identify the paths that lead from the
  234.        requestor's attachment point to the ones found in 2.
  235.  
  236.    At each level of binding, there can be several alternatives, so a
  237.    choice of which node, which attachment point, and which path must be
  238.    made. These choices are distinct, but can interact. For example, one
  239.    might chose the node only after first looking over the various paths
  240.    leading to the possible choices. In this case, the network tables may
  241.    only produce a partial binding, which means that an enquiry produces
  242.    a list of answers rather than a single one. The final binding choice
  243.    may be delayed until the last moment and recorded outside the three
  244.    binding services provided within the network.
  245.  
  246.    There is a very important subtlety about bindings that often leads
  247.    designers astray. Suppose we have recorded in a network table the
  248.    fact that the "Lockheed DIALOG Service" is running on node "5". There
  249.    are actually three different bindings involved here but only one of
  250.    these three is recorded in this table and changeable by simply
  251.    adjusting the table.
  252.  
  253.     1. The name "Lockheed DIALOG Service" is properly associate with a
  254.        specific service, management, and collection of stored files. One
  255.        does not usually reassign such a name to a different service. The
  256.        association of the name with the service is quite permanent, and
  257.        because of that permanence is not usually expressed in a single,
  258.        easily changed table.
  259.  
  260.     2. Similarly, the name "5" is assigned to a particular node on a
  261.        fairly long-term basis, without the expectation that it will
  262.        change. So that assignment is also not typically expressed in a
  263.        single, easily changed table.
  264.  
  265.     3. The fact that "DIALOG" is now operating on node "5"is the one
  266.        binding that our table does express, because we anticipate that
  267.        this association might reasonably change. The function of our
  268.        table is to allow us to express changes such as "DIALOG" is now
  269.        operating at node "6" or the "Pipe-fitting Service" is now
  270.        operating at node "5".
  271.  
  272.    The design mistake is to believe that this table allows one to give
  273.    the Lockheed DIALOG service a new name, merely by changing this table
  274.    entry. That is not the function of this table of bindings, and such a
  275.    name change is actually quite difficult to accomplish, since the
  276.    association in question is not usually expressed as a binding in a
  277.    single table. One would have to change not only this table, but also
  278.    user programs, documentation, scribbled notes and advertising copy to
  279.  
  280.  
  281.  
  282. Saltzer                                                         [Page 5]
  283.  
  284. RFC 1498   On the Naming and Binding of Network Destinations August 1993
  285.  
  286.  
  287.    accomplish such a name change.
  288.  
  289. Some Real-World Examples
  290.  
  291.    Although the ideas outlined so far seem fairly straightforward, it is
  292.    surprisingly easy to find real-world examples that pose a challenge
  293.    in interpretation. In the Xerox/DEC/Intel Ethernet [5, 6], for
  294.    example, the concept of a network attachment point is elusive,
  295.    because it collapses into the node name. A node can physical attach
  296.    to an Ethernet anywhere along it; the node brings with it a 48-bit
  297.    unique identifier that its interfaces watches for in packets passing
  298.    by. This identifier should probably be thought of as the name of a
  299.    network attachment point, even though the physical point of
  300.    attachment can be anywhere. At the same time, one can adopt a policy
  301.    that the node will supply from its own memory the 48-bit identifier
  302.    that is to be used by the Ethernet interface, so a second, equally
  303.    reasonable, view (likely to be taken elsewhere in the network in
  304.    interpreting the meaning of these identifiers) is that this 48-bit
  305.    identifier is the name of the node itself.  From a binding
  306.    perspective this way of using the Ethernet binds the node name and
  307.    the network attachment point name to be the same 48-bit unique
  308.    identifier.
  309.  
  310.    This permanent binding of node name to attachment point name has
  311.    several network management advantages:
  312.  
  313.      - a node can be moved from one physical location to another
  314.        without changing any network records.
  315.  
  316.      - one level of binding tables is omitted. This advantage is
  317.        particularly noticeable in implementing internetwork routing.
  318.  
  319.      - a node that is attached to two Ethernets can present the same
  320.        attachment point name to both networks, which simplifies
  321.        communication among internet routers and alternate path
  322.        finding.
  323.  
  324.    But permanent binding also produces a curiosity if is happens that
  325.    one wants one node to connect to two attachment points on the same
  326.    Ethernet. The curiosity arises because the only way to make the
  327.    second attachment point independently addressable by others is to
  328.    allow the node to use two different 48-bit identifiers, which means
  329.    that some other network records (the ones that interpret the ID to be
  330.    a node name) will likely be fooled into believing that there are not
  331.    one, but two nodes. To avoid this confusion, the same 48-bit
  332.    identifier could be used in both attachment points, but then there
  333.    will be no way intentionally to direct a message to one rather than
  334.    the other. One way or another, the permanent binding of attachment
  335.  
  336.  
  337.  
  338. Saltzer                                                         [Page 6]
  339.  
  340. RFC 1498   On the Naming and Binding of Network Destinations August 1993
  341.  
  342.  
  343.    point name to node name has made some function harder to accomplish,
  344.    though the overall effect of the advantages probably outweighs the
  345.    lost function in this case.
  346.  
  347.    For another example, the ARPANET NCP protocol provides character
  348.    string names that appear, from their mnemonics, to be node names or
  349.    service names, but in fact they are the names of network attachment
  350.    points [6]. Thus the character string name RADC-Multics is the name
  351.    of the network attachment point at ARPANET IMP 18, port 0, so
  352.    reattaching the node (a Honeywell 68/80 computer) to another network
  353.    attachment point requires either that the users learn a new name for
  354.    the service or else a change of tables in all other nodes.  Changing
  355.    tables superficially appears to be what rebinding is all about, but
  356.    the need to change more than one table is the tip-off that something
  357.    deeper is going on. What is actually happening is the change of the
  358.    permanent name of the network attachment point. We can see this more
  359.    clearly by noting that a parallel attachment of that Honeywell 68/80
  360.    to a second ARPANET port would be achievable only by assigning a
  361.    second character string identity; this requirement emphasizes that
  362.    the name is really of the attachment point, not the node.
  363.    Unfortunately, because of their mnemonic value, the ARPANET NCP name
  364.    mnemonics are often thought of as service names. Thus one expects
  365.    that that the Rome Air Development Center Multics service is operated
  366.    on the node reached by the name RADC-Multics.  This particular
  367.    assumption doesn't produce any surprises. But any one of the four
  368.    Digital PDP-10 computers at Bolt, Beranek and Newman can accept mail
  369.    for any of the others, as can the groups of PDP-10's at the USC
  370.    Information Sciences Institute, and at the Massachusetts Institute of
  371.    Technology. If the node to which ones tries to send mail is down, the
  372.    customer must realize that the same service is available by asking
  373.    for a different node, using what appears to be a different service
  374.    name. The need for a customer to realize that he must give a
  375.    different name to get the same service comes about because in the
  376.    ARPANET the name is not of a service that is bound to a node that is
  377.    bound to an attachment point, but rather it is directly the name of
  378.    an attachment point.
  379.  
  380.    Finally, confusion can arise because the three conceptually distinct
  381.    binding services (service name resolution, node name location, and
  382.    route dispensing) may not be mechanically distinct. There is usually
  383.    suggested only one identifiable service, a "name server". The name
  384.    server starts with a service name and returns a list of network
  385.    attachment points that can provide that service. It thereby performs
  386.    both the first and second conceptual binding services, though it may
  387.    leave to the customer the final choice of which attachment point to
  388.    use. Path choice may be accomplished by a distributed routing
  389.    algorithm that provides the final binding service without anyone
  390.    noticing it.
  391.  
  392.  
  393.  
  394. Saltzer                                                         [Page 7]
  395.  
  396. RFC 1498   On the Naming and Binding of Network Destinations August 1993
  397.  
  398.  
  399. Correspondence with Names, Addresses, and Routes
  400.  
  401.    With this model of binding among services, nodes, network attachment
  402.    points, and paths in mind, one possible interpretation of Shoch's
  403.    names, addresses and routes is as follows:
  404.  
  405.    1.  Any of the four kinds of objects (service, node, network
  406.        attachment point, and path) may have a name, though Shoch would
  407.        restrict that term to human-readable character strings.
  408.  
  409.    2.  The address of an object is a name (in the broad sense, not
  410.        Shoch's restricted sense) of the object it is bound to. Thus, an
  411.        address of a service is the name of some node that runs it. An
  412.        address of a node is the name of some network attachment point to
  413.        which it connects. An address of a network attachment point (a
  414.        concept not usually discussed) can be taken to be the name of a
  415.        path that leads to it. This interpretation captures Shoch's
  416.        meaning "An address indicates where it is," but does not very
  417.        well match Shoch's other notion that an address is a
  418.        machine-processable, rather than a human-processable form of
  419.        identification. This is probably the primary point where our
  420.        perspectives differ on which definitions provide the most clarity.
  421.  
  422.    3.  A route is a more sophisticated concept. A route to either a
  423.        network attachment point or a node is just a path, as we have
  424.        been using the term. Because a single node can run several
  425.        services at once, a route to a service consists of a path to the
  426.        network attachment point of a node that runs the service, plus
  427.        some identification of which activity within that node runs the
  428.        service (e.g., a "socket identifier" in the PUP internet [4] or
  429.        the ARPA Internet [7] protocols). But note that a route may
  430.        actually consist of a series of names, typically a list of
  431.        forwarding name nodes or attachment points and the names used by
  432.        the forwarding nodes for the paths between them.
  433.  
  434.    Whether or not one likes this particular interpretation of Shoch's
  435.    terms, it seems clear that there are more than three concepts
  436.    involved, so more than three labels are needed to discuss them.
  437.  
  438. Summary
  439.  
  440.    This paper has argued that some insight into the naming of
  441.    destinations in a network can be obtained by recognizing four kinds
  442.    of named objects at or leading to every destination (services, nodes,
  443.    attachment points, and routes) and then identifying three successive,
  444.    changeable, bindings (service to node, node to attachment point, and
  445.    attachment point to route). This perspective, modeled on analogous
  446.    successive bindings of storage management systems (file--storage
  447.  
  448.  
  449.  
  450. Saltzer                                                         [Page 8]
  451.  
  452. RFC 1498   On the Naming and Binding of Network Destinations August 1993
  453.  
  454.  
  455.    region--physical location) and virtual memories (object--segment--
  456.    page--memory block) provides a systematic explanation for some design
  457.    problems that are encountered in network naming systems.
  458.  
  459. Acknowledgements
  460.  
  461.    Discussions with David D. Clark, J. Noel Chiappa, David P. Reed, and
  462.    Danny Cohen helped clarify the reasoning used here. John F. Shoch
  463.    provided both inspiration and detailed comments, but should not be
  464.    held responsible for the result.
  465.  
  466. References
  467.  
  468.    1.  Shoch, John F., "Inter-Network Naming, Addressing, and Routing,"
  469.        IEEE Proc. COMPCON Fall 1978, pp. 72-79. Also in Thurber, K.
  470.        (ed.), Tutorial: Distributed Processor Communication
  471.        Architecture, IEEE Publ. #EHO 152-9, 1979, pp. 280-287.
  472.  
  473.    2.  Saltzer, J. H., "Naming and Binding of Objects", in: Operating
  474.        Systems, Lecture notes in Computer Science, Vol. 60, Edited by R.
  475.        Bayer, New York; Springer-Verlag, 1978.
  476.  
  477.    3.  Sunshine, Carl A., "Addressing Problems in Multi-Network
  478.        Systems", to appear in Proc. IEEE INFOCOM 82, Las Vegas, Nevada,
  479.        March 30 - April 1, 1982.
  480.  
  481.    4.  Boggs, D. R., Shoch, J. F., Taft, E. A., and Metcalfe, R. M.,
  482.        "PUP: An Internetwork Architecture", IEEE Trans. on Comm. 28, 4
  483.        (April, 1980) pp.  612-623.
  484.  
  485.    5.  (Anonymous), "The Ethernet, A Local Area Network: Data Link Layer
  486.        and Physical Layer Specifications, Version 1.0", published by
  487.        Xerox Corp., Palo Alto, Calif., Intel Corp., Sunnyvale, Calif.,
  488.        and Digital Equipment Corp., Tewksbury, Mass., September 30,
  489.        1980.
  490.  
  491.    6.  Dalal, Y. K., and Printis, R. S., "48-bit Absolute Internet and
  492.        Ethernet Host Numbers", Proc. Seventh Data Communications
  493.        Symposium, Mexico City, Mexico, October 1981, pp. 240-245.
  494.  
  495.    7.  Feinler, E., and J. Postel, Editors, "ARPANET Protocol Handbook",
  496.        SRI International, Menlo Park, Calif., January, 1978.
  497.  
  498.  
  499.  
  500.  
  501.  
  502.  
  503.  
  504.  
  505.  
  506. Saltzer                                                         [Page 9]
  507.  
  508. RFC 1498   On the Naming and Binding of Network Destinations August 1993
  509.  
  510.  
  511. Security Considerations
  512.  
  513.    Security issues are not discussed in this memo.
  514.  
  515. Author's Address
  516.  
  517.    Jerome H. Saltzer
  518.    M.I.T. Laboratory for Computer Science
  519.    545 Technology Square
  520.    Cambridge, MA 02139
  521.    U.S.A.
  522.  
  523.    Phone: (617) 253-6016
  524.    EMail: Saltzer@MIT.EDU
  525.  
  526.  
  527.  
  528.  
  529.  
  530.  
  531.  
  532.  
  533.  
  534.  
  535.  
  536.  
  537.  
  538.  
  539.  
  540.  
  541.  
  542.  
  543.  
  544.  
  545.  
  546.  
  547.  
  548.  
  549.  
  550.  
  551.  
  552.  
  553.  
  554.  
  555.  
  556.  
  557.  
  558.  
  559.  
  560.  
  561.  
  562. Saltzer                                                        [Page 10]
  563.  
  564.