Alarm.php 3.0 KB

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