-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathheartbeat.py
executable file
·86 lines (70 loc) · 2.86 KB
/
heartbeat.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
#-*- coding:utf-8 -*-
import requests
import time
import logging
import logging.handlers
import psutil
import os
import signal
import argparse
import threading
import smtplib
from email.mime.text import MIMEText
logger = logging.getLogger(__name__)
formatter = logging.Formatter('[%(asctime)s][%(levelname)s|%(filename)s:%(lineno)s] >> %(message)s')
streamHandler = logging.StreamHandler()
file_max_bytes = 5 * 1024 * 1024
fileHandler = logging.handlers.RotatingFileHandler('./oj_server.log', maxBytes=file_max_bytes, backupCount=50)
streamHandler.setFormatter(formatter)
fileHandler.setFormatter(formatter)
logger.addHandler(streamHandler)
logger.addHandler(fileHandler)
logger.setLevel(level=logging.DEBUG)
backend_conn = 0
db_conn = 0
redis_conn = 0
judge_conn = 0
def sendEmail(error): # 전송할 메일 내용 정의
print("sending Email for Notification")
s = smtplib.SMTP('smtp.gmail.com', 587)
s.starttls()
s.login('dcucode@gmail.com', 'wwwsnslab1!')
msg = MIMEText('Get up and FIX IT\n')
msg['Subject'] = '[DCU SERVER NOTIFICATION] Server has been broken by [' + error + ']'
s.sendmail('dcucode@gmail.com', ['junhp12345@gmail.com'], msg.as_string())
s.quit()
print("Email has been sent")
while True:
if backend_conn > 5:
# os.system('echo "08502740" | sudo -S docker restart oj-backend') # 본 서버 사용 시 아래 코드 주석 처리 후 해당 코드 사용
os.system('echo "akqthtk1!" | sudo -S docker restart oj-backend') # 에러 카운트가 5를 넘은 경우, (백엔드가 25초 이상 무응답 시) 백엔드 컨테이너를 재시작한다.
t = threading.Thread(target=sendEmail("backend"))
t.start()
jdata = r.json()
jdata['error'] = "Server Restarted"
logger.info(jdata)
backend_conn = 0
try:
requesttime = time.time()
r = requests.get("http://localhost:8085/api/heartbeat") # 프론트엔드 주소 입력 (환경에 따라 포트 변경 필요)
requesttime = time.time() - requesttime
print("백엔드 하트비트 앱 요청에 걸리는 시간", requesttime)
print("logging app cpu usage", psutil.cpu_percent())
print("logging app memory usage", psutil.virtual_memory().percent)
jsonerr = r.json()['error']
postgres = r.json()['data']['postgres']
if postgres is False: # Postgres 미동작하는 경우
db_conn = db_conn + 1
if jsonerr is not None: # 프론트엔드가 동작하지 않는 경우
json = r.json()
logger.info(json)
frontend_conn = frontend_conn + 1
else:
backend_conn = 0
json = r.json()
logger.info(json)
except Exception as e:
# catastrophic error. bail.
logger.info(e)
backend_conn = backend_conn + 1
time.sleep(5)