Refine your search:

4 ratings

Thanks For Downloading!

Review the documentation below and follow any custom installation steps. If no install steps are listed, most Splunk Apps and Add-ons can be installed as follows:

Windows: Decompress the downloaded file using a tool like 7-Zip and place the resulting folder into %PROGRAMFILES%\Splunk\etc\apps. Then restart Splunk using the splunk restart command or the GUI.

Unix/Linux: Decompress the downloaded file using a tool like tar -xvf and place the resulting folder into $SPLUNK_HOME/etc/apps. Then restart Splunk using the splunk restart command or the GUI.

Description

Google Maps for Splunk adds a geo-visualization module based on the Google Maps API and allows you to quickly plot geographical information on a map. Furthermore maps can be embedded in advanced dashboards.

Professional Services and Support

This add-on has been developed by SPP (<http://www.spp.at/>), a Splunk Partner located in Vienna, Austria. If you require support on getting solutions using Google Maps up and running, please contact splunk@spp.at.

Licence and Terms of Use

This app is licensed under the terms of the Creative Commons license and provided as-is without any warranty. It uses thrird-party components that are licensed differently:

  • Google Maps: <http://code.google.com/apis/maps/terms.html>
  • MAXMIND GeoLite City database see <http://geolite.maxmind.com/download/geoip/database/LICENSE.txt>
  • pygeoip see <http://www.gnu.org/licenses/lgpl.html>

Using the Google Maps Search View

The App provides a flashtimeline-like view which allows you to simply enter a search and display the results on the map. In order to plot search results on the map they have to have some kind of location information attached. This location information has to be included in a field with the name _geo and has to be formatted as "<latitude>,<longitude>". Latitude and Longitude have to be expressed as floating point numbers. As an example "47.11,0.815" would be a valid _geo value. Other notations (like 47°12',...) are not supported.

In most cases you don't have to build the _geo field yourself. The built-in geolocation lookup methods (geoip command and geo lookup) are emitting this field by default. In cases where you already have geolocation information in your results, you can leverage the geonormalize command to build the _geo value for you.

Geolocation Lookup for IP addresses

Performing Gelocation Lookup on external IP addresses

External IP address values can be easily translated to locations by using the built-in geoip command or the geo lookup.

Examples:

Perform a geolocation lookup for values of the clientip field in access_combined events:
sourcetype=access_combined | geoip clientip
Same as the previous example, but also perform DNS lookups in case when the value of the clientip field is a hostname and not an IP:
sourcetype=access_combined | geoip clientip resolve_hostnames=true
Same as the first example, but using the geo lookup instead of the command
sourcetype=access_combined | lookup geo ip as clientip

Performing Gelocation Lookup on internal IP addresses

In order to perform geolocation lookup on private IP address ranges you have to implement a lookup yourself. Splunk provides multiple ways to achieve this:

  • Creating a CSV with the IP subnets and their locations and leveraging the CIDR match_type
  • Creating a scripted lookup which queries the geolocation information from an existing asset management system.

Performing combined Geolocation Lookup on IP adresses

Lookups for external and interal IP addresses can be easily combined.

Examples:
sourcetype=access_combined clientip=* | lookup geoip_internal ip as clientip | geoip clientip

sourcetype=access_combined clientip=* | lookup example_geo_internal ip as clientip | lookup geo ip as clientip OUTPUTNEW _geo geo_info

Use existing geolocation information available in search results

It's common case that events already contain geo information.

The geonormalize command

The geonormalize command can detect existing fields containing the geoinformation and normalizes them for the GoogleMaps module. For doing this the command searches for field pairs (a latitude field and a longitude field) matching a name scheme. The values of those fields are then merged and emitted as the _geo field. The following name schemes are supported:

  • *lat/*lng
  • *lat/*lon
  • *latitude/*longitude

So for example when an event has the fields gps_lat=47.11 and gps_lon=0.815 the geonormalize command will detect those fields and emit the _geo field with the value 47.11,0.815.

Example:
sourcetype=device_tracking device_id=A47C08B13 | geonormalize

Manual building the _geo field

If you don't want to use the geonormalize command or if the location fields do not match any naming scheme, you can manually build the _geo field.

Example:
eventtype=phone_activation | eval _geo=phone_loc_1+&quot;,&quot;+phone_loc_2
(Assuming that phone_loc_1 contains the latitude and phone_loc_2 contains the longitude)

Creating Dashboards with Google Maps

This add-on provides a Splunk UI module called GoogleMaps. This module can only be using in advanced XML dashboards. The usage of the module is quite similar to any built-in module in Splunk which displays results (like SimpleResultsTable, EventsViewer, etc.).

Example:
&lt;module name=&quot;HiddenSearch&quot; layoutPanel=&quot;panel_row1_col1&quot; autoRun=&quot;true&quot;&gt; &lt;param name=&quot;search&quot;&gt;sourcetype=access_combined | geoip clientip&lt;/param&gt; &lt;param name=&quot;earliest&quot;&gt;-24h@h&lt;/param&gt; &lt;module name=&quot;GoogleMaps&quot;&gt; &lt;param name=&quot;height&quot;&gt;500px&lt;/param&gt; &lt;param name=&quot;mapType&quot;&gt;roadmap&lt;/param&gt; &lt;param name=&quot;scrollwheel&quot;&gt;off&lt;/param&gt; &lt;/module&gt; &lt;/module&gt;

All available options to the module can be found at the module reference at your Splunk instance at <http://localhost:8000/modules#Splunk.Module.GoogleMaps>

Versions and Release Notes

Version 1.1.2 (current version - updated Aug 21, 2012)
release notes:

Fixed issue with chrome not loading the API when SSL is enabled

show older versions »
Version 1.1.1 (updated May 29, 2012)
release notes:

- Fixed some UI issues:
- Fixed race condition when api load was loaded pretty early
- Fixed cluster icons did not appear in some cases
- Update to latest maxmind geolite city db

Version 1.1 (updated May 31, 2011)
Version 1.1 (updated May 31, 2011)
release notes:

Internal changes

The module now uses the _geo field instead of the _lat and _lng fields to resolve the location. The geoip and the geonormalize command are now emitting this field. It contains the combined latitude/longitude information in the form <lat>,<lng> (eg. 47.11,0.815).

Geolocation Lookup

The geolocation lookup now uses the Maxmind GeoLite City database. The geoip command is now emitting different fields:
<field>_latitude, <field>_longitude, <field>_country_name, <field>_country_code, <field>_region_name, <field>_city, and the _geo field

UI Changes

- More configuration options for the module
- Scrollwheel zooming is turned off by default
- Streetview is turned off
- Introduced opacity for cluster icons (Only in Browsers supporting native opacity).
- Added new mapStyles (See dark view).
- The module now persist settings like center, zoom and map style.
- Removed fields side-panel
- Added 2 panel to kind-of debug the results (Geo Results and Events)

Drilldown

Version 1.0.1 (updated Aug 31, 2010)
release notes:

Google Maps Version 1.0.1

- Enhanced clustering of the results displayed on the Google Map
- Improved performance for both the geoip and geonormalize command
- Added a custom results header in the maps view which displays the count of results with geo information as well as the count of distinct locations

posted 12 Aug '10, 13:36

ziegfried's gravatar image

ziegfried ♦
10.1k1618
accept rate: 52%

new version 21 Aug '12, 11:24


4 Reviews:
4 reviews, 4 ratings, average 4.25

Hi ziegfried,

Thanks for the great app. We have been using it at our workplace extensively. However, our mgmt is requesting a map that would show multiple parameters in a single view, for example, response_time, number_of_hits, number_of_ipv4_addr, etc in a one single representation. Would this be possible?

Kalpana

comments (0)

reviewed 13 Mar, 13:42

kalpana_810's gravatar image

kalpana_810
111
accept rate: 0%

Great app! Very easy to use! The only glitch I've hit is that for one particular search, it seems to stop after 18000 total, not unique, geolocations. I am totally sure the search I am using to feed this app returns way more IPs than just 18000.

I'd totally recommend this app anyway

comments (0)

reviewed 27 Mar '12, 06:35

ibercomm's gravatar image

ibercomm
1
accept rate: 0%

Reviews related to version 1.1.1 (current is 1.1.2)

Great app! Thanks a lot for sharing with the community.

Does it support commercial version of the MAXMIND db?

comments (1)

reviewed 09 Jun '11, 03:16

Alexandre%20Nizoux's gravatar image

Alexandre Ni...
215
accept rate: 0%

Yes, you should be able to use the commercial database from maxmind as well.

(24 Jun '11, 08:28) ziegfried ♦
Reviews related to version 1.1 (current is 1.1.2)

Hi,

as far as I can see, IPInfoDB has changed its format... Do yu plan to migrate your app to the new format?

cheers, Andy

P.S.: Great App!!

comments (1)

reviewed 02 May '11, 23:36

kochera's gravatar image

kochera
8116
accept rate: 0%

edited 02 May '11, 23:37

Actually no, since they also changed their usage terms, the Maxmind geolocation database will be leveraged instead.

(05 May '11, 11:10) ziegfried ♦
Your review

Did you find this app useful?

Preview toggle preview

Price: Free
Author: ziegfried
Version: 1.1.2
Splunk compatibility: 5.x, 4.3, 4.2
Updated:
License: Creative Commons BY-NC-SA 2.5

This app is not covered by any support agreements in place with Splunk. If you have questions about the installation or operation of this app, please contact the author.

Follow this app

Log In to enable email subscriptions

RSS:

Reviews

Reviews + Comments

Ask a Question
Copyright © 2005-2012 Splunk Inc. All rights reserved.