-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathheartbeat.py
45 lines (36 loc) · 1.2 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
from srun import SrunClient
import socket
import logging
logging.basicConfig(
format='%(asctime)s.%(msecs)03d [%(filename)s:%(lineno)d] %(message)s',
datefmt='## %Y-%m-%d %H:%M:%S'
)
logging.getLogger("heartbeat").setLevel(logging.INFO)
logger = logging.getLogger("heartbeat")
class HeartBeat:
CHECK_SERVER = 'www.baidu.com'
def check_connect(self):
with socket.socket() as s:
s.settimeout(3)
try:
status = s.connect_ex((self.CHECK_SERVER, 443))
return status == 0
except Exception as e:
print(e)
return False
def login(self):
#srun_client = SrunClient(print_log=False)
srun_client = SrunClient()
# Use this method frequently to check online is not suggested!
# if srun_client.check_online(): return
logger.info('NOT ONLINE, TRY TO LOGIN!')
srun_client.login()
def check_online(self):
while not self.check_connect():
self.login()
if __name__ == "__main__":
HeartBeat().check_online()
# import time
# while 1:
# check_online()
# time.sleep(10)