Jak ograniczyć liczbę współbieżnych operacji asynchronicznych we / wy?

// let's say there is a list of 1000+ URLs
string[] urls = { "http://google.com", "http://yahoo.com", ... };

// now let's send HTTP requests to each of these URLs in parallel
urls.AsParallel().ForAll(async (url) => {
    var client = new HttpClient();
    var html = await client.GetStringAsync(url);
});

Oto problem, uruchamia ponad 1000 jednoczesnych żądań internetowych. Czy istnieje prosty sposób na ograniczenie równoczesnej liczby asynchronicznych żądań http? Aby w danym momencie nie pobrano więcej niż 20 stron internetowych. Jak to zrobić w najbardziej efektywny sposób?

questionAnswers(12)

yourAnswerToTheQuestion