mirror of
https://github.com/bjc/prosody.git
synced 2025-04-04 21:57:45 +03:00
mod_http_file_share: Collect cache hit/miss statistics for downloads
This commit is contained in:
parent
e45dee37bd
commit
cdbb77ccbf
1 changed files with 5 additions and 1 deletions
|
@ -274,6 +274,9 @@ function handle_upload(event, path) -- PUT /upload/:slot
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
|
local download_cache_hit = module:measure("download_cache_hit", "rate");
|
||||||
|
local download_cache_miss = module:measure("download_cache_miss", "rate");
|
||||||
|
|
||||||
function handle_download(event, path) -- GET /uploads/:slot+filename
|
function handle_download(event, path) -- GET /uploads/:slot+filename
|
||||||
local request, response = event.request, event.response;
|
local request, response = event.request, event.response;
|
||||||
local slot_id = path:match("^[^/]+");
|
local slot_id = path:match("^[^/]+");
|
||||||
|
@ -281,7 +284,7 @@ function handle_download(event, path) -- GET /uploads/:slot+filename
|
||||||
local cached = upload_cache:get(slot_id);
|
local cached = upload_cache:get(slot_id);
|
||||||
if cached then
|
if cached then
|
||||||
module:log("debug", "Cache hit");
|
module:log("debug", "Cache hit");
|
||||||
-- TODO stats (instead of logging?)
|
download_cache_hit();
|
||||||
basename = cached.name;
|
basename = cached.name;
|
||||||
filesize = cached.size;
|
filesize = cached.size;
|
||||||
filetype = cached.type;
|
filetype = cached.type;
|
||||||
|
@ -290,6 +293,7 @@ function handle_download(event, path) -- GET /uploads/:slot+filename
|
||||||
-- TODO cache negative hits?
|
-- TODO cache negative hits?
|
||||||
else
|
else
|
||||||
module:log("debug", "Cache miss");
|
module:log("debug", "Cache miss");
|
||||||
|
download_cache_miss();
|
||||||
local slot, when = errors.coerce(uploads:get(nil, slot_id));
|
local slot, when = errors.coerce(uploads:get(nil, slot_id));
|
||||||
if not slot then
|
if not slot then
|
||||||
module:log("debug", "uploads:get(%q) --> not-found, %s", slot_id, when);
|
module:log("debug", "uploads:get(%q) --> not-found, %s", slot_id, when);
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue