Bu dokümanda, Google Cloud BigQuery ve Google Haritalar Platformu Veri Kümeleri API'sinde konum verileriyle harita verisi görselleştirmeleri oluşturmak için bir referans mimari ve örnek (ör. açık belediye verilerini analiz etme, telekomünikasyon kapsama haritası oluşturma veya mobil araç filosunun hareket izlerini görselleştirme) sağlanmaktadır.
Harita verisi görselleştirmeleri, kullanıcılarla etkileşim kurmak ve konum verilerindeki mekansal analizleri ortaya çıkarmak için güçlü bir araçtır. Konum verileri, nokta, çizgi veya poligon özelliklerine sahip verilerdir. Örneğin, hava durumu haritaları tüketicilerin seyahatleri anlamalarına, planlamalarına ve fırtınalara hazırlanmalarına yardımcı olur. İş zekası haritaları, kullanıcıların veri analizlerinden elde edilen analizleri keşfetmelerine yardımcı olur. Telekomünikasyon haritaları ise kullanıcıların sağlayıcılarının belirli bir hizmet alanındaki kapsamını ve kalitesini anlamalarına yardımcı olur.
Ancak uygulama geliştiricilerin, performanslı ve mükemmel bir kullanıcı deneyimi sunan büyük harita verisi görselleştirmeleri oluşturması zordur. Büyük veriler istemci tarafına belleğe yüklenmesi gerektiğinden, ilk harita yükleme süreleri yavaşlar. Görsel, bellek ve GPU kısıtlamaları olan düşük kaliteli cep telefonları da dahil olmak üzere tüm cihazlarda yüksek performanslı olmalıdır. Son olarak, geliştiricilerin taşınabilir, güvenilir ve büyük verilerle performanslı olan büyük bir veri oluşturma kitaplığı seçmesi gerekir.
Referans Mimari
Büyük veri görselleştirmeleri içeren uygulamalar geliştirmek için iki ana bileşen gerekir.
- Müşteri arka uç: İşleme ve depolama gibi tüm arka uç uygulama verileri ve hizmetleri.
- Müşteri istemcisi: Harita görselleştirme bileşeni içeren uygulama kullanıcı arayüzünüz.
Aşağıda, bu iki bileşenin büyük veri görselleştirme uygulaması oluşturmak için uygulama kullanıcısı, Google Cloud ve Google Haritalar Platformu ile nasıl etkileşime geçtiğini gösteren bir sistem şeması verilmiştir.
Tasarımla ilgili dikkat edilmesi gereken noktalar
Google Cloud ve Google Haritalar Platformu'nu kullanarak yüksek performanslı bir veri görselleştirme oluşturmak için dikkate alınması gereken çeşitli tasarım noktaları vardır.
- Kaynak veri boyutu ve güncelleme sıklığı.
- Geojson biçimindeki kaynak veriler 5 MB'tan küçükse veya çok sık güncelleniyorsa (ör. canlı hava durumu radar tahmini) verileri uygulamanızda istemci tarafında geojson nesnesi olarak sunmayı ve deck.gl katmanıyla oluşturmayı deneyin.
- Verilerinizin boyutu 5 MB'tan büyükse ve saatte en fazla bir kez güncelleniyorsa bu belgedeki Datasets API mimarisini kullanabilirsiniz.
- Veri kümeleri 350 MB'a kadar dosyaları destekler.
- Verileriniz 350 MB'tan büyükse veri kümelerine aktarmadan önce kaynak dosyasındaki geometri verilerini azaltmayı veya basitleştirmeyi düşünebilirsiniz (Aşağıdaki Verileri Azaltma bölümüne bakın).
- Şema ve biçim
- Verilerinizin her özellik için dünya genelinde benzersiz bir kimlik özelliğine sahip olduğundan emin olun. Tekil kimlik, belirli bir özelliği seçip biçimlendirmenize veya verileri bir özellikle birleştirerek görselleştirmenize olanak tanır. Örneğin, "tıklama" kullanıcı etkinliğinde seçili bir özelliğe stil uygulama.
- Verilerinizi Datasets API spesifikasyonuna uygun olarak geçerli sütun adları, veri türleri ve GeoJSON nesnesi türleriyle CSV veya GeoJSON olarak biçimlendirin.
- BigQuery'de veri kümelerini kolayca oluşturmak için SQL CSV dışa aktarma dosyanızda
wkt
adlı bir sütun oluşturun. Veri kümeleri,wkt
adlı bir sütundan Well-Known Text (WKT) biçiminde geometriyi CSV'den içe aktarmayı destekler. - Verilerinizin geçerli geometri ve veri türlerine sahip olup olmadığını kontrol edin. Örneğin, GeoJSON, WGS84 koordinat sisteminde, geometri sarma sırası vb. olmalıdır.
- Bir kaynak dosyasındaki tüm geometrilerin geçerli olduğundan emin olmak için geojson-validate gibi bir araç veya bir kaynak dosyayı biçimler ya da koordinat sistemleri arasında dönüştürmek için ogr2ogr kullanın.
- Veri azaltma
- Özelliklerin özelliklerinin sayısını en aza indirin. Benzersiz tanımlayıcı anahtarında (örnek) çalışma zamanında bir özelliğe başka özellikler daha ekleyebilirsiniz.
- Mümkün olduğunda tesis nesneleri için tam sayı veri türleri kullanarak karo depolama alanını en aza indirin. Böylece karolar, istemci uygulamasında HTTPS üzerinden yüklenirken performanslı kalır.
- Çok karmaşık özellik geometrilerini basitleştirin ve/veya toplayın. Kaynak dosya boyutunu azaltmak ve harita performansını artırmak için karmaşık poligon geometrilerinde ST_Simplify gibi BigQuery işlevlerini kullanabilirsiniz.
- Karo oluşturma
- Google Haritalar Veri Kümeleri API'si, web veya mobil Haritalar SDK'sıyla kullanılmak üzere kaynak veri dosyanızdan harita karoları oluşturur.
- Harita karoları, görsel bir uygulamaya veri yüklemenin daha verimli yollarını sunan, yakınlaştırmaya dayalı bir dizine ekleme sistemidir.
- Harita parçaları, daha düşük yakınlaştırma düzeylerinde yoğun veya karmaşık özellikleri çıkarabilir. Kullanıcı bir eyalete veya ülkeye (ör. z5-z12) yakınlaştırdığında, bir şehre veya mahalleye (ör. z13-z18) yakınlaştırdığından farklı görünebilir.
Örnek: Londra'daki demiryolları
Bu örnekte, Google Cloud ve Google Haritalar'ı kullanarak Open Street Map (OSM) verilerinden Londra'daki tüm demiryollarını görselleştiren bir web uygulaması oluşturmak için referans mimariyi uygulayacağız.
Ön koşullar
- BigQuery korumalı alanına ve Cloud Console'a erişim
- Google Cloud projesi ve faturalandırma hesabınız olmalıdır.
1. Adım: BigQuery'de verileri sorgulayın
BigQuery'deki Herkese Açık Veri Kümeleri'ne gidin. "bigquery-public-data" veri kümesi ve geo_openstreetmap.planet_features
tablosu, tüm olası özellikler dahil olmak üzere dünyanın tamamına ait Open Street Map (OSM) verilerini içerir. amenity
, road
ve landuse
dahil olmak üzere sorgulanabilir tüm özellikleri OSM Wiki'de keşfedin.
Tabloyu SQL kullanarak sorgulamak için Cloud Shell'i veya BigQuery Cloud Console'u kullanın. Aşağıdaki kod snippet'inde, bir sınırlayıcı kutu ve ST_Intersects() işlevi kullanılarak yalnızca Londra'ya göre filtrelenen tüm demiryollarını sorgulamak için bq query komutu kullanılmaktadır.
Bu sorguyu Cloud Shell'den gerçekleştirmek için aşağıdaki kod snippet'ini çalıştırın. Ortamınızın proje kimliğini, veri kümesini ve tablo adını güncelleyin.
bq query --use_legacy_sql=false \
--destination_table PROJECTID:DATASET.TABLENAME \
--replace \
'SELECT
osm_id,
feature_type,
(SELECT value
FROM unnest(all_tags)
WHERE KEY = "name") AS name,
(SELECT value
FROM unnest(all_tags)
WHERE KEY = "railway") AS railway,
geometry as wkt
FROM bigquery-public-data.geo_openstreetmap.planet_features
WHERE ("railway") IN (SELECT key FROM unnest(all_tags))
AND ST_Intersects(
geometry,
ST_MakePolygon(ST_MakeLine(
[ST_GeogPoint(-0.549370, 51.725346),
ST_GeogPoint(-0.549370, 51.2529407),
ST_GeogPoint(0.3110581, 51.25294),
ST_GeogPoint(0.3110581, 51.725346),
ST_GeogPoint(-0.549370, 51.725346)]
))
)'
Sorgu şu sonucu döndürür:
- Her özellik için benzersiz bir tanımlayıcı
osm_id
feature_type
(ör.noktalar, çizgiler vb.)- Özelliğin
name
değeri (ör.Paddington Station
) railway
türü (ör.ana, turizm, askeri vb.)- Özelliğin
wkt
değeri: WKT biçiminde nokta, çizgi veya poligon geometrisi. WKT, BigQuery Coğrafya sütunlarının bir sorguda döndürdüğü standart veri biçimidir.
Not: Veri kümesi oluşturmadan önce sorgu sonuçlarınızı görsel olarak doğrulamak için Looker Studio'yu kullanarak verilerinizi BigQuery'deki bir kontrol panelinde hızlıca görselleştirebilirsiniz.
Tabloyu bir Google Cloud Storage paketindeki CSV dosyasına aktarmak için Cloud Shell'de bq extract komutunu kullanın:
bq extract \
--destination_format "CSV" \
--field_delimiter "," \
--print_header=true \
PROJECTID:DATASET.TABLENAME \
gs://BUCKET/FILENAME.csv
Not: Verilerinizi düzenli olarak güncellemek için Cloud Scheduler'ı kullanarak her adımı otomatikleştirebilirsiniz.
2. Adım: CSV dosyanızdan veri kümesi oluşturun
Ardından, Google Cloud Storage'daki (GCS) sorgu çıkışından bir Google Haritalar Platformu veri kümesi oluşturun. Veri Kümeleri API'sini kullanarak veri kümesi oluşturabilir ve ardından GCS'de barındırılan bir dosyadan veri kümenize veri yükleyebilirsiniz.
Başlamak için Google Cloud projenizde Haritalar Veri Kümeleri API'yi etkinleştirin ve API belgelerini inceleyin. Uygulamanızın arka ucundaki mantıktan Datasets API'yi çağırmak için Python ve Node.js istemci kitaplıkları vardır. Ayrıca, Cloud Console'da veri kümelerini manuel olarak oluşturmak için bir veri kümesi GUI'si de vardır.
Veri kümesi yüklemeniz tamamlandıktan sonra veri kümenizi Veri Kümeleri GUI'sinde önizleyebilirsiniz.
4. Adım: Veri kümenizi bir harita kimliğiyle ilişkilendirin
Veri kümeniz oluşturulduktan sonra ilişkili bir Harita Stili ile harita kimliği oluşturabilirsiniz. Harita stili düzenleyicisinde, bir harita kimliğini ve stilini veri kümesiyle ilişkilendirebilirsiniz. Buradan haritanızın görünümünü ve tarzını özelleştirmek için Bulut Tabanlı Harita Stilleri'ni de uygulayabilirsiniz.
5. Adım: İstemci uygulaması haritası görselleştirmenizi oluşturun
Son olarak, Maps JS API'yi kullanarak veri kümesini istemci taraflı bir veri görselleştirme uygulamasına ekleyebilirsiniz. Önceki adımdaki veri kümenizle ilişkili mapID'yi kullanarak harita nesnenizi başlatın. Ardından, veri kümesi katmanınızın stilini ve etkileşimini ayarlayın. Daha fazla bilgi için veri kümeleriyle veri odaklı stil oluşturma kılavuzunu inceleyin.
Haritalar JS API'yi kullanarak stili özelleştirebilir, stili dinamik olarak değiştirmek için etkinlik işleyicileri ekleyebilir ve daha fazlasını yapabilirsiniz. Örnekleri dokümanlarda bulabilirsiniz. Aşağıda, bu örnek için "feature_type" özelliğine göre nokta ve çizgi özellik stilini oluşturacak bir setStyle işlevi tanımlayacağız.
function setStyle(params) {
const map.getDatasetFeatureLayer("your-dataset-id");
const datasetFeature = params.feature;
const type = datasetFeature.datasetAttributes["feature_type"];
if (type == "lines") {
return {
fillColor: "blue",
strokeColor: "blue",
fillOpacity: 0.5,
strokeWeight: 1,
}
} else if (type == "points") {
return {
fillColor: "black",
strokeColor: "black",
strokeOpacity: 0.5,
pointRadius: 2,
fillOpacity: 0.5,
strokeWeight: 1,
}
}
}
Yukarıdaki kod, tek sayfalık bir web uygulamasında başlatıldığında aşağıdaki harita verisi görselini oluşturur:
Buradan, filtre özelliklerine mantık ekleyerek, kullanıcı etkileşimine göre stil ekleyerek ve uygulamanızın geri kalanıyla etkileşime geçerek setStyle()
işlevindeki harita görselleştirmenizi genişletebilirsiniz.
Sonuç
Bu dokümanda, Google Cloud ve Google Haritalar Platformu'nu kullanan büyük bir veri görselleştirme uygulamasının referans mimarisini ve örnek uygulamasını ele aldık. Bu referans mimariyi kullanarak, Google Cloud BigQuery'deki herhangi bir veri kümesinden Google Haritalar Veri Kümeleri API'yi kullanarak herhangi bir cihazda performanslı konum verisi görselleştirme uygulamaları oluşturabilirsiniz.
Sonraki İşlemler
Daha fazla bilgi:
- Google Haritalar Platformu Veri Kümeleri API dokümanları
- Verilerle Yönetilen Stillerle verilerinizi anlık olarak görme
- BigQuery'deki coğrafi analizlere giriş
- Coğrafi analizler için BigQuery'de GeoJSON kullanma
Katkıda bulunanlar
Başlıca yazarlar:
- Ryan Baumann, Google Haritalar Platformu Çözümleri Mühendislik Müdürü