Trace.php 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130
  1. <?php
  2. namespace UCore;
  3. use Illuminate\Support\Facades\Cache;
  4. class Trace
  5. {
  6. static $ob;
  7. public $data = [];
  8. public $error = [];
  9. public function __destruct()
  10. {
  11. if(app()->runningUnitTests() || defined('IS_UNITTEST')){
  12. return true;
  13. }
  14. if (!function_exists('app') || !app() || !app()->bound('config')) {
  15. return true;
  16. }
  17. if(!defined('RUN_UNIQID')){
  18. define('RUN_UNIQID', uniqid());
  19. }
  20. self::getCache()->put('trace_' . RUN_UNIQID, $this->data, 3600);
  21. $list = self::getCache()->get('trace_list', []);
  22. if (count($list) > 300) {
  23. array_shift($list);
  24. array_shift($list);
  25. }
  26. $list[] = RUN_UNIQID;
  27. self::getCache()->put('trace_list', $list, 3600);
  28. }
  29. /**
  30. * @return \Illuminate\Contracts\Cache\Repository
  31. */
  32. static public function getCache()
  33. {
  34. if(app()->runningUnitTests() || defined('IS_UNITTEST')){
  35. return new class {
  36. public function put($key, $value, $ttl = null) { return true; }
  37. public function get($key, $default = null) { return $default; }
  38. };
  39. }
  40. return Cache::store();
  41. }
  42. /**
  43. * 获取数据
  44. *
  45. * @param $unid
  46. * @return mixed
  47. */
  48. static public function getData($unid)
  49. {
  50. return self::getCache()->get('trace_' . $unid, []);
  51. }
  52. static public function getlist()
  53. {
  54. return self::getCache()->get('trace_list', []);
  55. }
  56. static public function getOb()
  57. {
  58. if (!self::$ob) {
  59. return self::$ob = new Trace();
  60. }
  61. return self::$ob;
  62. }
  63. /**
  64. * 增加数据
  65. *
  66. * @param string $name
  67. * @param mixed $data
  68. * @return Trace
  69. */
  70. static public function addData($name, $data)
  71. {
  72. $ob = self::getOb();
  73. $ob->data[$name] = $data;
  74. return $ob;
  75. }
  76. /**
  77. * 增加错误
  78. *
  79. * @param mixed $data
  80. * @return Trace
  81. */
  82. static public function addError($data)
  83. {
  84. $ob = self::getOb();
  85. $ob->error[] = $data;
  86. return $ob;
  87. }
  88. /**
  89. * 追加数据
  90. * @param $name
  91. * @param $data
  92. * @return Trace
  93. */
  94. static public function applyData($name, $data)
  95. {
  96. $ob = self::getOb();
  97. $ob->data[$name][] = $data;
  98. return $ob;
  99. }
  100. }