Trace.php 2.3 KB

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