BigQuery ist ein leistungsstarkes Tool für Analysen. Sie können damit Logs für längere Zeiträume speichern und SQL-ähnliche Abfragen auf die Daten ausführen. Wenn Sie BigQuery für die Analyse verwenden möchten, müssen Sie Ihre Protokolle wie im nächsten Abschnitt beschrieben explizit an BigQuery weiterleiten.
Logs an BigQuery weiterleiten
- Erstellen Sie im Log-Explorer einen Filter, mit dem die Fleet Engine-Protokolle isoliert werden:
Fleetengine.googleapis.com/Fleet
. - Klicken Sie im Bereich Abfrageergebnisse auf das Menü Aktionen oder Weitere Aktionen und wählen Sie Senke erstellen aus.
- Geben Sie einen Namen für den Datensammler an, z. B. FleetEngineLogsSink. Klicken Sie auf Weiter.
- Wählen Sie unter Sink-Ziel die Option BigQuery-Dataset aus.
- Wählen Sie unter BigQuery-Dataset auswählen die Option Neues BigQuery-Dataset erstellen aus.
- Geben Sie im Dialogfeld Dataset erstellen eine Dataset-ID ein.
- Lassen Sie alles andere unverändert und klicken Sie auf Dataset erstellen.
- Setzen Sie ein Häkchen bei Partitionierte Tabellen verwenden. Klicken Sie auf Weiter.
- Lassen Sie die Optionen Logs auswählen, die in der Senke enthalten sein sollen und Logs auswählen, die aus der Senke herausgefiltert werden sollen unverändert.
- Klicken Sie auf Senke erstellen.
Die Protokolle sollten jetzt mit dem Einfügen in das BigQuery-Dataset beginnen. Das kann einige Zeit dauern. Siehe auch Protokolle an unterstützte Ziele weiterleiten.
Sobald Sie Protokolldaten an BigQuery weiterleiten, werden automatisch mehrere Tabellen unter dem Dataset FleetEngineLogs ausgefüllt, eine für jeden Protokolltyp:
- CreateVehicle
- GetVehicle
- ListVehicles
- SearchVehicles
- UpdateVehicle
- CreateTrip
- GetTrip
- UpdateTrip
- ListTrips
Die Tabellennamen folgen dem folgenden Muster:
project_id.data_set.log_name
Wenn das Projekt beispielsweise test-project heißt und der Dataset-Name FleetEngineLogs ist, hat die Tabelle CreateTrip
den folgenden Namen:
test-project.FleetEngineLogs.fleetengine_googleapis_com_create_trip
Beispielabfragen für BigQuery
In den folgenden Beispielabfragen wird gezeigt, wie Sie in BigQuery nach verschiedenen Logeinträgen suchen können.
Anzahl der CreateTrips-Logs, nach Stunde gruppiert
SELECT TIMESTAMP_TRUNC(timestamp, HOUR) as hour,
count(*) as num_trips_created
FROM
`ProjectId.FleetEngineLogs.fleetengine_googleapis_com_create_trip`
GROUP BY hour
ORDER by hour
Anzahl der Haltestellen pro Fahrzeug und Stunde
SELECT
jsonpayload_v1_updatevehiclelog.request.vehicleid AS vehicle,
TIMESTAMP_TRUNC(timestamp, HOUR) AS hour,
COUNT(*) AS num_stops
FROM
`ProjectId.FleetEngineLogs.fleetengine_googleapis_com_update__vehicle`
WHERE
ARRAY_LENGTH(jsonpayload_v1_updatevehiclelog.request.vehicle.remainingvehiclejourneysegments) > 0
AND jsonpayload_v1_updatevehiclelog.request.vehicle.remainingvehiclejourneysegments[
OFFSET
(0)].stop.state = 'VEHICLE_STOP_STATE_LOG_ARRIVED'
GROUP BY
1,
2
ORDER BY
2
Mit dieser Abfrage können Sie beispielsweise Folgendes herausfinden:
- Fahrzeug A hat in Stunde 12 zehn Haltestellen und in Stunde 13 acht Haltestellen angefahren.
- Fahrzeug B hat in Stunde 11 fünf Haltestellen und in Stunde 12 sieben Haltestellen angefahren.
- Fahrzeug C hat in Stunde 13 zwölf Haltestellen und in Stunde 14 neun Haltestellen angefahren.
Weitere Informationen finden Sie unter An BigQuery weitergeleitete Logs ansehen.
BigQuery in Looker Studio einbinden
BigQuery kann in Business Intelligence-Tools eingebunden werden, um Dashboards für die Geschäftsanalyse zu erstellen. Weitere Informationen finden Sie unter Looker Studio.
Im folgenden Beispiel wird gezeigt, wie Sie ein Looker Studio-Dashboard zum Visualisieren von Fahrten und Fahrzeugbewegungen auf einer Karte erstellen.
- Öffnen Sie ein neues Looker Studio-Dashboard und wählen Sie BigQuery als Datenverbindung aus.
- Wählen Sie Benutzerdefinierte Abfrage aus und geben Sie das Cloud-Projekt manuell ein oder wählen Sie es aus, dem die Kosten in Rechnung gestellt werden sollen.
- Geben Sie eine der folgenden Abfragen in das Abfragefeld ein.
Beispielabfrage für Fahrten auf Abruf
SELECT
timestamp,
labels.vehicle_id,
jsonpayload_v1_updatevehiclelog.response.lastlocation.location.latitude AS lat,
jsonpayload_v1_updatevehiclelog.response.lastlocation.location.longitude AS lng
FROM
`ProjectId.TableName.fleetengine_googleapis_com_update_vehicle`
Beispielabfrage für geplante Aufgaben
SELECT
labels.delivery_vehicle_id,
jsonpayload_v1_updatedeliveryvehiclelog.response.lastlocation.rawlocation.longitude as lat, jsonpayload_v1_updatedeliveryvehiclelog.response.lastlocation.rawlocation.latitude as lng
FROM `ProjectID.TableName.fleetengine_googleapis_com_update_delivery_vehicle`
- Wählen Sie Diagrammtyp als Karte mit Blasen und dann das Feld Standort aus.
- Wählen Sie Feld hinzufügen aus.
- Geben Sie einen Namen für das Feld ein und fügen Sie die folgende Formel hinzu:
CONCAT(lat, ",", lng)
. - Legen Sie den Typ auf Standort -> Breitengrad, Längengrad fest.
- Sie können dem Dashboard Steuerelemente hinzufügen, um Daten zu filtern. Wählen Sie beispielsweise den Filter Zeitraum aus.
- Bearbeiten Sie das Feld für den Zeitraum, um einen Standardzeitraum auszuwählen.
- Sie können für
vehicle_id
zusätzliche Drop-down-Listen hinzufügen. Mit diesen Steuerelementen können Sie die Bewegung des Fahrzeugs oder die Bewegung innerhalb einer Fahrt visualisieren.
Beispielausgabe in Looker Studio:
Nächste Schritte
Informationen zur Einhaltung der Datenaufbewahrungsrichtlinien finden Sie unter Protokollaufbewahrung einschränken.