diff options
author | Nick Mathewson <nickm@torproject.org> | 2008-05-29 02:51:47 +0000 |
---|---|---|
committer | Nick Mathewson <nickm@torproject.org> | 2008-05-29 02:51:47 +0000 |
commit | 582046e85fe93eed06aaae3a1066f77988656d79 (patch) | |
tree | bda13b9b0232318c937e588c72d311bd5897625f /doc/spec/dir-spec.txt | |
parent | ac330d9ba72c2379372682216b329f384dbe30fe (diff) | |
download | tor-582046e85fe93eed06aaae3a1066f77988656d79.tar tor-582046e85fe93eed06aaae3a1066f77988656d79.tar.gz |
Document our timelines for fetching consensuses. The language is not as clear as it could be; can anybody make it better?
svn:r14803
Diffstat (limited to 'doc/spec/dir-spec.txt')
-rw-r--r-- | doc/spec/dir-spec.txt | 25 |
1 files changed, 22 insertions, 3 deletions
diff --git a/doc/spec/dir-spec.txt b/doc/spec/dir-spec.txt index 3419abb3a..d2851f603 100644 --- a/doc/spec/dir-spec.txt +++ b/doc/spec/dir-spec.txt @@ -1336,9 +1336,15 @@ $Id$ - The cache has no consensus document. - The cache's consensus document is no longer valid. Otherwise, the cache downloads a new consensus document at a randomly - chosen time after its current consensus stops being fresh. (This time is - chosen at random to avoid swarming the authorities at the start of each - period.) + chosen time in the first half-interval after its current consensus + stops being fresh. (This time is chosen at random to avoid swarming + the authorities at the start of each period. The interval size is + inferred from the difference between the valid-after time and the + fresh-until time on the consensus.) + + [For example, if a cache has a consensus that became valid at 1:00, + and is fresh until 2:00, that cache will fetch a new consensus at + a random time between 2:00 and 2:30.] 4.4. Downloading and storing router descriptors (authorities and caches) @@ -1515,6 +1521,19 @@ $Id$ from an authority, they should not need to go to the authority directly again.) + To avoid swarming the caches whenever a consensus expires, the + clients download new consensuses at a randomly chosen time after the + caches are expected to have a fresh consensus, but before their + consensus will expire. (This time is chosen uniformly at random from + the interval between the time 3/4 into the first interval after the + consensus is no longer fresh, and 7/8 of the time remaining after + that before the consensus is invalid.) + + [For example, if a cache has a consensus that became valid at 1:00, + and is fresh until 2:00, and expires at 4:00, that cache will fetch + a new consensus at a random time between 2:45 and 3:50, since 3/4 + of the one-hour interval is 45 minutes, and 7/8 of the remaining 75 + minutes is 65 minutes.] 5.2. Downloading and storing router descriptors |