170 похожих чатов

Есть WCF-сервис. У него в одном endpoint’е всего две строчки

- логирование и асинхронный запуск таска Task.Run() без ожидания результата. Под нагрузкой этот endpoint работает 7 секунд. Я правильно понимаю, что это означает, что забивается .Net Thread Pool?

2 ответов

5 просмотров

О, а вот это интересно! Да, вероятно, что тредпул забит, и поэтому запуск новой таски подтупливает. Но чтобы настолько сильно… странно это всё. Я бы советовал попрофилировать.

Valeriy-Osipov Автор вопроса
Dr. Friedrich von Never
О, а вот это интересно! Да, вероятно, что тредпул ...

А что значит "забит" ThreadPool? То есть, количество потоков в ThreadPool достигло максимального значения? Значение максимального количества потоков в ThreadPool на тестируемом сервере 32767. Я сомневаюсь, что создается столько потоков. Если смотреть на количество потоков через Task Manager, то оно порядка 200+. И тут у меня возникает полнейшее непонимание - что такое вообще Thread в .NET? Является ли .NET Thread оберткой над системным потоком (unmanaged thread)? Или Managed thread с системными потоками слабо связан? Настоящие системные потоки не могут существовать без выполняемого в них кода. Как только код в потоке заканчивает свое выполнение поток завершается. А управляемыке потоки в ThreadPool молучается - это просто объекты, которые могут существовать и без выполняемого в них кода? То есть, ThreadPool - это что-то типа DI-контейнера? А причина торможения я думаю не в "забитии" ThreadPool, а в том, что потоки, которые в этом ThreadPool в основном блокирующие. А ThreadPool создает новые потоки не моментально, а с задержкой (по моему, 500мс). И при быстром запросе большого количества потоков в принципе может возникать задержка. А профилировать я пытался. Пытался использовать dotTrace portable. У него есть несколько режимов профилирования. Мне нужен Timeline profile. И этот Timeline profile почему-то на этом сервере не заработал. Работает только Sample profile

Похожие вопросы

Обсуждают сегодня

А чем вам питонисты не угодили?😂
.
79
Язык Си можно выучить за день? По книжке ANSI C на 230 страниц
Vincent Vegan
29
Всем привет, написал код ниже, но он выдает сегфолт, в чем причина? #include <stdio.h> #include <stdlib.h> #include <string.h> struct product { char *name; float price; };...
buzz базз
75
Dim Dim, [02.07.2024 11:07] DB 0x62 Dim Dim, [02.07.2024 11:07] DB 0x66 Dim Dim, [02.07.2024 11:07] кто пояснит что это?
Dim Dim
14
Ошибка: segmentation fault (core dumped) Код: pastebin.com/BEsNNSSV Сообщение от компилятора: отсутствует ОС: Arch Linux Ядро: x86_64 Linux 6.9.7-arch1-1 Процессор: Intel Cele...
sec
4
Ребят, а за скок можно впарить анон чат с апишкой и веб админкой ?
Eugene Неелов
15
Ещё такой вопрос. Мне необходимо хранить пароль пользователя локально. Для этого планирую использовать ini файл. Это для автозаполнения полей логин и пароль при авторизации. Е...
Евгений
19
Кстати, я тут еще с одной темой столкнулся, вот учу я C++, на таком то ресурсе, а остальные постоянно советуют практиковаться, что то писать, проекты, но как писать если вот т...
aaswq1
7
Добрый день, чат. Мне в очередь из других RabbitMQ по shovel валятся метрики в формате текста для Prometheus. Помогите пожалуйста подружить RabbitMQ и Prometheus, чтобы он (...
Aleksey
4
@ahndmn @ayaw0_0 здарова, на чем пишете?
Aiwan \ (•◡•) / _bot
7
Карта сайта