Dữ liệu đường theo thời gian thực cung cấp thông tin cập nhật mới nhất về tình trạng đường và các sự kiện cho những tuyến đường bạn chọn, hỗ trợ hoạt động giám sát linh hoạt và phản hồi nhanh chóng. Dữ liệu này khác với dữ liệu được thu thập định kỳ có trong BigQuery và phù hợp với những trường hợp cần thông tin kịp thời.
Dữ liệu này truyền liên tục và bao gồm: thời lượng chuyến đi (cho biết thời gian di chuyển trên một tuyến đường) và khoảng thời gian đọc tốc độ (cho biết mật độ đoạn đường).
Để truy cập vào dữ liệu đường theo thời gian thực, hợp đồng của bạn phải bao gồm gói Vận hành theo thời gian thực.
Tạo gói thuê bao Pub/Sub trên đám mây
Sau khi dự án của bạn được thiết lập để nhận dữ liệu theo thời gian thực, một chủ đề Google Cloud Pub/Sub chuyên dụng sẽ có sẵn cho dự án của bạn. Đây là chủ đề Pub/Sub nơi bạn có thể tìm thấy dữ liệu theo thời gian thực cho tất cả các tuyến đường bạn đã tạo.
Mã mẫu sau đây cho thấy định dạng của URL chủ đề.
projects/maps-platform-roads-management/topics/rmi-roadsinformation-PROJECT_NUMBER
Bạn phải đăng ký chủ đề Pub/Sub được cung cấp cho bạn để nhận các thông báo dữ liệu theo thời gian thực. Hãy xem phần Đăng ký theo dõi một chủ đề để biết thông tin tổng quan nhanh về cách đăng ký theo dõi và sử dụng tin nhắn từ một chủ đề Cloud Pub/Sub.
Giản đồ thông báo dữ liệu giao thông theo thời gian thực
Mỗi thông báo dữ liệu theo thời gian thực đều kết hợp các dữ liệu như:
- Thông tin chi tiết về đường, chẳng hạn như
travel_duration
vàspeed_reading_intervals
. - Giá trị nhận dạng tuyến đường, chẳng hạn như
selected_route_id
vàdisplay_name
.
Mỗi thông báo được xuất bản tuân theo định dạng Protobuf sau.
syntax = "proto3"; // Contains the road information like travel duration and speed reading // intervals for a selected route. message RoadsInformation { message TravelDuration { // The duration of travel through the route based on current road conditions. float duration_in_seconds = 1; // The duration of travel through the route without taking road conditions into consideration. float static_duration_in_seconds = 2; } message Timestamp { // Represents seconds of UTC time since Unix epoch // 1970-01-01T00:00:00Z. Must be from 0001-01-01T00:00:00Z to // 9999-12-31T23:59:59Z inclusive. int64 seconds = 1; // Non-negative fractions of a second at nanosecond resolution. Negative // second values with fractions must still have non-negative nanos values // that count forward in time. Must be from 0 to 999,999,999 // inclusive. int32 nanos = 2; } // Represents the latitude and longitude of a coordinate // within speed reading interval. message LatLng { float latitude = 1; float longitude = 2; } message SpeedReadingInterval { // The coordinates on the polyline for the speed reading interval repeated LatLng interval_coordinates = 1; // Describes the categorized current speed of road conditions. Possible values are: // - "NORMAL": Road is flowing smoothly, no slowdown is detected. // - "SLOW": Slowdown detected, but no congestion formed. // - "TRAFFIC_JAM": Congestion detected. string speed = 2; } // Id for selected_route. string selected_route_id = 1; // User provided name for the route. string display_name = 2; // Intervals representing the road density across the route. repeated SpeedReadingInterval speed_reading_intervals = 3; // Travel time information. TravelDuration travel_duration = 4; // The time the road data was collected. Timestamp retrieval_time = 5; // Contains a geojson polyline representing the optimal route determined based // on user's input waypoints. string route_geometry = 6; }
Truyền dữ liệu về tuyến đường đến BigQuery bằng Pub/Sub
Bạn có thể định cấu hình một thuê bao Pub/Sub để truyền trực tiếp dữ liệu đường vào một bảng BigQuery. Điều này cho phép lưu trữ dữ liệu mạnh mẽ và phân tích hiệu quả thông tin về tuyến đường được cung cấp. Trước khi thiết lập loại thuê bao này, bạn cần tạo một tập dữ liệu và bảng phù hợp trong dự án BigQuery để ghi dữ liệu vào.
Hãy xem phần Truyền trực tuyến dữ liệu đến BigQuery để biết hướng dẫn chi tiết về cách tạo một thuê bao Pub/Sub ghi vào BigQuery.
Giản đồ bảng BigQuery
Các thông báo được xuất bản lên chủ đề Pub/Sub của bạn (cũng có thể được ghi vào bảng BigQuery) sẽ tuân theo giản đồ sau. Bạn nên sử dụng giản đồ này khi tạo bảng BigQuery đích để đảm bảo khả năng tương thích.
{ "mode": "NULLABLE", "name": "selected_route_id", "type": "STRING", "description": "Id for selected_route." }, { "mode": "NULLABLE", "name": "display_name", "type": "STRING", "description": "User provided name for the route." }, { "fields": [ { "mode": "NULLABLE", "name": "speed", "type": "STRING", "description": "Describes the categorized current speed of traffic. Possible values are: \"NORMAL\": Traffic is flowing smoothly, no slowdown is detected. \"SLOW\": Slowdown detected, but no traffic jam formed. \"TRAFFIC_JAM\": Traffic jam detected." }, { "fields": [ { "mode": "NULLABLE", "name": "latitude", "type": "NUMERIC" }, { "mode": "NULLABLE", "name": "longitude", "type": "NUMERIC" } ], "mode": "REPEATED", "name": "interval_coordinates", "type": "RECORD", "description": "The geometry for this interval" } ], "mode": "REPEATED", "name": "speed_reading_intervals", "type": "RECORD", "description": "Intervals representing the traffic density across the route." }, { "fields": [ { "mode": "NULLABLE", "name": "duration_in_seconds", "type": "FLOAT", "description": "The duration of travel through the route based on current traffic conditions." }, { "mode": "NULLABLE", "name": "static_duration_in_seconds", "type": "FLOAT", "description": "The duration of travel through the route without taking traffic conditions into consideration." } ], "mode": "NULLABLE", "name": "travel_duration", "type": "RECORD", "description": "Travel time information." }, { "fields": [ { "mode": "NULLABLE", "name": "seconds", "type": "INTEGER", "description": "Represents seconds of UTC time since Unix epoch 1970-01-01T00:00:00Z. Must be from 0001-01-01T00:00:00Z to 9999-12-31T23:59:59Z inclusive." }, { "mode": "NULLABLE", "name": "nanos", "type": "INTEGER", "description": "Non-negative fractions of a second at nanosecond resolution. Negative second values with fractions must still have non-negative nanos values that count forward in time. Must be from 0 to 999,999,999 inclusive." } ], "mode": "NULLABLE", "name": "retrieval_time", "type": "RECORD", "description": "The time the traffic data was collected." }, { "mode": "NULLABLE", "name": "route_geometry", "type": "STRING", "description": "Contains a geojson polyline representing the optimal route determined based on user's input waypoints" }