Splunk Search

How to combine values from stats into single row?

TribesmanJohn
Explorer

Hi All,

I am looking into using some proxy logs to determine download volume for particular streaming sites and was looking for a way to merge hostnames into one "service".

Consider the SPL:

index=proxy url=*.streaming-site.com
| eval megabytes=round(((bytes_in/1024)/1024),2)
| stats sum(megabytes) as Download_MB by url
| sort -Download_MB

Will likely return multiple rows like:

cdn1.streaming-site.com    180.3
cdn2.streaming-site.com 164.8
www.streaming-site.com  12.3

I am wanting to merge those all into one row of

streaming-site.com   357.4

I have played around with the coalesce function, but this would be unsustainable for sites like Netflix which have dozens of URLs associated with them.

If anyone has any suggestions on how I might combine results with say a wildcard (*), I'd love to hear from you!

Labels (3)
0 Karma
1 Solution

richgalloway
SplunkTrust
SplunkTrust

The coalesce function selects a field within a single result.  To combine (aggregate) multiple results, use the stats command again after modifying the url field.

index=proxy url=*.streaming-site.com
| eval megabytes=round(((bytes_in/1024)/1024),2)
| stats sum(megabytes) as Download_MB by url
| eval url=replace(url, ".*?\.(.*)","\1")
| stats sum(Download_MB) as Download_MB by url
| sort - Download_MB

 

---
If this reply helps you, Karma would be appreciated.

View solution in original post

TribesmanJohn
Explorer

Thanks for this! 🙂

More tweaking required on my part as some of the subdomains being evaluated have more than 3 levels, but this is a big help in getting me on the right track!

richgalloway
SplunkTrust
SplunkTrust

The coalesce function selects a field within a single result.  To combine (aggregate) multiple results, use the stats command again after modifying the url field.

index=proxy url=*.streaming-site.com
| eval megabytes=round(((bytes_in/1024)/1024),2)
| stats sum(megabytes) as Download_MB by url
| eval url=replace(url, ".*?\.(.*)","\1")
| stats sum(Download_MB) as Download_MB by url
| sort - Download_MB

 

---
If this reply helps you, Karma would be appreciated.
Got questions? Get answers!

Join the Splunk Community Slack to learn, troubleshoot, and make connections with fellow Splunk practitioners in real time!

Meet up IRL or virtually!

Join Splunk User Groups to connect and learn in-person by region or remotely by topic or industry.

Get Updates on the Splunk Community!

Why Splunk Customers Should Attend Cisco Live 2026 Las Vegas

Why Splunk Customers Should Attend Cisco Live 2026 Las Vegas     Cisco Live 2026 is almost here, and this ...

What Is the Name of the USB Key Inserted by Bob Smith? (BOTS Hint, Not the Answer)

Hello Splunkers,   So you searched, “what is the name of the usb key inserted by bob smith?”  Not gonna lie… ...

Automating Threat Operations and Threat Hunting with Recorded Future

    Automating Threat Operations and Threat Hunting with Recorded Future June 29, 2026 | Register   Is your ...