-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathpost_ping_as_json.py
44 lines (32 loc) · 1.18 KB
/
post_ping_as_json.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
import re
import sys
import json
from datetime import datetime
import pytz
import requests
if __name__ == '__main__':
if(len(sys.argv) == 1):
print('set index name')
exit;
index_name = sys.argv[1].strip()
url = "http://127.0.0.1:9200/{}/ping".format(index_name)
for txt in iter(sys.stdin.readline, ""):
payload = {}
now_timestamp = datetime.now().timestamp()
tz = pytz.timezone("Japan")
created_time = datetime.fromtimestamp(now_timestamp, tz).isoformat()
payload['createdAt'] = created_time
time_matcher = re.search("time=(\d+(\.\d*)?|\.\d+)", txt)
if time_matcher:
payload['pingTime'] = float(time_matcher.group(1))
payload['canConnect2Endpoint'] = 1
elif "timeout" in txt:
payload['canConnect2Endpoint'] = 0
else:
continue
with requests.post(
url,
json.dumps(payload, separators=(',', ':')),
headers = {'Content-Type': 'application/json'}) as response:
print(response.status_code, payload)
print('end')