mirror of
git://xwords.git.sourceforge.net/gitroot/xwords/xwords
synced 2025-01-03 23:04:08 +01:00
script for tracking message delivery
The http-based comms flow is stalling. This will help figure out why.
This commit is contained in:
parent
1648c9b3e3
commit
7efcdf0cb8
1 changed files with 100 additions and 0 deletions
100
xwords4/linux/scripts/list-message-flow.py
Executable file
100
xwords4/linux/scripts/list-message-flow.py
Executable file
|
@ -0,0 +1,100 @@
|
|||
#!/usr/bin/python3
|
||||
|
||||
import getopt, re, sys
|
||||
import json, psycopg2
|
||||
|
||||
"""
|
||||
|
||||
I want to understand why some messages linger on the database so
|
||||
long. So given one or more logfiles that track a linux client's
|
||||
interaction, look at what it sends and receives and compare that with
|
||||
what's in the relay's msgs table.
|
||||
|
||||
"""
|
||||
|
||||
DEVID_PAT = re.compile('.*linux_getDevIDRelay => (\d+)$')
|
||||
QUERY_GOT_PAT = re.compile('.*>(\d+:\d+:\d+):runWitCurl\(\): got for query: \"({.*})\"$')
|
||||
# <26828:7f03b7fff700>07:47:20:runWitCurl(): got for post: "{"data": ["AR03ggcAH2gwBwESbnVja3k6NTlmYTFjZmM6MTEw", "AR43ggcAH2gwDQBvAgEAAAAAvdAAAAAAAAAAAJIGUGxheWVyGg==", "AYALgw=="], "err": "timeout"}"
|
||||
POST_GOT_PAT = re.compile('.*>(\d+:\d+:\d+):runWitCurl\(\): got for post: \"({.*})\"$')
|
||||
def usage(msg = None):
|
||||
if msg: sys.stderr.write('ERROR:' + msg + '\n')
|
||||
sys.stderr.write('usage: ' + sys.argv[0] + ': (-l logfile)+ \n')
|
||||
sys.exit(1)
|
||||
|
||||
def parseLog(log, data):
|
||||
devIDs = []
|
||||
msgMap = {}
|
||||
for line in open(log):
|
||||
line = line.strip()
|
||||
aMatch = DEVID_PAT.match(line)
|
||||
if aMatch:
|
||||
devID = int(aMatch.group(1))
|
||||
if devID and (len(devIDs) == 0 or devIDs[-1] != devID):
|
||||
devIDs.append(devID)
|
||||
|
||||
aMatch = QUERY_GOT_PAT.match(line)
|
||||
if aMatch:
|
||||
rtime = aMatch.group(1)
|
||||
jobj = json.loads(aMatch.group(2))
|
||||
for relayID in jobj:
|
||||
msgs = jobj[relayID]
|
||||
for msgarr in msgs:
|
||||
for msg in msgarr:
|
||||
if not msg in msgMap: msgMap[msg] = []
|
||||
msgMap[msg].append({'rtime' : rtime,})
|
||||
if len(msgMap[msg]) > 1: print('big case')
|
||||
|
||||
aMatch = POST_GOT_PAT.match(line)
|
||||
if aMatch:
|
||||
jobj = json.loads(aMatch.group(2))
|
||||
for datum in jobj['data']:
|
||||
data.add(datum)
|
||||
|
||||
return devIDs, msgMap
|
||||
|
||||
def fetchMsgs(devIDs, msgMaps, data):
|
||||
foundCount = 0
|
||||
notFoundCount = 0
|
||||
|
||||
con = psycopg2.connect(database='xwgames')
|
||||
cur = con.cursor()
|
||||
query = "SELECT ctime, stime, stime-ctime as age, msg64 FROM msgs WHERE devid in (%s) order by ctime" \
|
||||
% (','.join([str(id) for id in devIDs]))
|
||||
# print(query)
|
||||
cur.execute(query)
|
||||
for row in cur:
|
||||
msg64 = row[3]
|
||||
for msgMap in msgMaps:
|
||||
if msg64 in msgMap:
|
||||
print('added:', row[0], 'sent:', row[1], 'received:', msgMap[msg64][0]['rtime'], 'age:', row[2])
|
||||
if msg64 in data:
|
||||
foundCount += 1
|
||||
else:
|
||||
notFoundCount += 1
|
||||
print('found:', foundCount, 'not found:', notFoundCount);
|
||||
|
||||
|
||||
def main():
|
||||
logs = []
|
||||
opts, args = getopt.getopt(sys.argv[1:], "l:")
|
||||
for option, value in opts:
|
||||
if option == '-l': logs.append(value)
|
||||
else: usage("unknown option" + option)
|
||||
|
||||
if len(logs) == 0: usage('at least one -l requried')
|
||||
|
||||
msgMaps = []
|
||||
devIDs = set()
|
||||
data = set()
|
||||
for log in logs:
|
||||
ids, msgMap = parseLog(log, data)
|
||||
msgMaps.append(msgMap)
|
||||
for id in ids: devIDs.add(id)
|
||||
|
||||
print(msgMaps)
|
||||
print(devIDs)
|
||||
fetchMsgs(devIDs, msgMaps, data)
|
||||
|
||||
##############################################################################
|
||||
if __name__ == '__main__':
|
||||
main()
|
Loading…
Reference in a new issue