[mod] better search request exception handling

This commit is contained in:
Adam Tauber 2014-12-19 20:01:01 +01:00
parent 8c05c00762
commit 1c969186bf

View File

@ -34,14 +34,27 @@ from searx.query import Query
number_of_searches = 0 number_of_searches = 0
def search_request_wrapper(fn, url, engine_name, **kwargs):
try:
return fn(url, **kwargs)
except Exception, e:
# increase errors stats
engines[engine_name].stats['errors'] += 1
# print engine name and specific error message
print('[E] Error with engine "{0}":\n\t{1}'.format(
engine_name, str(e)))
return
def threaded_requests(requests): def threaded_requests(requests):
timeout_limit = max(r[2]['timeout'] for r in requests) timeout_limit = max(r[2]['timeout'] for r in requests)
search_start = time() search_start = time()
for fn, url, request_args, engine_name in requests: for fn, url, request_args, engine_name in requests:
request_args['timeout'] = timeout_limit request_args['timeout'] = timeout_limit
th = threading.Thread( th = threading.Thread(
target=fn, target=search_request_wrapper,
args=(url,), args=(fn, url, engine_name),
kwargs=request_args, kwargs=request_args,
name='search_request', name='search_request',
) )
@ -79,16 +92,7 @@ def make_callback(engine_name, results_queue, callback, params):
return return
# callback # callback
try: search_results = callback(response)
search_results = callback(response)
except Exception, e:
# increase errors stats
engines[engine_name].stats['errors'] += 1
# print engine name and specific error message
print '[E] Error with engine "{0}":\n\t{1}'.format(
engine_name, str(e))
return
# add results # add results
for result in search_results: for result in search_results: