IP address field type

Introduced 1.0

An ip field type contains an IP address in IPv4 or IPv6 format.

To represent IP address ranges, there is an IP range field type.

Example

Create a mapping with an IP address:

  1. PUT testindex
  2. {
  3. "mappings" : {
  4. "properties" : {
  5. "ip_address" : {
  6. "type" : "ip"
  7. }
  8. }
  9. }
  10. }

copy

Index a document with an IP address:

  1. PUT testindex/_doc/1
  2. {
  3. "ip_address" : "10.24.34.0"
  4. }

copy

Query an index for a specific IP address:

  1. GET testindex/_doc/1
  2. {
  3. "query": {
  4. "term": {
  5. "ip_address": "10.24.34.0"
  6. }
  7. }
  8. }

copy

Searching for an IP address and its associated network mask

You can query an index for an IP address in Classless Inter-Domain Routing (CIDR) notation. Using CIDR notation, specify the IP address and the prefix length (0–32), separated by /. For example, the prefix length of 24 will match all IP addresses with the same initial 24 bits.

Example query in IPv4 format

  1. GET testindex/_search
  2. {
  3. "query": {
  4. "term": {
  5. "ip_address": "10.24.34.0/24"
  6. }
  7. }
  8. }

copy

Example query in IPv6 format

  1. GET testindex/_search
  2. {
  3. "query": {
  4. "term": {
  5. "ip_address": "2001:DB8::/24"
  6. }
  7. }
  8. }

copy

If you use an IP address in IPv6 format in a query_string query, you need to escape : characters because they are parsed as special characters. You can accomplish this by wrapping the IP address in quotation marks and escaping those quotation marks with \.

  1. GET testindex/_search
  2. {
  3. "query" : {
  4. "query_string": {
  5. "query": "ip_address:\"2001:DB8::/24\""
  6. }
  7. }
  8. }

copy

Parameters

The following table lists the parameters accepted by ip field types. All parameters are optional.

ParameterDescription
boostA floating-point value that specifies the weight of this field toward the relevance score. Values above 1.0 increase the field’s relevance. Values between 0.0 and 1.0 decrease the field’s relevance. Default is 1.0.
doc_valuesA Boolean value that specifies if the field should be stored on disk so that it can be used for aggregations, sorting, or scripting. Default is true.
ignore_malformedA Boolean value that specifies to ignore malformed values and not to throw an exception. Default is false.
indexA Boolean value that specifies whether the field should be searchable. Default is true.
null_valueA value to be used in place of null. Must be of the same type as the field. If this parameter is not specified, the field is treated as missing when its value is null. Default is null.
storeA Boolean value that specifies whether the field value should be stored and can be retrieved separately from the _source field. Default is false.