mirror of
https://github.com/chubin/wttr.in
synced 2025-01-26 02:34:59 +00:00
bin/proxy.py: smoothed cache load
This commit is contained in:
parent
413f23bec3
commit
ea0786edbf
1 changed files with 24 additions and 8 deletions
32
bin/proxy.py
32
bin/proxy.py
|
@ -23,6 +23,7 @@ import sys
|
||||||
import os
|
import os
|
||||||
import time
|
import time
|
||||||
import json
|
import json
|
||||||
|
import hashlib
|
||||||
|
|
||||||
import requests
|
import requests
|
||||||
import cyrtranslit
|
import cyrtranslit
|
||||||
|
@ -73,29 +74,44 @@ TRANSLATIONS = load_translations()
|
||||||
def _find_srv_for_query(path, query): # pylint: disable=unused-argument
|
def _find_srv_for_query(path, query): # pylint: disable=unused-argument
|
||||||
return 'http://api.worldweatheronline.com'
|
return 'http://api.worldweatheronline.com'
|
||||||
|
|
||||||
|
def _cache_file(path, query):
|
||||||
|
"""Return cache file name for specified `path` and `query`
|
||||||
|
and for the current time.
|
||||||
|
|
||||||
|
Do smooth load on the server, expiration time
|
||||||
|
is slightly varied basing on the path+query sha1 hash digest.
|
||||||
|
"""
|
||||||
|
|
||||||
|
digest = hashlib.sha1(("%s %s" % (path, query)).encode("utf-8")).hexdigest()
|
||||||
|
digest_number = ord(digest[0])
|
||||||
|
expiry_interval = 60*(30+digest_number)
|
||||||
|
|
||||||
|
timestamp = "%010d" % (int(time.time())//1000/expiry_interval*expiry_interval)
|
||||||
|
filename = os.path.join(PROXY_CACHEDIR, timestamp, path, query)
|
||||||
|
|
||||||
|
return filename
|
||||||
|
|
||||||
|
|
||||||
def _load_content_and_headers(path, query):
|
def _load_content_and_headers(path, query):
|
||||||
if is_testmode():
|
if is_testmode():
|
||||||
cache_file = "test/proxy-data/data1"
|
cache_file = "test/proxy-data/data1"
|
||||||
else:
|
else:
|
||||||
timestamp = time.strftime("%Y%m%d%H", time.localtime())
|
cache_file = _cache_file(path, query)
|
||||||
cache_file = os.path.join(PROXY_CACHEDIR, timestamp, path, query)
|
|
||||||
try:
|
try:
|
||||||
return (open(cache_file, 'r').read(),
|
return (open(cache_file, 'r').read(),
|
||||||
json.loads(open(cache_file+".headers", 'r').read()))
|
json.loads(open(cache_file+".headers", 'r').read()))
|
||||||
except IOError:
|
except IOError:
|
||||||
return None, None
|
return None, None
|
||||||
|
|
||||||
def _touch_empty_file(path, query, content, headers):
|
def _touch_empty_file(path, query):
|
||||||
timestamp = time.strftime("%Y%m%d%H", time.localtime())
|
cache_file = _cache_file(path, query)
|
||||||
cache_file = os.path.join(PROXY_CACHEDIR + ".empty", timestamp, path, query)
|
|
||||||
cache_dir = os.path.dirname(cache_file)
|
cache_dir = os.path.dirname(cache_file)
|
||||||
if not os.path.exists(cache_dir):
|
if not os.path.exists(cache_dir):
|
||||||
os.makedirs(cache_dir)
|
os.makedirs(cache_dir)
|
||||||
open(cache_file, 'w').write("")
|
open(cache_file, 'w').write("")
|
||||||
|
|
||||||
def _save_content_and_headers(path, query, content, headers):
|
def _save_content_and_headers(path, query, content, headers):
|
||||||
timestamp = time.strftime("%Y%m%d%H", time.localtime())
|
cache_file = _cache_file(path, query)
|
||||||
cache_file = os.path.join(PROXY_CACHEDIR, timestamp, path, query)
|
|
||||||
cache_dir = os.path.dirname(cache_file)
|
cache_dir = os.path.dirname(cache_file)
|
||||||
if not os.path.exists(cache_dir):
|
if not os.path.exists(cache_dir):
|
||||||
os.makedirs(cache_dir)
|
os.makedirs(cache_dir)
|
||||||
|
@ -212,7 +228,7 @@ def proxy(path):
|
||||||
except ValueError:
|
except ValueError:
|
||||||
attempts -= 1
|
attempts -= 1
|
||||||
|
|
||||||
_touch_empty_file(path, query_string, content, headers)
|
_touch_empty_file(path, query_string)
|
||||||
if response:
|
if response:
|
||||||
headers = {}
|
headers = {}
|
||||||
headers['Content-Type'] = response.headers['content-type']
|
headers['Content-Type'] = response.headers['content-type']
|
||||||
|
|
Loading…
Reference in a new issue