Make your lookup automatic
When you create a lookup configuration in transforms.conf
, you invoke it by running searches that reference it. However, you can optionally create an additional props.conf
configuration that makes the lookup "automatic." This means that it runs in the background at search time and automatically adds output fields to events that have the correct match fields.
You can make all lookup types automatic. However, KV Store lookups have an additional setup step that you must complete before you configure them as automatic lookups in props.conf
. See Enable replication for a KV Store collection.
Each automatic lookup configuration you create is limited to events that belong to a specific host, source, or source type. Automatic lookups can access any data in a lookup table that belongs to you or which you have shared.
When your lookup is automatic you do not need to invoke its transforms.conf
configuration with the lookup
command.
Splunk software does not support nested automatic lookups.
The automatic lookup format in props.conf
An automatic lookup configuration in props.conf
:
- References the lookup table you configured in
transforms.conf
. - Specifies the fields in your events that the lookup should match in the lookup table.
- Specifies the corresponding fields that the lookup should output from the lookup table to your events.
At search time, the LOOKUP-<class>
configuration identifies a lookup and describes how that lookup should be applied to your events. To create an automatic lookup, follow this syntax:
[<spec>] LOOKUP-<class> = $TRANSFORM <match_field_in_lookup_table> OUTPUT|OUTPUTNEW <output_field_in_lookup_table>
- The stanza header is
[<spec>]
.<spec>
can be:<sourcetype>
, the source type of an event.host::<host>
, where<host>
is the host, or host-matching pattern, for an event.source::<source>, where <source>
is the source, or source-matching pattern, for an event.
<spec>
cannot use regular expression syntax.$TRANSFORM
: References thetransforms.conf
stanza that defines the lookup table.match_field_in_lookup_table
: This variable is the field in your lookup table that matches a field in your events with the same host, source, or source type as thisprops.conf
stanza. If the match field in your events has a different name from the match field in the lookup table, use the AS clause as specified in Step 3, below.output_field_from_lookup_table
: The corresponding field in the lookup table that you want to add to your events. If the output field in your events should have a different name from the output field in the lookup table, use the AS clause as specified in Step 3, below.
You can have multiple fields on either side of the lookup. For example, you can have:
$TRANSFORM <match_field_in_lookup_table1>, <match_field_in_lookup_table>OUTPUT|OUTPUTNEW <output_field_from_lookup_table1>, <output_field_from_lookup_table2>
You can also have one matching field return two output fields, three matching fields return one output field, and so on.
If you do not include an OUTPUT|OUTPUTNEW
clause, Splunk software adds all the field names and values from the lookup table to your events. When you use OUTPUTNEW
, Splunk software can add only the output fields that are "new" to the event. If you use OUTPUT
, output fields that already exist in the event are overwritten.
If the "match" field names in the lookup table and your events are not identical, or if you want to "rename" the output field or fields that get added to your events, use the AS
clause:
[<stanza name>] LOOKUP-<class> = $TRANSFORM <match_field_in_lookup_table> AS <match_field_in_event> OUTPUT|OUTPUTNEW <output_field_from_lookup_table> AS <output_field_in_event>
For example, if the lookup table has a field named dept
and you want the automatic lookup to add it to your events as department_name
, set department_name
as the value of <output_field_in_event>
.
When you set up your match fields and output fields, avoid creating automatic lookup reference cycles. A reference cycle occurs when match and output fields are reused, either within the same lookup or among related lookups. For example, you do not want to set up a lookup where the <match_field_in_event> and the <output_field_in_event> values are the same. This can easily happen if you do not explicitly set an OUTPUT|OUTPUTNEW clause in your automatic lookup configuration.
For more information about automatic lookup reference cycles see Define an automatic lookup in Splunk Web.
Multiple lookup configurations in a single props.conf stanza
You can have multiple LOOKUP-<class>
configurations in a single props.conf
stanza. Each lookup should have its own unique lookup name. For example, if you have multiple lookups, you can name them LOOKUP-table1
, LOOKUP-table2
, and so on.
You can also have different props.conf
automatic lookup stanzas that each reference the same lookup stanza in transforms.conf
.
Create an automatic lookup stanza in props.conf
- Create a stanza header that references the host, source, or source type that you are associating the lookup with.
- Add a
LOOKUP-<class>
configuration to the stanza that you have identified or created.- As described in the preceding section this configuration specifies:
- What fields in your events it should match to fields in the lookup table.
- What corresponding output fields it should add to your events from the lookup table.
- Be sure to make the
<class>
value unique. You can run into trouble if two or more automatic lookup configurations have the same<class>
name. See "Do not use identical names in automatic lookup configurations."
- (Optional) Include the AS clause in the configuration when the "match" field names in the lookup table and your events are not identical, or when you want to "rename" the output field or fields that get added to your events, use the
AS
clause. - Restart Splunk Enterprise to apply your changes.
- If you have set up an automatic lookup, after restart you should see the
output
fields from your lookup table listed in the fields sidebar. From there, you can select the fields to display in each of the matching search results.
- If you have set up an automatic lookup, after restart you should see the
Enable replication for a KV store collection
In Splunk Enterprise, KV Store collections are not bundle-replicated to indexers by default, and lookups run locally on the search head rather than on remote peers. If you enable replication for a KV Store collection, you can run the lookups on your indexers which let you use automatic lookups with your KV Store collections.
To enable replication for a KV Store collection and allow lookups against that collection to be automatic:
- Open
collections.conf
. - Set
replicate
totrue
in the stanza for the collection.- This parameter is set to
false
by default.
- This parameter is set to
- Restart Splunk Enterprise to apply your changes.
If your indexers are running a version of Splunk Enterprise that is older than 6.3, attempts to run an automatic lookup fail with a "lookup does not exist" error. You must upgrade your indexers to 6.3 or later to use this functionality.
For more information, see Use configuration files to create a KV Store collection at the Splunk Developer Portal.
Example configuration of an automatic KV Store lookup
This configuration references the example KV Store lookup configuration in Configure KV Store lookups, in this manual. The KV Store lookup is defined in transforms.conf
, in a stanza named employee_info
.
[access_combined] LOOKUP-http = employee_info CustID AS cust_ID OUTPUT CustName AS cust_name, CustCity AS cust_city
This configuration uses the employee_info
lookup in transforms.conf
to add fields to your events. Specifically it adds cust_name
and cust_city
fields to any access_combined
event with a cust_ID
value that matches a CustID
value in the kvstorecoll
KV Store collection. It also uses the AS
clause to:
- Find matching fields in the KV Store collection.
- Rename output fields when they are added to events.
Configure a time-based lookup | About workflow actions in Splunk Web |
This documentation applies to the following versions of Splunk® Enterprise: 7.0.0, 7.0.1, 7.0.2, 7.0.3, 7.0.4, 7.0.5, 7.0.6, 7.0.7, 7.0.8, 7.0.9, 7.0.10, 7.0.11, 7.0.13, 7.1.0, 7.1.1, 7.1.2, 7.1.3, 7.1.4, 7.1.5, 7.1.6, 7.1.7, 7.1.8, 7.1.9, 7.1.10, 7.2.0, 7.2.1, 7.2.2, 7.2.3, 7.2.4, 7.2.5, 7.2.6, 7.2.7, 7.2.8, 7.2.9, 7.2.10, 7.3.0, 7.3.1, 7.3.2, 7.3.3, 7.3.4, 7.3.5, 7.3.6, 7.3.7, 7.3.8, 7.3.9, 8.0.0, 8.0.1, 8.0.2, 8.0.3, 8.0.4, 8.0.5, 8.0.6, 8.0.7, 8.0.9, 8.0.10, 8.1.1, 8.1.2, 8.1.3, 8.1.4, 8.1.5, 8.1.6, 8.1.7, 8.1.8, 8.1.9, 8.1.12, 8.1.13, 8.1.14, 8.2.0, 8.2.1, 8.2.2, 8.2.3, 8.2.4, 8.2.5, 8.2.6, 8.2.7, 8.2.8, 8.2.9, 8.2.10, 8.2.11, 8.2.12, 9.0.0, 9.0.1, 9.0.2, 9.0.3, 9.0.4, 9.0.5, 9.0.6, 9.0.7, 9.0.8, 9.0.9, 9.0.10, 9.1.0, 9.1.1, 9.1.2, 9.1.3, 9.1.4, 9.1.5, 9.2.0, 9.2.1, 9.2.2, 9.3.0, 8.0.8, 8.1.0, 8.1.10, 8.1.11
Feedback submitted, thanks!