searxng/searx
Alexandre Flament 01e2648e93 Simplify search.py, basically updated PR #518
The timeouts in settings.yml is about the total time (not only the HTTP request but also the prepare the request and parsing the response)
It was more or less the case before since the threaded_requests function ignores the thread after the timeout even the HTTP request is ended.

New / changed stats :
* page_load_time : record the HTTP request time
* page_load_count: the number of HTTP request
* engine_time : the execution total time of an engine
* engine_time_count : the number of "engine_time" measure

The avg response times in the preferences are the engine response time (engine_load_time / engine_load_count)

To sum up :
* Search.search() filters the engines that can't process the request
* Search.search() call search_multiple_requests function
* search_multiple_requests creates one thread per engine, each thread runs the search_one_request function
* search_one_request calls the request function, make the HTTP request, calls the response function, extends the result_container
* search_multiple_requests waits for the the thread to finish (or timeout)
2016-11-05 13:45:20 +01:00
..
data
engines Simplify search.py, basically updated PR #518 2016-11-05 13:45:20 +01:00
plugins
static
templates
translations
__init__.py
autocomplete.py
languages.py
poolrequests.py
preferences.py
query.py
results.py
search.py Simplify search.py, basically updated PR #518 2016-11-05 13:45:20 +01:00
settings.yml
settings_robot.yml
testing.py
utils.py
version.py
webapp.py Simplify search.py, basically updated PR #518 2016-11-05 13:45:20 +01:00