Project

General

Profile

Feature #12167

Updated by Tom Clegg about 7 years ago

h2. Background 

 When an arv-put process is slow or broken, it is useful to grep logs for related server-side activity. To make this easy, arv-put should generate a "request ID" at startup, and all components should propagate this ID to log files and other Arvados components. 

 h2. Specific improvements 

 * A request ID looks like "req-" + 20 random alphanum chars, e.g., @req-iNjNZUDqU35yxSXFYJ8x@ 
 * (Done) If running in verbose --verbose mode, arv-put should log the request ID to stderr as soon as it's generated. 
 * Whether running in verbose --verbose mode or not, arv-put should log the request ID in every error log. Presumably the easiest way to do this is to include it in _every_ log message, just like timestamp and PID. Thus, a failed arv-put will _always_ log its request ID, because every failure mode causes a log (make sure this is true even for SIGINT). 
 * (Done) Each keepstore/keepproxy/API request made by arv-put should include a request header like @X-Request-Id: req-iNjNZUDqU35yxSXFYJ8x@ (no ETag-esque quoting). 
 * (Done) When keepproxy receives an X-Request-Id request header, it should propagate that same header when it makes keepstore requests in the course of servicing the incoming request instead of inventing its own. Keepproxy's request log should include whichever request ID was used. Keepproxy's generated IDs should be updated to the above format. 
 * keepproxy should also send the X-Request-Id when making API requests. 
 * (Done) When keepstore receives an X-Request-Id request header, it should include the header value in the corresponding request log; otherwise it should generate a random one. 
 * (Done) When API server receives an X-Request-Id request header, it should include the header value in the corresponding request log; otherwise it should generate a random one. 
 * (Done) Workbench should include its request ID in an X-Request-Id header instead of a "current_request_id" query parameter. (Current code tries to do this, but it doesn't work. Rails middleware is probably overwriting it.) 
 * (Done) Workbench's generated IDs should also be updated to the above format. 
 * (Done) When Workbench receives an X-Request-Id request header, it should use that header value instead of generating a new request ID. 

 Of course, incoming headers can be broken or malicious, so logs should use appropriate quoting. 

Back