IP address field type

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. }

Index a document with an IP address:

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

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. }

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. }

Example query in IPv6 format

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

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. }

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 false.
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.