This article has multiple issues. Please helpimprove it or discuss these issues on thetalk page.(Learn how and when to remove these messages) (Learn how and when to remove this message)
|
NetBIOS (/ˈnɛtbaɪɒs/) is an acronym forNetwork Basic Input/Output System. It provides services related to thesession layer of theOSI model, allowing applications on separate computers to communicate over alocal area network. As strictly anAPI, NetBIOS is not anetworking protocol.Operating systems of the 1980s (DOS and Novell Netware primarily) ran NetBIOS overIEEE 802.2 andIPX/SPX using the NetBIOS Frames (NBF) andNetBIOS over IPX/SPX (NBX) protocols, respectively. In modern networks, NetBIOS normally runs overTCP/IP via theNetBIOS over TCP/IP (NBT) protocol. NetBIOS is also used for identifying system names in TCP/IP (Windows).
The NetBIOS Frames protocol is most commonly used as one of the layers ofMicrosoft Windows networking in the 1990s. NBF or NetBIOS overIEEE 802.2LLC is used by a number of network operating systems released in the 1990s, such asLAN Manager,LAN Server,Windows for Workgroups,Windows 95 andWindows NT. Other protocols, such as NBT (NetBIOS over TCP/IP), and NBX (NetBIOS-over-IPX/SPX) also implement the NetBIOS/NetBEUI services over other protocol suites.
NetBIOS is an operating system-level API that allows applications on computers to communicate with one another over alocal area network (LAN). The API was created in 1983 bySytek Inc. for software communication overIBM PC Network LAN technology.[1][2]: 1-1 On IBM PC Network, as an API alone, NetBIOS relied on proprietary Sytek networking protocols for communication over the wire.[3][2]: 1-1
In 1985, IBM went forward with theToken Ring network scheme and produced anemulator of Sytek's NetBIOS API to allow NetBIOS-aware applications from the PC-Network era to work over IBM's new Token Ring hardware.[2]: 1-1 This IBM emulator, named NetBIOS Extended User Interface (NetBEUI),[2]: 2-2 expanded the base NetBIOS API created by Sytek with, among other things, the ability to deal with the greater node capacity of Token Ring.[2]: 2-17 A new networking protocol, NetBIOS Frames (NBF), was simultaneously produced by IBM to allow the NetBEUI API to provide its services over Token Ring – specifically, at theIEEE 802.2Logical Link Control layer; it uses 802.2 type 1 mode to provide the NetBIOS/NetBEUI name service anddatagram service, and 802.2 type 2 mode to provide the NetBIOS/NetBEUI session service (virtual circuit).[2]: 3-8–3-10
In 1985,Microsoft created its own implementation of the NetBIOS API for itsMS-Net networking technology. As in the case of IBM's Token Ring, the services of Microsoft's NetBIOS implementation were provided over the IEEE 802.2 Logical Link Control layer by the NBF protocol.[4] However, the MS-Net was only delivered toOEMs, and it was actually not a complete product, nor was it ready to communicate on the network in the form it was distributed. It lacked any implementation ofOSI Layers 1 to 4 (Physical,Data link,Network andTransport Layers) and an OEM was expected to provide these implementations (in the form of a NetBIOS part) to make its version of MS-Net a complete and ready to use product. MS-Net accessed the network through Microsoft's own variant of NetBIOS, which was split into two parts - the lower level part that OEMs had to provide, implemented the NetBIOS calls that depended on layers 1-4, while the higher level part, provided by Microsoft, was hardware- and protocol-independent. This NetBIOS implementation supported the full NetBIOS API, but was called by invokingx86 interrupt 0x2A, instead of IBM's standard interrupt 0x5C. The reliance on OEMs to implement parts of NetBIOS had the unfortunate side effect that different OEM versions of MS-Net and NetBIOS generally weren't able to communicate with one another.[5]
In 1986,Novell released AdvancedNovell NetWare 2.0, featuring the company's own emulation of the NetBIOS API. Its services were encapsulated within NetWare'sIPX/SPX protocol using theNetBIOS over IPX/SPX (NBX) protocol.
In 1987, a method of providing NetBIOS services atopTCP andUDP packets,NetBIOS over TCP/IP (NBT), was published. It was described in RFC 1001 ("Protocol Standard for a NetBIOS Service on a TCP/UDP Transport: Concepts and Methods") and RFC 1002 ("Protocol Standard for a NetBIOS Service on a TCP/UDP Transport: Detailed Specifications"). The NBT protocol was developed in order to "allow an implementation [of NetBIOS applications] to be built on virtually any type of system where the TCP/IP protocol suite is available," and to "allow NetBIOS interoperation in the Internet."
After thePS/2 computer hit the market in 1987, IBM released the PC LAN Support Program, which included a driver offering the NetBIOS API. The NBF protocol was officially supported by Microsoft on almost every version of Windows up toWindows 2000,[6] but its use has decreased quickly since the development ofNBT. Microsoft officially dropped support starting withWindows XP,[7] but it is included on the Windows XP CD-ROM and can be installed manually.[8] Windows Vista does not includeNetBEUI (means NBF) support at all, but the Windows XPNetBEUI support drivers can be used.[9]
There is some confusion between the names NetBIOS and NetBEUI. NetBEUI originated strictly as themoniker for IBM's enhanced 1985 NetBIOS emulator for Token Ring. The name NetBEUI should have died there, considering that at the time, the NetBIOS implementations by other companies were known simply as NetBIOS regardless of whether they incorporated the API extensions found in Token Ring's emulator. For MS-Net, however, Microsoft elected to name its implementation of the NBF protocol "NetBEUI" – naming its implementation of the transport protocol after IBM's enhanced version of the API.[citation needed] Consequently Microsoft file and printer sharing overEthernet often continues to be called NetBEUI, with the name NetBIOS commonly used only in reference to file and printer sharing overTCP/IP. More accurately, the former isNetBIOS Frames (NBF), and the latter isNetBIOS over TCP/IP (NBT).
Because the NBF protocol is unroutable, it can only be used to communicate with devices in the samebroadcast domain, but being bridgeable, it can also be used to communicate with network segments connected to each other viabridges. The lack of support for routable networks means that NBF is only well-suited for small to medium-sizednetworks, where it has an advantage over TCP/IP in that it requires little configuration. The NetBIOS/NetBEUI services must be implemented atop other protocols, such as IPX and TCP/IP (see above), in order to be of use in an internetwork.[10]
Since its original publication in a technical reference book from IBM, the NetBIOS API specification has become ade facto standard in the industry despite originally supporting a maximum of only 80 PCs in a LAN. This limitation was generally overcome industry-wide through the transition from NBF to NBT, under which, for example, Microsoft was able to switch toDomain Name System (DNS) for resolution of NetBIOShostnames, having formerly used the LAN segment-compartmentalized NBF protocol itself to resolve such names in Windowsclient-server networks.[1]
NetBIOS provides three distinct services:
(Note:SMB, an upper layer, is a service that runs on top of the Session Service and the Datagram service, and is not to be confused as a necessary and integral part of NetBIOS itself. It can now run atop TCP with a small adaptation layer that adds a length field to each SMB message; this is necessary because TCP only provides a byte-stream service with no notion of message boundaries.)
In order to start sessions or distribute datagrams, an application must register its NetBIOS name using the name service. NetBIOS names are 16 octets in length and vary based on the particular implementation. Frequently, the 16th octet, called the NetBIOS Suffix, designates the type of resource, and can be used to tell other applications what type of services the system offers.[citation needed] InNBT, the name service operates on UDP port 137 (TCP port 137 can also be used, but rarely is).
The name service primitives offered by NetBIOS are:
Internet Protocol Version 6 (IPv6) is not supported by the NetBIOS name resolution protocol.[11]
Datagram mode isconnectionless; the application is responsible for error detection and recovery. InNBT, the datagram service runs on UDP port 138.
The datagram service primitives offered by NetBIOS are:
Session mode lets two computers establish a connection, allows messages to span multiple packets, and provides error detection and recovery. InNBT, the session service runs on TCP port 139.
The session service primitives offered by NetBIOS are:
In the original protocol used to implement NetBIOS services on PC-Network, to establish a session, the initiating computer sends an Open request, which is answered by an Open acknowledgment. The computer that started the session will then send a Session Request packet, which will prompt either a Session Accept or Session Reject packet.
During an established session, each transmitted packet is answered by either a positive acknowledgment (ACK) or a negative acknowledgment (NAK) response. A NAK will prompt retransmission of the data. Sessions are closed by the non-initiating computer by sending a close request. The computer that started the session will reply with a close response, which prompts the final session closed packet.
When NetBIOS is run in conjunction withInternet protocols (e.g., NBT), each computer may have multiple names: one or more NetBIOS name service names and one or more Internethostnames.
A NetBIOS name is 16 ASCII characters; however, Microsoft limits the hostname to 15 characters and reserves the 16th character as a NetBIOS Suffix.[12] This suffix describes the service or name record type, such as host record, master browser record, or domain controller record or other services. The hostname (or short hostname) for a host is specified when Windows networking is installed or configured on the host; the suffixes registered are determined by the individual services supplied by the host. In order to connect to a computer running TCP/IP via its NetBIOS name, the name must be resolved to anetwork address. Today, this is usually anIP address (the NetBIOS name to IP address resolution is often done by either broadcasts or aWINS Server – NetBIOS Name Server). A computer's NetBIOS name is often the same as that computer's hostname (see below), although truncated to 15 characters, but it may also be completely different.
NetBIOS names are a sequence of alphanumeric characters. The following characters are explicitly not permitted:\/:*?"<>|. Since Windows 2000, NetBIOS names also had to comply with restrictions on DNS names: they cannot consist entirely of digits, and the hyphen ("-") or full-stop (".") characters may not appear as the first or last character. Since Windows 2000, Microsoft has advised against including any full-stop (".") characters in NetBIOS names, such that applications can use the presence of a full-stop to distinguish domain names from NetBIOS names.[12]
The WindowsLMHOSTS file provides a NetBIOS name resolution method that can be used for small networks that do not use a WINS server.
A Windows machine's NetBIOS name is not to be confused with the computer's Internet hostname (assuming that the computer is also an Internet host in addition to being a NetBIOS node, which need not necessarily be the case). Generally, a computer running Internet protocols (whether it is a Windows machine or not) usually has a hostname (also sometimes called a machine name). Originally, these names were stored in and provided by ahosts file but today most such names are part of the hierarchicalDomain Name System (DNS).
Generally, the hostname of a Windows computer is based on the NetBIOS name plus the Primary DNS Suffix, which are both set in the System Properties dialog box. There may also be connection-specific suffixes which can be viewed or changed on the DNS tab in Control Panel → Network → TCP/IP → Advanced Properties. Hostnames are used byapplications such astelnet,ftp,web browsers, etc. To connect to a computer running the TCP/IP protocol using its name, the hostname must be resolved into anIP address, typically by a DNS server. (It is also possible to operate many TCP/IP-based applications, including the three listed above, using only IP addresses, but this is not the norm.)
Under Windows, thenode type of a networkedcomputer relates to the way it resolves NetBIOS names toIP addresses. This assumes that there are any IP addresses for the NetBIOS nodes, which is assured only when NetBIOS operates over NBT; thus, node types are not a property of NetBIOS per se but of interaction between NetBIOS and TCP/IP in the Windows OS environment. There are four node types.
The node type in use is displayed by opening acommand line and typingipconfig /all.AWindows computer registry may also be configured in such a way as to display "unknown" for the node type.
The NetBIOS Suffix, alternately called the NetBIOS End Character (endchar), is the 16th character of a NetBIOS name and indicates service type for the registered name. The number of record types is limited to 255; some commonly used values are:
For unique names:
For group names:
The following table shows a brief history of NetBIOS and its related protocols.SMB was the main protocol that used NetBIOS. SMB enables Windows File and Printer Sharing.
| 7 | Application layer | Windows Chat,ClipBook Viewer,Microsoft Hearts | SMB | SMB | SMB | SMB | SMB | |
| 6 | Presentation layer | NetDDE | ||||||
| 5 | Session layer | NetBIOS (The original "Network Basic Input/Output System") | NetBIOS Frames (incorrectly labeled as "NetBEUI" in Windows) | NetBIOS over IPX/SPX | NetBIOS over TCP/IP | |||
| 4 | Transport layer | IPX/SPX | TCP/UDP | TCP/UDP | QUIC (overUDP) | |||
| 3 | Network layer | IPX | IP | IP | IP | |||
| 2 | Data link layer | IEEE 802.2 onEthernet,Token Ring | Any link that carries IPX | Any link that carries IP | Any link that carries IP | Any link that carries IP | ||
| 1 | Physical layer | IBM PC Network | Ethernet,Token Ring | |||||
| First supported | Windows for Workgroups 3.1 | Windows for Workgroups 3.1 | Windows NT 3.5 | Windows 2000 | Windows 11 (Server side requires Windows Server 2022 Datacenter: Azure Edition) | |||
| Last supported | Windows XP (requires manual install) | Windows XP | ||||||
Because the NetBIOS protocol, defined in [RFC1002], does not support the mapping between NetBIOS names and IPv6 addresses, the Remote Administrative Interface: WINS protocol applies only to IPv4 addresses. It does not apply to IPv6 addresses.