Como limitar a quantidade de operações de E / S assíncronas simultâneas?

// 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);
});

Aqui está o problema, ele inicia mais de 1000 solicitações da Web simultâneas. Existe uma maneira fácil de limitar a quantidade simultânea dessas solicitações http async? De modo que não mais de 20 páginas da web são baixadas a qualquer momento. Como fazê-lo da maneira mais eficiente?

questionAnswers(12)

yourAnswerToTheQuestion