Caching-Problem mit WebClient / HttpClient

Ich entwickle einen Code, um alle 30 Sekunden einen Bitstamp-Börsenticker abzufragen. Dies ist ein Code, den ich habe:

public IObservable<string> Stream(Uri way, WebClient wc)
    {
        Func<IObserver<string>, Task> Fun = async Observer =>
        {
            var res = await wc.DownloadStringTaskAsync(way);
            Observer.OnNext(value: res);
        };

        return Observable.Create<string>(Fun);
    }

public IObservable<string> GetDelay(int secs)
    {
        var exe = TimeSpan.FromSeconds(secs);
        return Observable.Empty<string>("x").Delay(exe);
    }

Stream(new Uri("https://bitstamp.net/api/ticker"), new WebClient { }).Concat(GetDelay(30))
    .Repeat(5).Subscribe(res => Debug.WriteLine("got result: {0}", res));

Das Problem ist, dassWebClient (undHttpClientauch) beide geben nach dem ersten Aufruf zwischengespeicherte Ergebnisse zurück, die mit demselben Zeitstempel angezeigt werden:

got result: {"high": "690.00", "last": "645.10", "timestamp": "1387715532" ... }
got result: {"high": "690.00", "last": "645.10", "timestamp": "1387715532" ... }
...

Selbst nach dem Ausschalten der Netzwerke geben sie das Ergebnis normal zurück, so dass es offensichtlich irgendwo zwischengespeichert wird. Das Hinzufügen von etwas wie "? Cache = random" funktioniert nicht, da Anforderungsparameter für den Ticker in Bitstamp nicht zulässig sind. RahmenHeaders[HttpRequestHeader.CacheControl] = "no-cache" zumWebRequest geht auch nicht.

Wie kann ich dieses seltsame Caching-Verhalten beheben?

Antworten auf die Frage(2)

Ihre Antwort auf die Frage