我有大约 100 个 GPS 设备每 10 秒定期发送坐标。我的客户想要实时反向地理编码来查看他的车辆以及表格视图上的位置。在添加地理编码脚本之前,我已经设置了一个队列以将所有这些数据包保存在 db 中,如下所示
使用 websocket 接收 TCP IP 消息
public function onMessage(ConnectionInterface $conn, $msg) { //get the message // send the dispatch job to save it in db $this->dispatch(new SavePacketsToDb($key_1, json_encode( array( 'company_id' => $key_1, 'vehicle_id' => $company->vehicle_id, 'tracker_id' => $company->tracker_id, 'lat' => $lat, 'lng' => $lng, 'imei' => $imei, 'datetime' => $datetime, ) )));
}
运行队列
public function handle(){ $lat=$obj->lat; $lng=$obj->lng; $url = "https://maps.googleapis.com/maps/api/geocode/json?latlng=" . $lat . "," . $lng . "&key=mykey"; $json = file_get_contents($url); $data = json_decode($json); $status = $data->status; $address = ''; if ($status == "OK") { // echo "from geocode address"; echo $address = $data->results[0]->formatted_address; } else{ $address=NULL; } //save to db }
如果我在队列中包含此地理编码,我只是担心它是否适用于 1000 个并发设备,有没有更好的方法呢?