Yermek68 commited on
Commit
85c1154
·
verified ·
1 Parent(s): be14f74

Update metrics_core.py

Browse files
Files changed (1) hide show
  1. metrics_core.py +16 -6
metrics_core.py CHANGED
@@ -1,35 +1,45 @@
 
 
1
  import json
2
  import os
3
  from datetime import datetime
4
 
 
 
 
 
 
 
 
 
 
 
5
  METRICS_FILE = "metrics_log.json"
6
 
 
7
  def save_metrics(metrics: dict):
8
  """
9
  Сохраняет метрики в локальный JSON-файл.
 
10
  """
11
- # Добавляем timestamp
12
  metrics["timestamp"] = datetime.now().strftime("%Y-%m-%d %H:%M:%S")
13
 
14
- # Если файла нет — создаём новый список
15
  if not os.path.exists(METRICS_FILE):
16
  with open(METRICS_FILE, "w", encoding="utf-8") as f:
17
  json.dump([], f, ensure_ascii=False, indent=2)
18
 
19
- # Загружаем старые метрики
20
  with open(METRICS_FILE, "r", encoding="utf-8") as f:
21
  data = json.load(f)
22
 
23
- # Добавляем новые
24
  data.append(metrics)
25
 
26
- # Сохраняем обратно
27
  with open(METRICS_FILE, "w", encoding="utf-8") as f:
28
  json.dump(data, f, ensure_ascii=False, indent=2)
29
 
 
30
  def read_metrics():
31
  """
32
- Возвращает все сохранённые метрики.
33
  """
34
  if not os.path.exists(METRICS_FILE):
35
  return []
 
1
+ # core/metrics_core.py
2
+
3
  import json
4
  import os
5
  from datetime import datetime
6
 
7
+ from core.alerters import ConsoleAlerter, FileAlerter
8
+ from core.alert_manager import AlertManager
9
+ from core.failsafe_core import failsafe
10
+
11
+ # Настройка алертов — FailSafe будет сообщать о сбоях
12
+ alert_manager = AlertManager([
13
+ ConsoleAlerter(),
14
+ FileAlerter("failsafe_errors.log")
15
+ ])
16
+
17
  METRICS_FILE = "metrics_log.json"
18
 
19
+ @failsafe(alert_manager)
20
  def save_metrics(metrics: dict):
21
  """
22
  Сохраняет метрики в локальный JSON-файл.
23
+ Если произойдет ошибка, она будет автоматически залогирована, и функция не упадёт.
24
  """
 
25
  metrics["timestamp"] = datetime.now().strftime("%Y-%m-%d %H:%M:%S")
26
 
 
27
  if not os.path.exists(METRICS_FILE):
28
  with open(METRICS_FILE, "w", encoding="utf-8") as f:
29
  json.dump([], f, ensure_ascii=False, indent=2)
30
 
 
31
  with open(METRICS_FILE, "r", encoding="utf-8") as f:
32
  data = json.load(f)
33
 
 
34
  data.append(metrics)
35
 
 
36
  with open(METRICS_FILE, "w", encoding="utf-8") as f:
37
  json.dump(data, f, ensure_ascii=False, indent=2)
38
 
39
+ @failsafe(alert_manager)
40
  def read_metrics():
41
  """
42
+ Возвращает все сохранённые метрики. Ошибки логируются и не ломают систему.
43
  """
44
  if not os.path.exists(METRICS_FILE):
45
  return []