OSD_DRONE_CLIENT.php 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899
  1. <?php
  2. require('../vendor/autoload.php');
  3. use \PhpMqtt\Client\MqttClient;
  4. use \PhpMqtt\Client\ConnectionSettings;
  5. use think\facade\Cache;
  6. use think\facade\Db;
  7. date_default_timezone_set("PRC");
  8. // define('HOST', '127.0.0.1');
  9. // define('PORT', '6379');
  10. // define('PASSWORD', '123456');
  11. // define('DATABASE', 2);
  12. define('HOST', '172.16.222.97');
  13. define('PORT', '6379');
  14. define('PASSWORD', 'jrtk.net');
  15. define('DATABASE', 4);
  16. (new think\App())->initialize();
  17. function app_redis()
  18. {
  19. static $redis = null;
  20. static $conn = false;
  21. if (!$conn) {
  22. connect: //定义标签
  23. $redis = new Redis();
  24. try {
  25. //建立的Redis短连接,在请求结束后不会自动关闭,相当于持久连接.
  26. $conn = $redis->connect(HOST, PORT);
  27. $conn = $redis->auth(PASSWORD);
  28. $conn = $redis->select(DATABASE);
  29. // 连接成功,返回$redis对象,连接失败,返回false.
  30. return ($conn === true) ? $redis : false;
  31. } catch (Exception $e) {
  32. return false;
  33. }
  34. } else {
  35. // 这里假设PHP-FPM在处理一个请求的时间内,Redis连接都是可用的.
  36. // 所以只在PHP-CLI下检查Redis连接的状态,进行断线重连.
  37. if (php_sapi_name() === 'cli') {
  38. try {
  39. // ping用于检查当前连接的状态,成功时返回+PONG,失败时抛出一个RedisException对象.
  40. // ping失败时警告:
  41. // Warning: Redis::ping(): connect() failed: Connection refused
  42. // var_dump('AAAAAAAAA', $redis);
  43. // echo 'Redis 连接状态' . $redis->ping() . PHP_EOL;
  44. @$redis->ping();
  45. if (!$redis->ping()) {
  46. goto connect; //跳转到标签出继续执行连接操作
  47. }
  48. } catch (Exception $e) {
  49. // 信息如 Connection lost 或 Redis server went away
  50. echo $e->getMessage();
  51. echo 'Redis 连接失败 重新连接:' . PHP_EOL;
  52. // 断线重连
  53. goto connect;
  54. }
  55. }
  56. return $redis;
  57. }
  58. }
  59. while (1) {
  60. $jsonData= app_redis()->rpop("OSD_DRONE_LIST");
  61. if(!$jsonData){
  62. sleep(3);
  63. continue;
  64. }
  65. $redis_data=json_decode($jsonData,true);
  66. $device_sn=$redis_data['from'];
  67. $gateway=$redis_data['gateway'];
  68. $data=$redis_data['val'];
  69. if(!isset($data['longitude']) || !isset($data['latitude']) || !isset($data['height'])){
  70. continue;
  71. }
  72. $save_data=[
  73. 'longitude'=>$data['longitude'],
  74. 'latitude'=>$data['latitude'],
  75. 'height'=>$data['height'],
  76. // 'time'=>$data['timestamp'],
  77. 'time'=>time(),
  78. 'gateway'=>$gateway,
  79. 'device_sn'=>$device_sn ,
  80. ];
  81. var_dump($save_data);
  82. try {
  83. $res = Db::connect('uav')->name('uav_route')->insertGetId($save_data);
  84. var_dump($res);
  85. } catch (\Exception $e) {
  86. // 错误日志或重新连接逻辑
  87. echo "错误: " . $e->getMessage().PHP_EOL;
  88. // 重新连接逻辑(示例):
  89. Db::connect('uav')->close(); // 关闭现有连接
  90. Db::connect('uav')->connect(); // 重新连接
  91. $res = Db::connect('uav')->name('uav_route')->insertGetId($save_data);
  92. var_dump($res);
  93. }
  94. }