Что делает MaxDegreeOfParallelism? ⇐ C#
-
Anonymous
Что делает MaxDegreeOfParallelism?
Я использую Parallel.ForEach и делаю некоторые обновления базы данных, теперь без установки MaxDegreeOfParallelism, машина с двухъядерным процессором приводит к тайм-аутам клиента SQL, где еще четырехъядерный процессор машина с основным процессором почему-то не истекает по тайм-ауту.
Теперь я не могу контролировать, какие ядра процессора доступны для выполнения моего кода, но есть ли какие-то настройки, которые я могу изменить с помощью MaxDegreeOfParallelism, которые, вероятно, будут выполнять меньше операций одновременно и не приведут к тайм-аутам ?
Я могу увеличить таймауты, но это не очень хорошее решение: если на более низком процессоре я смогу обрабатывать меньше операций одновременно, это снизит нагрузку на процессор.
Хорошо, я прочитал все остальные сообщения и MSDN, но не пострадает ли установка MaxDegreeOfParallelism на более низкое значение на моих четырехъядерных компьютерах?
Например, можно ли как-нибудь сделать что-то вроде: если у ЦП два ядра, то использовать 20, если у ЦП четыре ядра, то 40?
Я использую Parallel.ForEach и делаю некоторые обновления базы данных, теперь без установки MaxDegreeOfParallelism, машина с двухъядерным процессором приводит к тайм-аутам клиента SQL, где еще четырехъядерный процессор машина с основным процессором почему-то не истекает по тайм-ауту.
Теперь я не могу контролировать, какие ядра процессора доступны для выполнения моего кода, но есть ли какие-то настройки, которые я могу изменить с помощью MaxDegreeOfParallelism, которые, вероятно, будут выполнять меньше операций одновременно и не приведут к тайм-аутам ?
Я могу увеличить таймауты, но это не очень хорошее решение: если на более низком процессоре я смогу обрабатывать меньше операций одновременно, это снизит нагрузку на процессор.
Хорошо, я прочитал все остальные сообщения и MSDN, но не пострадает ли установка MaxDegreeOfParallelism на более низкое значение на моих четырехъядерных компьютерах?
Например, можно ли как-нибудь сделать что-то вроде: если у ЦП два ядра, то использовать 20, если у ЦП четыре ядра, то 40?
Мобильная версия