Alarm.php 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081
  1. <?php
  2. namespace common\helpers;
  3. class Alarm
  4. {
  5. // 预警平台Domain
  6. private static $url = 'http://ibs-cn.elken.com:8017';
  7. // 推送预警信息API
  8. private static $reportApi = '/api/report';
  9. /**
  10. * @throws \Exception
  11. */
  12. public static function reportAlarm($message)
  13. {
  14. // 业务环境白名单
  15. // $allowPlatform = \Yii::$app->params['allowPlatform'];
  16. // 是否开启预警信息推送
  17. $reportAlarmOpen = Cache::getSystemConfig()['reportAlarmOpen']['VALUE'];
  18. // 业务平台token
  19. $message['platform-id'] = \Yii::$app->params['alarmAccessToken'];
  20. // 级别
  21. $message['stance'] = $message['stance'] ?? 2;
  22. // 类型
  23. $message['brand'] = $message['brand'] ?? 'OTA';
  24. // 日志入库
  25. // Tool::alarmCall($message);
  26. // 日志写文件
  27. LoggerTool::error($message);
  28. // 业务环境过滤
  29. if ($reportAlarmOpen /**&& (count($allowPlatform) == 0 || in_array($_SERVER['HTTP_HOST'], $allowPlatform))*/) {
  30. $result = self::curl(json_encode($message));
  31. LoggerTool::info(['push AlarmService 1. ', $result]);
  32. if ($result['code'] != 200) {
  33. // 重新推送一次,如果失败,写错误日志
  34. $result = self::curl(json_encode($message));
  35. LoggerTool::info(['push AlarmService 2. ', $result]);
  36. if ($result['code'] != 200) {
  37. LoggerTool::error(['预警信息上报平台失败. traceId【' . $message['trace-id'] . '】', $result]);
  38. }
  39. }
  40. LoggerTool::notice(sprintf('信息推送预警平台成功. platformID[%s], traceID[%s]', $message['platform-id'], $message['trace-id']));
  41. } else {
  42. $reason = '';
  43. if ($reportAlarmOpen == '0') {
  44. $reason = '上报预警平台状态不允许(reportAlarmOpen=关闭)';
  45. }
  46. // if (!count($allowPlatform)) {
  47. // $reason = '主机地址不在白名单中(host=' . $_SERVER['HTTP_HOST'] . ')';
  48. // }
  49. LoggerTool::error('预警信息上报平台取消. traceId【' . $message['trace-id'] . '】. 原因:' . $reason);
  50. }
  51. }
  52. private static function curl($post_string)
  53. {
  54. $ch = curl_init();
  55. curl_setopt($ch, CURLOPT_URL, self::$url . self::$reportApi);
  56. curl_setopt($ch, CURLOPT_POST, 1);
  57. curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 5);
  58. curl_setopt($ch, CURLOPT_HTTPHEADER, array ('Content-Type: application/json;charset=utf-8'));
  59. curl_setopt($ch, CURLOPT_POSTFIELDS, $post_string);
  60. curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
  61. // 线下环境不用开启curl证书验证, 未调通情况可尝试添加该代码
  62. curl_setopt ($ch, CURLOPT_SSL_VERIFYHOST, 0);
  63. curl_setopt ($ch, CURLOPT_SSL_VERIFYPEER, 0);
  64. $response = curl_exec($ch);
  65. curl_close($ch);
  66. if (curl_errno($ch)) {
  67. // 请求失败,返回错误信息
  68. return ['code' => 500, 'message' => curl_error($ch)];
  69. }
  70. return ['code' => 200, 'message' => json_decode($response, true)];
  71. }
  72. }