Splunk
Splunk: Ingests, indexes, and visualizes data for monitoring, analysis, and alerting.
To add a Splunk destination (Splunk Cloud or Splunk Enterprise) to Axoflow, complete the following steps.
Prerequisites
- 
Enable the HTTP Event Collector (HEC) on your Splunk deployment if needed. On Splunk Cloud Platform deployments, HEC is enabled by default. 
- 
Create a token for Axoflow to use in the destination. When creating the token, use the syslog source type. For details, see Set up and use HTTP Event Collector in Splunk Web. 
- 
If you’re using AxoRouter, create the indexes where Axoflow sends the log data. Which index is needed depends on the sources you have, but create at least the following event indices: axoflow,infraops,netops,netfw,osnix(for unclassified messages). Check your sources in the Sources section for a detailed lists on which indices their data is sent.
- 
If you’ve created any new indexes, make sure to add those indexes to the token’s Allowed Indexes. 
Steps
- 
Create a new destination. - Open the Axoflow Console.
- Select Topology.
- Select + Create New Item > Destination.
 
- 
Configure the destination. - 
Select Splunk. 
- 
Select which type of configuration you want to use: - Simple: Send all data into a single index, with fixed source and source type settings.
- Dynamic: Set index, source, and source type based on the content or metadata of the incoming messages.
- Advanced: Allows you to specify a custom URL endpoint.
 
- 
Enter a name for the destination.  
- 
Configure the endpoint of the destination. - Advanced: Enter your Splunk URL into the URL field, for example, https://<your-splunk-tenant-id>.splunkcloud.com:8088for Splunk Cloud Platform free trials, orhttps://<your-splunk-tenant-id>.splunkcloud.comfor Splunk Cloud Platform instances.
- Simple and Dynamic:
- Select the HTTPS or HTTP protocol to use to access your destination.
- Enter the Hostname and Port of the destination.
 
 
- Advanced: Enter your Splunk URL into the URL field, for example, 
- 
Specify the Splunk index to send the data to. - Simple: Enter the expression that specifies the Splunk index to use into the Index field, for example: netops. All data will be sent into this index.
- Dynamic and Advanced:
- Enter the name of the Default Index. The data will be sent into this index if no other index is set during the processing of the message (based on automatic classification, or by the processing steps of the Flow). Make sure that the index exists in Splunk.
- Enter the Default Source and Default Source Type. These will be assigned to the messages that have no source or source type set during the processing of the message (based on automatic classification, or by the processing steps of the Flow).
 
 
- Simple: Enter the expression that specifies the Splunk index to use into the Index field, for example: 
- 
Enter the token you’ve created into the Token field. 
- 
Disable the Verify server certificate option unless your deployment has a valid, non-self-signed certificate. Free Splunk Cloud accounts have self-signed certificates. 
- 
(Optional) Set other options as needed for your environments. - Timeout: The number of seconds to wait for a log-forwarding request to complete, and attempt to reconnect the server if exceeded. If the timeout is exceeded, AxoRouter attempts to reconnect the destination. The default (0) is unlimited. For more details, see the AxoSyslog documentation.
 - Batch Bytes: Sets the maximum size of payload in a batch. If the size of the messages reaches this value, AxoRouter sends the batch to the destination even if the number of messages is less than the value of the batch lines option.
- Batch Lines: Number of lines sent to the destination in one batch. AxoRouter waits for this number of lines to accumulate and sends them off in a single batch. Increasing this number increases throughput as more messages are sent in a single batch, but also increases message latency. For more details, see the AxoSyslog documentation.
- Batch Timeout: Maximal time in milliseconds to wait for a batch to be filled before sending it. The default value (-1) means that the batch should be full before sending, which may result in a long wait if the incoming traffic is low. For more details, see the AxoSyslog documentation.
- Number of Workers: Used for scaling the destination in case of high message load. Specifies the number of worker threads AxoRouter uses for sending messages to the destination. The default is 1. If high message throughput is not a concern, leave it on 1. For maximum performance, increase it up to the number of CPU cores available on AxoRouter. For more details, see the AxoSyslog documentation.
 
- Timeout: The number of seconds to wait for a log-forwarding request to complete, and attempt to reconnect the server if exceeded. If the timeout is exceeded, AxoRouter attempts to reconnect the destination. The default (
- 
Select Create. 
 
- 
- 
Create a flow to connect the new destination to an AxoRouter instance.- 
Select Flows. 
- 
Select Create New Flow. 
- 
Enter a name for the flow, for example, my-test-flow. 
- 
In the Router Selector field, enter an expression that matches the router(s) you want to apply the flow. To select a specific router, use a name selector, for example, name = my-axorouter-hostname.It also makes more complex filtering possible, using the Equals, Contains (partial match), and Match (regular expression match) operators. Note that: - To execute the search, click Search, or hit ESC then ENTER.
 - Axoflow Console autocompletes the built-in and custom labels and field names, as well as their most frequent values, but doesn’t autocomplete labels and variables created by data parsing and processing steps.
- You can use the AND and OR operators to combine expressions, and also parenthesis if needed. For details on AQL, see AQL operator reference.
- The precedence of the operators is the following: parentheses, AND, OR, comparison operators.
- Use the usual keyboard shortcuts to undo (⌘/Ctrl + Z) or redo (⌘/Ctrl + Shift + Z) your edits.
 
- 
Select the Destination where you want to send your data. If you don’t have any destination configured, see Destinations. By default, you can select only external destinations. If you want to send data to another AxoRouter, enable the Show all destinations option, and select the connector of the AxoRouter where you want to send the data.  
- 
(Optional) To process the data transferred in the flow, select Add New Processing Step. For details, see Processing steps. For example: - Add a Classify, a Parse, and a Reduce step, in that order, to automatically remove redundant and empty fields from your data.
- To select which messages are processed by the flow, add a Select Messages step, and enter a filter into the Query field. For example, to select only the messages received from Fortinet FortiGate firewalls, use the meta.vendor = fortinet AND meta.product = fortigatequery.
- Save the processing steps.
  
- 
Select Create. 
- 
The new flow appears in the Flows list.  
 
- 
Related message fields
You can use the following message fields to modify messages sent to this destination using processing steps.