Numerical label used to identify a network interface in an IP network
AnInternet Protocol address (IP address) is a numerical label such as192.0.2.1 that is assigned to a device connected to acomputer network that uses theInternet Protocol for communication.[1][2] IP addresses serve two main functions: network interfaceidentification, and locationaddressing.
Internet Protocol version 4 (IPv4) was the first standalone specification for the IP address, and has been in use since 1983.[2] IPv4 addresses are defined as a32-bit number, which became too small to provide enough addresses as the internet grew, leading toIPv4 address exhaustion over the 2010s. Its designated successor,IPv6, uses 128 bits for the IP address, giving it a largeraddress space.[3][4][5] AlthoughIPv6 deployment has been ongoing since the mid-2000s, both IPv4 and IPv6 are still used side-by-side as of 2025[update].
IP addresses are usually displayed in ahuman-readable notation, but systems may use them in various differentcomputer number formats.CIDR notation can also be used to designate how much of the address should be treated as a routing prefix. For example,192.0.2.1/24 indicates that 24significant bits of the address are the prefix, with the remaining 8 bits used for host addressing. This is equivalent to the historically usedsubnet mask (in this case,255.255.255.0).
Within a network, thenetwork administrator assigns an IP address to each device. Such assignments may be on astatic (fixed or permanent) ordynamic basis, depending on network practices and software features. Some jurisdictions consider IP addresses to bepersonal data.
Function
An IP address serves two principal functions: itidentifies the host, or more specifically, itsnetwork interface, and it provides the location of the host in the network, and thus, the capability of establishing a path to that host. Its role has been characterized as follows: "A name indicates what we seek. An address indicates where it is. A route indicates how to get there."[2] Theheader of eachIP packet contains the IP address of the sending host and that of the destination host.
By the early 1990s, the rapidexhaustion of IPv4 address space available for assignment toInternet service providers and end-user organizations prompted theInternet Engineering Task Force (IETF) to explore new technologies to expand addressing capability on the Internet. The result was a redesign of the Internet Protocol which became eventually known asInternet Protocol Version 6 (IPv6) in 1995.[3][4][5]IPv6 technology was in various testing stages until the mid-2000s when commercial production deployment commenced.
Today, these two versions of the Internet Protocol are in simultaneous use. Among other technical changes, each version defines the format of addresses differently. Because of the historical prevalence of IPv4, the generic termIP address typically still refers to the addresses defined by IPv4. The gap in version sequence between IPv4 and IPv6 resulted from the assignment of version 5 to the experimentalInternet Stream Protocol in 1979 which, however, was never referred to asIPv5.
Versions 1 to 9 were defined, but only 4 and 6 ever gained widespread use.Transmission Control Protocol (the protocol suite later referred to asTCP/IP) versions 1[6] and 2[7] were published in 1974 and 1977. Version 3[8] was defined in 1978, and version 3.1 is the first version in which TCP is separated from IP[9][10]. Version 6 is a synthesis of several suggested versions, version 6Simple Internet Protocol, version 7TP/IX: The Next Internet, version 8P. Internet Protocol, and version 9TCP and UDP with Bigger Addresses (TUBA).[11][12]
Subnetworks
IP networks may be divided intosubnetworks in bothIPv4 andIPv6. For this purpose, an IP address is recognized as consisting of two parts: thenetwork prefix in the high-order bits and the remaining bits called therest field,host identifier, orinterface identifier (IPv6), used for host numbering within a network.[1] Thesubnet mask orCIDR notation determines how the IP address is divided into network and host parts.
The termsubnet mask is only used within IPv4. Both IP versions however use the CIDR concept and notation. In this, the IP address is followed by a slash and the number (in decimal) of bits used for the network part, also called therouting prefix. For example, an IPv4 address and its subnet mask may be192.0.2.1 and255.255.255.0, respectively. The CIDR notation for the same IP address and subnet is192.0.2.1/24, because the first 24 bits of the IP address indicate the network and subnet.
An IPv4 address has a size of 32 bits, which limits theaddress space to4294967296 (232) addresses. Of this number, some addresses are reserved for special purposes such asprivate networks (≈18 million addresses) andmulticast addressing (≈270 million addresses).
IPv4 addresses are usually represented indot-decimal notation, consisting of four decimal numbers, each ranging from 0 to 255, separated by dots, e.g.,192.0.2.1. Each part represents a group of 8 bits (anoctet) of the address.[13] In some cases of technical writing,[specify] IPv4 addresses may be presented in varioushexadecimal,octal, orbinary representations.
Subnetting history
In the early stages of development of the Internet Protocol, the network number was always the highest order octet (most significant eight bits). Because this method allowed for only 256 networks, it soon proved inadequate as additional networks developed that were independent of the existing networks already designated by a network number. In 1981, the addressing specification was revised with the introduction ofclassful network architecture.[2]
Classful network design allowed for a larger number of individual network assignments and fine-grained subnetwork design. The first three bits of the most significant octet of an IP address were defined as theclass of the address. Three classes (A,B, andC) were defined for universalunicast addressing. Depending on the class derived, the network identification was based on octet boundary segments of the entire address. Each class used successively additional octets in the network identifier, thus reducing the possible number of hosts in the higher order classes (B andC). The following table gives an overview of this now-obsolete system.
Historical classful network architecture
Class
Leading bits
Size ofnetwork number bit field
Size ofrest bit field
Number of networks
Number of addresses per network
Start address
End address
A
0
8
24
128 (27)
16777216 (224)
0.0.0.0
127.255.255.255
B
10
16
16
16384 (214)
65536 (216)
128.0.0.0
191.255.255.255
C
110
24
8
2097152 (221)
256 (28)
192.0.0.0
223.255.255.255
Classful network design served its purpose in the startup stage of the Internet, but it lackedscalability in the face of the rapid expansion of networking in the 1990s. The class system of the address space was replaced withClassless Inter-Domain Routing (CIDR) in 1993.[citation needed] CIDR is based on variable-length subnet masking (VLSM) to allow allocation and routing based on arbitrary-length prefixes. Today, remnants of classful network concepts function only in a limited scope as the default configuration parameters of some network software and hardware components (e.g. netmask), and in the technical jargon used in network administrators' discussions.
Private addresses
Early network design, when global end-to-end connectivity was envisioned for communications with all Internet hosts, intended that IP addresses be globally unique. However, it was found that this was not always necessary as private networks developed and public address space needed to be conserved.
Computers not connected to the Internet, such as factory machines that communicate only with each other viaTCP/IP, need not have globally unique IP addresses. Today, such private networks are widely used and typically connect to the Internet withnetwork address translation (NAT), when needed.
Three non-overlapping ranges of IPv4 addresses for private networks are reserved.[14] These addresses are not routed on the Internet and thus their use need not be coordinated with an IP address registry. Any user may use any of the reserved blocks. Typically, a network administrator will divide a block into subnets; for example, manyhome routers automatically use a default address range of192.168.0.0 through192.168.0.255 (192.168.0.0/24).
Decomposition of an IPv6 address fromhexadecimal representation to its binary value
In IPv6, the address size was increased from 32 bits in IPv4 to 128 bits, thus providing up to 2128 (approximately3.403×1038) addresses. This is deemed sufficient for the foreseeable future.
The intent of the new design was not to provide just a sufficient quantity of addresses, but also redesign routing in the Internet by allowing more efficient aggregation of subnetwork routing prefixes. This resulted in slower growth ofrouting tables in routers. The smallest possible individual allocation is a subnet for 264 hosts, which is the square of the size of the entire IPv4 Internet. At these levels, actual address utilization ratios will be small on any IPv6 network segment. The new design also provides the opportunity to separate the addressing infrastructure of a network segment, i.e. the local administration of the segment's available space, from the addressing prefix used to route traffic to and from external networks. IPv6 has facilities that automatically change the routing prefix of entire networks, should the global connectivity or therouting policy change, without requiring internal redesign or manual renumbering.
The large number of IPv6 addresses allows large blocks to be assigned for specific purposes and, where appropriate, to be aggregated for efficient routing. With a large address space, there is no need to have complex address conservation methods as used in CIDR.
All modern desktop and enterprise server operating systems include native support forIPv6, but it is not yet widely deployed in other devices, such as residential networking routers,voice over IP (VoIP) and multimedia equipment, and somenetworking hardware.
Private addresses
Just as IPv4 reserves addresses for private networks, blocks of addresses are set aside in IPv6. In IPv6, these are referred to asunique local addresses (ULAs). The routing prefixfc00::/7 is reserved for this block,[15] which is divided into two/8 blocks with different implied policies. The addresses include a 40-bitpseudorandom number that minimizes the risk of address collisions if sites merge or packets are misrouted.
Early practices used a different block for this purpose (fec0::), dubbed site-local addresses.[16] However, the definition of what constituted asite remained unclear and the poorly defined addressing policy created ambiguities for routing. This address type was abandoned and must not be used in new systems.[17]
Addresses starting withfe80::, calledlink-local addresses, are assigned to interfaces for communication on the attached link. The addresses are automatically generated by the operating system for each network interface. This provides instant and automatic communication between all IPv6 hosts on a link. This feature is used in the lower layers of IPv6 network administration, such as for theNeighbor Discovery Protocol.
Private and link-local address prefixes may not be routed on the public Internet.
IP address assignment
IP addresses are assigned to a host either dynamically as they join the network, or persistently by configuration of the host hardware or software. Persistent configuration is also known as using astatic IP address. In contrast, when a computer's IP address is assigned each time it restarts, this is known as using adynamic IP address.
Dynamic IP addresses are assigned by network usingDynamic Host Configuration Protocol (DHCP).[18] DHCP is the most frequently used technology for assigning addresses. It avoids the administrative burden of assigning specific static addresses to each device on a network. It also allows devices to share the limited address space on a network if only some of them are online at a particular time. Typically, dynamic IP configuration is enabled by default in modern desktop operating systems.
The address assigned with DHCP is associated with alease and usually has an expiration period. If the lease is not renewed by the host before expiry, the address may be assigned to another device. Some DHCP implementations attempt to reassign the same IP address to a host, based on itsMAC address, each time it joins the network. A network administrator may configure DHCP by allocating specific IP addresses based on MAC address.
Computers and equipment used for the network infrastructure, such as routers and mail servers, are typically configured with static addressing.
In the absence or failure of static or dynamic address configurations, an operating system may assign a link-local address to a host using stateless address autoconfiguration.
Sticky dynamic IP address
Sticky is an informal term used to describe a dynamically assigned IP address that seldom changes.[19] IPv4 addresses, for example, are usually assigned with DHCP, and a DHCP servicecan use rules that maximize the chance of assigning the same address each time a client asks for an assignment. In IPv6, aprefix delegation can be handled similarly, to make changes as rare as feasible. In a typical home or small-office setup, a singlerouter is the only device visible to anInternet service provider (ISP), and the ISP may try to provide a configuration that is as stable as feasible, i.e.sticky. On the local network of the home or business, a local DHCP server may be designed to provide sticky IPv4 configurations, and the ISP may provide a sticky IPv6 prefix delegation, giving clients the option to use sticky IPv6 addresses.Sticky should not be confused withstatic; sticky configurations have no guarantee of stability, while static configurations are used indefinitely and only changed deliberately.
Address autoconfiguration
Address block169.254.0.0/16 is defined for the special use of link-local addressing for IPv4 networks.[20] In IPv6, every interface, whether using static or dynamic addresses, also receives a link-local address automatically in the blockfe80::/10.[20] These addresses are only valid on the link, such as a local network segment or point-to-point connection, to which a host is connected. These addresses are not routable and, like private addresses, cannot be the source or destination of packets traversing the Internet.
When the link-local IPv4 address block was reserved, no standards existed for mechanisms of address autoconfiguration. Filling the void,Microsoft developed a protocol calledAutomatic Private IP Addressing (APIPA), whose first public implementation appeared inWindows 98.[21] APIPA has been deployed on millions of machines and became ade facto standard in the industry. In May 2005, theIETF defined a formal standard for it.[22]
Addressing conflicts
An IP address conflict occurs when two devices on the same local physical or wireless network claim to have the same IP address. A second assignment of an address generally stops the IP functionality of one or both of the devices. Many modernoperating systems notify the administrator of IP address conflicts.[23][24] When IP addresses are assigned by multiple people and systems with differing methods, any of them may be at fault.[25][26][27][28][29] If one of the devices involved in the conflict is thedefault gateway access beyond the LAN for all devices on the LAN, all devices may be impaired.
Routing
IP addresses are classified into several classes of operational characteristics: unicast, multicast, anycast and broadcast addressing.
The most common concept of an IP address is inunicast addressing, available in both IPv4 and IPv6. It normally refers to a single sender or a single receiver, and can be used for both sending and receiving. Usually, a unicast address is associated with a single device or host, but a device or host may have more than one unicast address. Sending the same data to multiple unicast addresses requires the sender to send all the data many times over, once for each recipient.
Broadcast addressing
Broadcasting is an addressing technique available in IPv4 to address data to all possible destinations on a network in one transmission operation as anall-hosts broadcast. All receivers capture the network packet. The address255.255.255.255 is used for network broadcast. In addition, a more limited directed broadcast uses the all-ones host address with the network prefix. For example, the destination address used for directed broadcast to devices on the network192.0.2.0/24 is192.0.2.255.[30]
IPv6 does not implement broadcast addressing and replaces it with multicast to the specially defined all-nodes multicast address.
Multicast addressing
Amulticast address is associated with a group of interested receivers. In IPv4, addresses224.0.0.0 through239.255.255.255 (the formerClass D addresses) are designated as multicast addresses.[31] IPv6 uses the address block with the prefixff00::/8 for multicast. In either case, the sender sends a singledatagram from its unicast address to the multicast group address and the intermediary routers take care of making copies and sending them to all interested receivers (those that have joined the corresponding multicast group).
Anycast addressing
Like broadcast and multicast,anycast is a one-to-many routing topology. However, the data stream is not transmitted to all receivers, just the one which the router decides is closest in the network. Anycast addressing is a built-in feature of IPv6.[32][33] In IPv4, anycast addressing is implemented withBorder Gateway Protocol using the shortest-pathmetric to choose destinations. Anycast methods are useful for globalload balancing and are commonly used in distributedDNS systems.
A host may usegeolocation to deduce thegeographic position of its communicating peer.[34][35] This is typically done by retrieving geolocation info about the IP address of the other node from a database.[36]
Public address
A public IP address is a globally routable unicast IP address, meaning that the address is not an address reserved for use inprivate networks, such as those reserved byRFC1918, or the various IPv6 address formats of local scope or site-local scope, for example for link-local addressing. Public IP addresses may be used for communication between hosts on the global Internet.In a home situation, a public IP address is the IP address assigned to the home's network by theISP. In this case, it is also locally visible by logging into the router configuration.[37]
Most public IP addresses change relatively often. Any type of IP address that changes is called a dynamic IP address. In home networks, the ISP usually assigns a dynamic IP. If an ISP gave a home network an unchanging address, it is more likely to be abused by customers who host websites from home, or byhackers who can try the same IP address over and over until they breach a network.[37]
Multiple client devices can appear to share an IP address, either because they are part of ashared web hosting service environment or because an IPv4network address translator (NAT) orproxy server acts as anintermediary agent on behalf of the client, in which case the real originating IP address is masked from the server receiving a request. A common practice is to have a NAT mask many devices in a private network. Only the public interface(s) of the NAT needs to have an Internet-routable address.[38]
The NAT device maps different IP addresses on the private network to different TCP or UDPport numbers on the public network. In residential networks, NAT functions are usually implemented in aresidential gateway. In this scenario, the computers connected to the router have private IP addresses and the router has a public address on its external interface to communicate on the Internet. The internal computers appear to share one public IP address.
^"IPv4 and IPv6 address formats".IBM.An IPv4 address has the following format: x . x . x . x where x is called an octet and must be a decimal value between 0 and 255. Octets are separated by periods. An IPv4 address must contain three periods and four octets. The following examples are valid IPv4 addresses: 1 . 2 . 3 . 4 01 . 102 . 103 . 104