- Kibana Guide: other versions:
- What is Kibana?
- What’s new in 8.15
- Kibana concepts
- Quick start
- Set up
- Install Kibana
- Configure Kibana
- Alerting and action settings
- APM settings
- Banners settings
- Cases settings
- Enterprise Search settings
- Fleet settings
- i18n settings
- Logging settings
- Logs settings
- Metrics settings
- Monitoring settings
- Reporting settings
- Search sessions settings
- Secure settings
- Security settings
- Spaces settings
- Task Manager settings
- Telemetry settings
- URL drilldown settings
- Start and stop Kibana
- Access Kibana
- Securing access to Kibana
- Add data
- Upgrade Kibana
- Configure security
- Configure reporting
- Configure logging
- Configure monitoring
- Command line tools
- Production considerations
- Discover
- Dashboard and visualizations
- Canvas
- Maps
- Build a map to compare metrics by country or region
- Track, visualize, and alert on assets in real time
- Map custom regions with reverse geocoding
- Heat map layer
- Tile layer
- Vector layer
- Plot big data
- Search geographic data
- Configure map settings
- Connect to Elastic Maps Service
- Import geospatial data
- Troubleshoot
- Reporting and sharing
- Machine learning
- Graph
- Alerting
- Observability
- Playground
- Security
- Dev Tools
- Fleet
- Osquery
- Stack Monitoring
- Stack Management
- Cases
- Connectors
- Amazon Bedrock
- Cases
- CrowdStrike
- D3 Security
- Google Gemini
- IBM Resilient
- Index
- Jira
- Microsoft Teams
- Observability AI Assistant
- OpenAI
- Opsgenie
- PagerDuty
- SentinelOne
- Server log
- ServiceNow ITSM
- ServiceNow SecOps
- ServiceNow ITOM
- Swimlane
- Slack
- Tines
- Torq
- Webhook
- Webhook - Case Management
- xMatters
- Preconfigured connectors
- License Management
- Maintenance windows
- Manage data views
- Numeral Formatting
- Rollup Jobs
- Manage saved objects
- Security
- Spaces
- Advanced Settings
- Tags
- Upgrade Assistant
- Watcher
- REST API
- Get features API
- Kibana spaces APIs
- Kibana role management APIs
- User session management APIs
- Saved objects APIs
- Data views API
- Index patterns APIs
- Alerting APIs
- Action and connector APIs
- Cases APIs
- Import and export dashboard APIs
- Logstash configuration management APIs
- Machine learning APIs
- Osquery manager API
- Short URLs APIs
- Get Task Manager health
- Upgrade assistant APIs
- Synthetics APIs
- Uptime APIs
- Kibana plugins
- Troubleshooting
- Accessibility
- Release notes
- Kibana 8.15.5
- Kibana 8.15.4
- Kibana 8.15.3
- Kibana 8.15.2
- Kibana 8.15.1
- Kibana 8.15.0
- Kibana 8.14.3
- Kibana 8.14.2
- Kibana 8.14.1
- Kibana 8.14.0
- Kibana 8.13.4
- Kibana 8.13.3
- Kibana 8.13.2
- Kibana 8.13.1
- Kibana 8.13.0
- Kibana 8.12.2
- Kibana 8.12.1
- Kibana 8.12.0
- Kibana 8.11.4
- Kibana 8.11.3
- Kibana 8.11.2
- Kibana 8.11.1
- Kibana 8.11.0
- Kibana 8.10.4
- Kibana 8.10.3
- Kibana 8.10.2
- Kibana 8.10.1
- Kibana 8.10.0
- Kibana 8.9.2
- Kibana 8.9.1
- Kibana 8.9.0
- Kibana 8.8.2
- Kibana 8.8.1
- Kibana 8.8.0
- Kibana 8.7.1
- Kibana 8.7.0
- Kibana 8.6.1
- Kibana 8.6.0
- Kibana 8.5.2
- Kibana 8.5.1
- Kibana 8.5.0
- Kibana 8.4.3
- Kibana 8.4.2
- Kibana 8.4.1
- Kibana 8.4.0
- Kibana 8.3.3
- Kibana 8.3.2
- Kibana 8.3.1
- Kibana 8.3.0
- Kibana 8.2.3
- Kibana 8.2.2
- Kibana 8.2.1
- Kibana 8.2.0
- Kibana 8.1.3
- Kibana 8.1.2
- Kibana 8.1.1
- Kibana 8.1.0
- Kibana 8.0.0
- Kibana 8.0.0-rc2
- Kibana 8.0.0-rc1
- Kibana 8.0.0-beta1
- Kibana 8.0.0-alpha2
- Kibana 8.0.0-alpha1
- Developer guide
Clean your data
editClean your data
editGeospatial fields in Elasticsearch have certain restrictions that need to be addressed before upload. On this section a few recipes will be presented to help troubleshooting common issues on this type of data.
Convert to GeoJSON or Shapefile
editUse ogr2ogr (part of the GDAL/OGR suite) to convert datasets into a GeoJSON or Esri Shapefile. For example, use the following commands to convert a GPX file into JSON:
# Example GPX file from https://www.topografix.com/gpx_sample_files.asp # # Convert the GPX waypoints layer into a GeoJSON file $ ogr2ogr \ -f GeoJSON "waypoints.geo.json" \ # Output format and file name "fells_loop.gpx" \ # Input File Name "waypoints" # Input Layer (usually same as file name) # Extract the routes layer into a GeoJSON file $ ogr2ogr -f "GeoJSON" "routes.geo.json" "fells_loop.gpx" "routes"
Convert to WGS84 Coordinate Reference System
editElasticsearch only supports WGS84 Coordinate Reference System. Use ogr2ogr
to convert from other coordinate systems to WGS84.
On the following example, ogr2ogr
transforms a shapefile from NAD83 to WGS84. The input CRS is detected automatically thanks to the .prj
sidecar file in the source dataset.
# Example NAD83 file from https://www2.census.gov/geo/tiger/GENZ2018/shp/cb_2018_us_county_5m.zip # # Convert the Census Counties shapefile to WGS84 (EPSG:4326) $ ogr2ogr -f "Esri Shapefile" \ "cb_2018_us_county_5m.4326.shp" \ # Output file -t_srs "EPSG:4326" \ # EPSG:4326 is the code for WGS84 "cb_2018_us_county_5m.shp" \ # Input file "cb_2018_us_county_5m" # Input layer
Improve performance by breaking out complex geometries into one geometry per document
editSometimes geospatial datasets are composed by a small amount of geometries that contain a very large amount of individual part geometries. A good example of this situation is on detailed world country boundaries datasets where records for countries like Canada or Philippines have hundreds of small island geometries. Depending on the final usage of a dataset, you may want to break out this type of dataset to keep one geometry per document, considerably increasing the performance of your index.
# Example NAD83 file from www12.statcan.gc.ca/census-recensement/2011/geo/bound-limit/files-fichiers/2016/ler_000b16a_e.zip # # Check the number of input features $ ogrinfo -summary ler_000b16a_e.shp ler_000b16a_e \ | grep "Feature Count" Feature Count: 76 # Convert to WGS84 exploding the multiple geometries $ ogr2ogr \ -f "Esri Shapefile" \ "ler_000b16a_e.4326-parts.shp" \ # Output file -explodecollections \ # Convert multiparts into single records -t_srs "EPSG:4326" \ # Transform to WGS84 "ler_000b16a_e.shp" \ # Input file "ler_000b16a_e" # Input layer # Check the number of geometries in the output file # to confirm the 76 records are exploded into 27 thousand rows $ ogrinfo -summary ler_000b16a_e.4326-parts.shp ler_000b16a_e.4326 \ | grep "Feature Count" Feature Count: 27059
A dataset containing records with a very large amount of parts as the one from the example above may even hang in Kibana Maps file uploader.
Reduce the precision
editSome machine generated datasets are stored with more decimals than are strictly necessary. For reference, the GeoJSON RFC 7946 coordinate precision section specifies six digits to be a common default to around 10 centimeters on the ground. The file uploader in the Maps application will automatically reduce the precision to 6 decimals but for big datasets it is better to do this before uploading.
ogr2ogr
generates GeoJSON files with 7 decimal degrees when requesting RFC7946
compliant files but using the COORDINATE_PRECISION
GeoJSON layer creation option it can be downsized even more if that is OK for the usage of the data.
# Example NAD83 file from https://www2.census.gov/geo/tiger/GENZ2018/shp/cb_2018_us_county_5m.zip # # Generate a 2008 GeoJSON file $ ogr2ogr \ -f GeoJSON \ "cb_2018_us_county_5m.4326.geo.json" \ # Output file -t_srs "EPSG:4326" \ # Convert to WGS84 -lco "RFC7946=NO" \ # Request a 2008 GeoJSON file "cb_2018_us_county_5m.shp" \ "cb_2018_us_county_5m" # Generate a RFC7946 GeoJSON file $ ogr2ogr \ -f GeoJSON \ "cb_2018_us_county_5m.4326.RFC7946.geo.json" \ # Output file -t_srs "EPSG:4326" \ # Convert to WGS84 -lco "RFC7946=YES" \ # Request a RFC7946 GeoJSON file "cb_2018_us_county_5m.shp" \ "cb_2018_us_county_5m" # Generate a RFC7946 GeoJSON file with just 5 decimal figures $ ogr2ogr \ -f GeoJSON \ "cb_2018_us_county_5m.4326.RFC7946_mini.geo.json" \ # Output file -t_srs "EPSG:4326" \ # Convert to WGS84 -lco "RFC7946=YES" \ # Request a RFC7946 GeoJSON file -lco "COORDINATE_PRECISION=5" \ # Downsize to just 5 decimal positions "cb_2018_us_county_5m.shp" \ "cb_2018_us_county_5m" # Compare the disk size of the three output files $ du -h cb_2018_us_county_5m.4326*.geo.json 7,4M cb_2018_us_county_5m.4326.geo.json 6,7M cb_2018_us_county_5m.4326.RFC7946.geo.json 6,1M cb_2018_us_county_5m.4326.RFC7946_mini.geo.json
Simplifying region datasets
editRegion datasets are polygon datasets where the boundaries of the documents don’t overlap. This is common for administrative boundaries, land usage, and other continuous datasets. This type of datasets has the special feature that any geospatial operation modifying the lines of the polygons needs to be applied in the same way to the common sides of the polygons to avoid the generation of thin gap and overlap artifacts.
mapshaper
is an excellent tool to work with this type of datasets as it understands datasets of this nature and works with them accordingly.
Depending on the usage of a region dataset, different geospatial precisions may be adequate. A world countries dataset that is displayed for the entire planet does not need the same precision as a map of the countries in the South Asian continent.
mapshaper
offers a simplify
command that accepts percentages, resolutions, and different simplification algorithms.
# Example NAD83 file from https://www2.census.gov/geo/tiger/GENZ2018/shp/cb_2018_us_county_5m.zip # # Generate a baseline GeoJSON file from OGR $ ogr2ogr \ -f GeoJSON "cb_2018_us_county_5m.ogr.geo.json" \ -t_srs "EPSG:4326" \ -lco RFC7946=YES \ "cb_2018_us_county_5m.shp" \ "cb_2018_us_county_5m" # Simplify at different percentages with mapshaper $ for pct in 10 50 75 99; do \ mapshaper \ -i "cb_2018_us_county_5m.shp" \ # Input file -proj "EPSG:4326" \ # Output projection -simplify "${pct}%" \ # Simplification -o cb_2018_us_county_5m.mapshaper_${pct}.geo.json; \ # Output file done # Compare the size of the output files $ du -h cb_2018_us_county_5m*.geo.json 2,0M cb_2018_us_county_5m.mapshaper_10.geo.json 4,1M cb_2018_us_county_5m.mapshaper_50.geo.json 5,3M cb_2018_us_county_5m.mapshaper_75.geo.json 6,7M cb_2018_us_county_5m.mapshaper_99.geo.json 6,7M cb_2018_us_county_5m.ogr.geo.json
Fixing incorrect geometries
editThe Maps application expects valid GeoJSON or Shapefile datasets. Apart from the mentioned CRS requirement, geometries need to be valid. Both ogr2ogr
and mapshaper
have options to try to fix invalid geometries:
-
OGR
-makevalid
option -
Mapshaper
-clean
command
And so much more
editogr2ogr
and mapshaper
are excellent geospatial ETL (Extract Transform and Load) utilities that can do much more than viewed here. Reading the documentation in detail is worth investment to improve the quality of the datasets by removing unwanted fields, refining data types, validating value domains, etc. Finally, being command line utilities, both can be automated and added to QA pipelines.
On this page