`
lee79
  • 浏览: 106787 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

IP Address

阅读更多

An Internet Protocol (IP) address is a numerical identification (logical address) that is assigned to devices participating in a computer network utilizing the Internet Protocol for communication between its nodes.[1] Although IP addresses are stored as binary numbers, they are usually displayed in human-readable notations, such as 208.77.188.166 (for IPv4), and 2001:db8:0:1234:0:567:1:1 (for IPv6). The role of the IP address 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]

The original designers of TCP/IP defined an IP address as a 32-bit number[1] and this system, now named Internet Protocol Version 4 (IPv4), is still in use today. However, due to the enormous growth of the Internet and the resulting depletion of the address space, a new addressing system (IPv6), using 128 bits for the address, was developed (RFC 1883).

The Internet Protocol also has the task of routing data packets between networks, and IP addresses specify the locations of the source and destination nodes in the topology of the routing system. For this purpose, some of the bits in an IP address are used to designate a subnetwork. The number of these bits is indicated in CIDR notation, appended to the IP address, e.g., 208.77.188.166/24.

With the development of private networks and the threat of IPv4 address exhaustion, a group of private address spaces was set aside by RFC 1918. These private addresses may be used by anyone on private networks. They are often used with network address translators to connect to the global public Internet.

The Internet Assigned Numbers Authority (IANA) manages the IP address space allocations globally. IANA works in cooperation with five Regional Internet Registries (RIRs) to allocate IP address blocks to Local Internet Registries (Internet service providers) and other entities.

Contents

[hide]

[edit] IP versions

The Internet Protocol (IP) has two versions currently in use (see IP version history for details). Each version has its own definition of an IP address. Because of its prevalence, the generic term IP address typically still refers to the addresses defined by IPv4.

An illustration of an IP address (version 4), in both dot-decimal notation and binary.

[edit] IP version 4 addresses

IPv4 uses 32-bit (4-byte) addresses, which limits the address space to 4,294,967,296 (232) possible unique addresses. However, IPv4 reserves some addresses for special purposes such as private networks (~18 million addresses) or multicast addresses (~270 million addresses). This reduces the number of addresses that can be allocated as public Internet addresses, and as the number of addresses available is consumed, an IPv4 address shortage appears to be inevitable in the long run. This limitation has helped stimulate the push towards IPv6, which is currently in the early stages of deployment and is currently the only offering to replace IPv4.

IPv4 addresses are usually represented in dot-decimal notation (four numbers, each ranging from 0 to 255, separated by dots, e.g. 208.77.188.166). Each part represents 8 bits of the address, and is therefore called an octet. In less common cases of technical writing, IPv4 addresses may be presented in hexadecimal, octal, or binary representations. When converting, each octet is usually treated as a separate number.

[edit] IPv4 networks

In the early stages of development of the Internet protocol,[1] network administrators interpreted an IP address as a structure of network number and host number. The highest order octet (most significant eight bits) were designating the network number, and the rest of the bits were called the rest field or host identifier and used for host numbering within a network. This method soon proved inadequate as local area networks developed that were not part of the larger networks already designated by a network number. In 1981, the Internet addressing specification was revised with the introduction of classful network architecture. [2]

Classful network design allowed for a larger number of individual assignments. The first three bits of the most significant octet of an IP address was defined as the "class" of the address, instead of just the network number and, depending on the class derived, the network designation was based on octet boundary segments of the entire address. The following table gives an overview of this system.

ClassFirst octet in binaryRange of first octetNetwork IDHost IDPossible number of networksPossible number of hosts A B C
0XXXXXXX 0 - 127 a b.c.d 128 = (27) 16,777,214 = (224 - 2)
10XXXXXX 128 - 191 a.b c.d 16,384 = (214) 65,534 = (216 - 2)
110XXXXX 192 - 223 a.b.c d 2,097,152 = (221) 254 = (28 - 2)

The articles 'subnetwork' and 'classful network' explain the details of this design.

Although classful network design was a successful developmental stage, it proved unscalable in the rapid expansion of the Internet and was abandoned in 1993 when Classless Inter-Domain Routing (CIDR) was introduced (RFC 1517, RFC 1518, RFC 1519) to define a new concept for the allocation of IP address blocks and new rules of routing protocol packets using IPv4 addresses. CIDR is based on variable-length subnet masking (VLSM) to allow allocation and routing 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.

[edit] IPv4 private addresses

Early network design, when global end-to-end connectivity was envisioned for all Internet hosts, intended that IP addresses be uniquely assigned to a particular computer or device. However, it was found that this was not always necessary as private networks developed and address space needed to be conserved (IPv4 address exhaustion).

Computers not connected to the Internet, such as factory machines that communicate only with each other via TCP/IP, need not have globally-unique IP addresses. Three ranges of IPv4 addresses for private networks, one range for each class (A, B, C), were reserved in RFC 1918. These addresses are not routed on the Internet, and thus their use need not be coordinated with an IP address registry.

Today, such private networks typically connect to the Internet through Network Address Translation (NAT).

IANA Reserved Private Network RangesStart of rangeEnd of rangeTotal addresses 24-bit Block (/8 prefix, 1 x A) 20-bit Block (/12 prefix, 16 x B) 16-bit Block (/16 prefix, 256 x C)
10.0.0.0 10.255.255.255 16,777,216
172.16.0.0 172.31.255.255 1,048,576
192.168.0.0 192.168.255.255 65,536

Any user may use any block. Typically, a network administrator will divide a block into subnets; for example, many home routers automatically use a default address range of 192.168.0.0 - 192.168.0.255 (192.168.0.0/24).

[edit] IPv4 address depletion

The IP version 4 address space is rapidly nearing exhaustion of available, officially assignable address blocks.

[edit] IP version 6 addresses

An illustration of an IP address (version 6), in hexadecimal and binary.

The rapid exhaustion of IPv4 address space, despite conservation techniques, prompted the Internet Engineering Task Force (IETF) to explore new technologies to expand the Internet's addressing capability. The permanent solution was deemed to be a redesign of the Internet Protocol itself. This next generation of the Internet Protocol, aimed to replace IPv4 on the Internet, was eventually named Internet Protocol Version 6 (IPv6)[3] The address size was increased from 32 to 128 bits (16 bytes), which, even with a generous assignment of network blocks, is deemed sufficient for the foreseeable future. Mathematically, the new address space provides the potential for a maximum of 2128, or about 3.403 × 1038 unique addresses.

The new design is not based on the goal to provide a sufficient quantity of addresses alone, but rather to allow efficient aggregation of subnet routing prefixes to occur at routing nodes. As a result, routing table sizes are smaller, and the smallest possible individual allocation is a subnet for 264 hosts, which is the size of the square of the size of the entire IPv4 Internet. At these levels, actual address utilization rates will be small on any IPv6 network segment. The new design also provides the opportunity to separate the addressing infrastructure of a network segment--that is the local administration of the segment's available space--from the addressing prefix used to route external traffic for a network. IPv6 has facilities that automatically change the routing prefix of entire networks should the global connectivity or the routing policy change without requiring internal redesign or 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 not the need to have complex address conservation methods as used in classless inter-domain routing (CIDR).

Windows Vista, Apple Computer's Mac OS X, all modern Linux distributions[4], and an increasing range of other operating systems include native support for the protocol, but it is not yet widely deployed in other devices.

Example of an IPv6 address:

2001:0db8:85a3:08d3:1319:8a2e:0370:7334

[edit] IPv6 private addresses

Just as IPv4 reserves addresses for private or internal networks, there are blocks of addresses set aside in IPv6 for private addresses. In IPv6, these are referred to as unique local addresses (ULA). RFC 4193 sets aside the routing prefix fc00::/7 for this block which is divided into two /8 blocks with different implied policies (cf. IPv6) The addresses include a 40-bit pseudorandom number that minimizes the risk of address collisions if sites merge or packets are misrouted.

Early designs (RFC 3513) used a different block for this purpose (fec0::), dubbed site-local addresses. However, the definition of what constituted sites remained unclear and the poorly defined addressing policy created ambiguities for routing. The address range specification was abandoned and must no longer be used in new systems.

Addresses starting with fe80: — called link-local addresses — are assigned only in the local link area. The addresses are generated usually automatically by the operating system's IP layer for each network interface. This provides instant automatic network connectivity for any IPv6 host and means that if several hosts connect to a common hub or switch, they have an instant communication path via their link-local IPv6 address. This feature is used extensively, and invisibly to most users, in the lower layers of IPv6 network administration (cf. Neighbor Discovery Protocol).

None of the private address prefixes may be routed in the public Internet.

[edit] IP subnetworks

The technique of subnetting can operate in both IPv4 and IPv6 networks. The IP address is divided into two parts: the network address and the host identifier. The subnet mask (in IPv4 only) or the CIDR prefix determines how the IP address is divided into network and host parts.

The term subnet mask is only used within IPv4. Both IP versions however use the Classless Inter-Domain Routing (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 the routing prefix. For example, an IPv4 address and its subnet mask may be 192.0.2.1 and 255.255.255.0, respectively. The CIDR notation for the same IP address and subnet is 192.0.2.1/24, because the first 24 bits of the IP address indicate the network and subnet.

[edit] Static and dynamic IP addresses

When a computer is configured to use the same IP address each time it powers up, this is known as a Static IP address. In contrast, in situations when the computer's IP address is assigned automatically, it is known as a Dynamic IP address.

[edit] Method of assignment

Static IP addresses are manually assigned to a computer by an administrator. The exact procedure varies according to platform. This contrasts with dynamic IP addresses, which are assigned either by the computer interface or host software itself, as in Zeroconf), or assigned by a server using Dynamic Host Configuration Protocol (DHCP). Even though IP addresses assigned using DHCP may stay the same for long periods of time, they can generally change. In some cases, a network administrator may implement dynamically assigned static IP addresses. In this case, a DHCP server is used, but it is specifically configured to always assign the same IP address to a particular computer. This allows static IP addresses to be configured centrally, without having to specifically configure each computer on the network in a manual procedure.

In the absence of both an administrator (to assign a static IP address) and a DHCP server, the operating system may assign itself an IP address using state-less autoconfiguration methods, such as Zeroconf.

[edit] Uses of dynamic addressing

Dynamic IP addresses are most frequently assigned on LANs and broadband networks by Dynamic Host Configuration Protocol (DHCP) servers. They are used because it avoids the administrative burden of assigning specific static addresses to each device on a network. It also allows many devices to share limited address space on a network if only some of them will be online at a particular time. In most current desktop operating systems, dynamic IP configuration is enabled by default so that a user does not need to manually enter any settings to connect to a network with a DHCP server. DHCP is not the only technology used to assigning dynamic IP addresses. Dialup and some broadband networks use dynamic address features of the Point-to-Point Protocol.

[edit] Sticky dynamic IP address

A sticky dynamic IP address or sticky IP is a term created by cable and DSL users to describe a dynamically assigned IP address that does not change often. This is however an informal term, as a sticky IP does not differ in any way from other dynamic IP addresses.

Even though IP addresses may not change often for cable or DSL users, the addresses are still controlled by the standard DHCP process. Since the modems are often online for extended periods of time, the leases on the IP addresses are commonly renewed, and therefore may not change.

Should the modem be turned off, a new IP address may be assigned when the modem is turned back on, as a different host on the network may have been assigned the old IP address. IP address changes may also be triggered by resetting the DHCP server configuration; therefore causing the modem to receive a new IP address.

[edit] Address autoconfiguration

RFC 3330 defines an address block, 169.254.0.0/16, for the special use in link-local addressing for IPv4 networks. In IPv6, every interface, whether using static or dynamic address assignments, also receives a local-link address automatically in the fe80::/10 subnet.

These addresses are only valid on the link, such as a local network segment or point-to-point connection, that a host is connected to. 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 created an implementation that called Automatic Private IP Addressing (APIPA). Due to Microsoft's market power, APIPA has been deployed on millions of machines and has, thus, become a de facto standard in the industry. Many years later, the IETF defined a formal standard for this functionality, RFC 3927, entitled Dynamic Configuration of IPv4 Link-Local Addresses.

[edit] Uses of static addressing

Some infrastructure situations have to use static addressing, such as when finding the Domain Name System host that will translate domain names to IP addresses. Static addresses are also convenient, but not absolutely necessary, to locate servers inside an enterprise. An address obtained from a DNS server comes with a time to live, or caching time, after which it should be looked up to confirm that it has not changed. Even static IP addresses do change as a result of network administration (RFC 2072)

[edit] Modifications to IP addressing

[edit] IP blocking and firewalls

Firewalls are common on today's Internet. For increased network security, they control access to private networks based on the public IP of the client. Whether using a blacklist or a whitelist, the IP address that is blocked is the perceived public IP address of the client, meaning that if the client is using a proxy server or NAT, blocking one IP address might block many individual people.

[edit] IP address translation

Multiple client devices can appear to share IP addresses: either because they are part of a shared hosting web server environment or because an IPv4 network address translator (NAT) or proxy server acts as an intermediary agent on behalf of its customers, in which case the real originating IP addresses might be hidden from the server receiving a request. A common practice is to have a NAT hide a large number of IP addresses in a private network. Only the "outside" interface(s) of the NAT need to have Internet-routable addresses[5].

Most commonly, the NAT device maps TCP or UDP port numbers on the outside to individual private addresses on the inside. Just as a telephone number may have site-specific extensions, the port numbers are site-specific extensions to an IP address.

In small home networks, NAT functions usually take place in a residential gateway device, typically one marketed as a "router". In this scenario, the computers connected to the router would have 'private' IP addresses and the router would have a 'public' address to communicate with the Internet. This type of router allows several computers to share one public IP address.

[edit] See also

[edit] References

  1. ^ a b c RFC 760, "DOD Standard Internet Protocol". DARPA Request For Comments. Internet Engineering Task Force. January 1980. http://www.ietf.org/rfc/rfc0760.txt. Retrieved on 2008-07-08. 
  2. ^ a b RFC 791, "Internet Protocol". DARPA Request For Comments. Internet Engineering Task Force. September 1981. 6. http://www.ietf.org/rfc/rfc791.txt. Retrieved on 2008-07-08. 
  3. ^ RFC 1883, "Internet Protocol, Version 6 (IPv6) Specification". DARPA Request For Comments. Internet Engineering Task Force. December 1995. http://www.ietf.org/rfc/rfc1883.txt. Retrieved on 2008-07-08. 
  4. ^ "Linux IPv6 Implementation". ipv6.org. 2003-03-20. http://www.ipv6.org/impl/linux.html. Retrieved on 2008-06-06. 
  5. ^ Comer pg.394

[edit] External links

[edit] RFCs

分享到:
评论

相关推荐

    ipaddress 5.3.3 java版

    import inet.ipaddr.IPAddressString; import inet.ipaddr.ipv6.IPv6Address; import org.tinyradius.util.RadiusException; tinyradius-java 所需库 IPAddress-master.zip\IPAddress-master\IPAddress\dist\IP...

    用IP Address控件编辑IP地址

    2. **声明控件变量**:在头文件中,为新添加的控件声明一个成员变量,例如`CIPAddressCtrl m_ipAddress;` 3. **初始化控件**:在对话框类的`OnInitDialog()`函数中,使用`DoDataExchange()`函数进行数据交换,同时...

    IP Address控件编辑IP地址.rar vc++

    在源文件(.cpp)中,将该成员变量与对话框中的控件ID关联起来,使用`DDX_Control(pDX, IDC_IP_ADDRESS, m_ipAddress);`这行代码。 为了读取或设置IP Address控件的值,可以使用控件提供的成员函数。例如,`...

    IP Address Control 使用实例

    在IT行业中,IP Address Control是一种常见的工具或组件,主要用于管理和控制网络设备的IP地址分配,以确保网络资源的有效利用和安全。在这个特定的实例中,我们聚焦于在VC++(Visual C++)环境下如何有效使用IP ...

    QT 下载:Download from your IP address is not allowed

    Download from your IP address is not allowed 百度网盘永久连接: QT下载: qt-opensource-linux-x64-5.8.0.run: 链接:https://pan.baidu.com/s/1sQ3tqPaWdDnmhBYAc_XR7g qt-opensource-linux-x64-5.13.1....

    Advanced IP Address Calculator网络规划(中文版)

    5. **避免IP冲突**:在网络规划中,必须确保每个设备的IP地址在整个网络中是唯一的,Advanced IP Address Calculator可以辅助检查和避免IP冲突。 使用"Advanced IP Address Calculator.exe"这个程序,用户只需输入...

    IP子网划分工具Advanced IP Address Calculator

    **IP子网划分工具——Advanced IP Address Calculator** 在IT网络管理中,IP地址的规划与管理是一项基础且关键的任务。为了有效地利用网络资源,我们常常需要进行IP子网划分,这是一个将一个大IP网络划分为多个小IP...

    Advanced IP Address Calculator

    在计算机网络中,IP地址(Internet Protocol Address)是互联网上设备的唯一标识符。它由32位二进制数组成,通常以点分十进制的形式表示,例如192.168.1.1。IP地址分为两大类:IPv4和IPv6。IPv4地址包含32位,而IPv6...

    QQ IP address查询软件

    QQ IP address查询软件,方便用语查询IP的ADD的归属地等。

    使用IP Address读取IP的资源

    使用`IPAddress.Parse("ip_address_string")`或`IPAddress.TryParse("ip_address_string", out ipAddress)`可以将字符串形式的IP地址转换为`IPAddress`对象。 5. 检查IP地址的有效性: `IPAddress.TryParse`方法...

    understanding IP address

    understanding IP address

    jQuery IP address plugin

    6. **API接口**:提供丰富的API接口,比如`$.fn.ipAddress('validate')`用于手动验证IP地址,`$.fn.ipAddress('get')`用于获取当前输入的IP地址等。 7. **扩展性**:开发者可以通过插件提供的API接口进行扩展,实现...

    IPAddress类、 Dns类、 IPHostEntry类和IPEndPoint 类的使用方法

    IPAddress ipAddress = IPAddress.Parse(ipAddressString); ``` 此外,`IPAddress`还提供了如`IsLoopback`、`IsMulticast`等方法来检查IP地址的类型。 接下来是`Dns`类,它提供了一些用于解析DNS(域名系统)记录的...

    howto-ipaddress.pdf

    在本文档中,我们将介绍Python编程语言中的一个内置模块:ipaddress。这个模块专门用于创建和操作IP地址、网络和接口对象。在深入探讨之前,有必要理解IP地址以及IP网络的基础知识,特别是随着互联网协议从IPv4向...

    QQWryIP.dat和access格式的ipaddress

    QQWryIP.dat和Access格式的IPAddress是两种常见的IP地址数据库文件,它们在IT行业中被广泛用于IP地理位置查询和网络管理。这两种文件都包含了大量关于IP地址与地理位置对应关系的数据,但它们的结构和使用方式有所...

    C# IPAddress控件

    标题提到的"C# IPAddress控件"显然是一个专门为C# WinForm应用设计的IP地址输入控件。这个控件可能包含了用户友好的界面,允许用户以标准的IPv4或IPv6格式输入IP地址,并且可能提供了验证和错误处理机制,确保输入的...

    python-ipaddress-1.0.16-2.el7.noarch.rpm

    离线安装包,亲测可用

    PyPI 官网下载 | ipaddress-1.0.5.tar.gz

    《Python中的ipaddress库详解与应用》 在Python编程中,处理IP地址和网络相关的操作是常见的需求。PyPI(Python Package Index)是Python开发者获取第三方库的主要平台,其中包含了丰富的资源。今天我们将聚焦于一...

Global site tag (gtag.js) - Google Analytics