Getting Data In

Receive data on intermediate or heavy forwarder, consolidate into one index, and forward to single index externally

mccartneyc
Path Finder

Hi all, for the last few months I've been working on a splunk environment and need some assistance with routing data.

The current setup:
Universal forwarders cloning data to indexer cluster and intermediate forwarder on roughly 20 different indexes.
Heavy Forwarder with AWS addon forwarding local and AWS cloning data to different indexes on indexers and intermediate forwarder.

What we want to do is send the data to the indexers like normal and send all of the cloned data being received by the intermediate forwarder to a single index on an external splunk enterprise indexer.

I have tried changing the intermediate to a heavy forwarder (locally indexing the data into their respective indexes) and forwarding to the external party to a single index, but because of the amount of indexes, we need to consolidate the cloned data to a single index and forward,

I attempted using the transforms and props confs on the intermediate (now heavy) forwarder to change the receiving index for all data received on [splunktcp://9997] to go to a single index either locally and forward or to just forward to a single index. Below are examples of the confs on the intermediate. Note: I refer to it as the intermediate as that is what we want it to be, but currently have indexing setup on it.

Our long term goal is to use the intermediate to receive all of our data into a single index and index from our other environments into their own respective indexes, and forward to the external splunk environment.

inputs.conf

[splunktcp://9997]
compressed = true
disabled = 0
index=test_index

props.conf

[source::splunktcp:9997]
TRANSFORMS-forwarding = changeIndex, tcpForward

transforms.conf

[changeIndex]
#SOURCE_KEY = _MetaData:Index
DEST_KEY = _MetaData:Index
REGEX = .
FORMAT = test_index

[tcpForward]
REGEX = .
DEST_KEY = _TCP_ROUTING
FORMAT = external-splunk

Any help would be greatly appreciated. Currently with this and various setups, I'm not getting any errors, but the data is not getting to the external splunk environment.

0 Karma
1 Solution

koshyk
Super Champion

So I assume the ultimate aim is to forward all data to the external-splunk ? Then you don't need to index at all in your HF or old Splunk. Just do this using HF on the fly

But before you do, please check if you are getting data into test_index. This will ensure there is no issues with network connectivity or data flow.
1) So if you need to send everything to external splunk, you don't need transforms. Just below settings is good
props.conf

[source::splunktcp:9997]
TRANSFORMS-forwarding = tcpForward

outputs.conf

[tcpout]

[tcpout:tcpForward]
server = <external_Server>:<external_port>
sendCookedData = false

2) But if you really need to index for something reason and then forward.
You need to retain props.conf & transforms.conf as you have already written, but just add outputs.conf like below

[tcpout]

[tcpout:external-splunk]
server=<external_Server>:<external_port>
sendCookedData=false

Also good to have a look into https://docs.splunk.com/Documentation/Splunk/latest/Forwarding/Forwarddatatothird-partysystemsd

View solution in original post

0 Karma

koshyk
Super Champion

So I assume the ultimate aim is to forward all data to the external-splunk ? Then you don't need to index at all in your HF or old Splunk. Just do this using HF on the fly

But before you do, please check if you are getting data into test_index. This will ensure there is no issues with network connectivity or data flow.
1) So if you need to send everything to external splunk, you don't need transforms. Just below settings is good
props.conf

[source::splunktcp:9997]
TRANSFORMS-forwarding = tcpForward

outputs.conf

[tcpout]

[tcpout:tcpForward]
server = <external_Server>:<external_port>
sendCookedData = false

2) But if you really need to index for something reason and then forward.
You need to retain props.conf & transforms.conf as you have already written, but just add outputs.conf like below

[tcpout]

[tcpout:external-splunk]
server=<external_Server>:<external_port>
sendCookedData=false

Also good to have a look into https://docs.splunk.com/Documentation/Splunk/latest/Forwarding/Forwarddatatothird-partysystemsd

0 Karma
Get Updates on the Splunk Community!

Automatic Discovery Part 1: What is Automatic Discovery in Splunk Observability Cloud ...

If you’ve ever deployed a new database cluster, spun up a caching layer, or added a load balancer, you know it ...

Real-Time Fraud Detection: How Splunk Dashboards Protect Financial Institutions

Financial fraud isn't slowing down. If anything, it's getting more sophisticated. Account takeovers, credit ...

Splunk + ThousandEyes: Correlate frontend, app, and network data to troubleshoot ...

 Are you tired of troubleshooting delays caused by siloed frontend, application, and network data? We've got a ...