|
62 / 63 / 28
Регистрация: 10.01.2018
Сообщений: 360
|
||||||
.NET 4.x Управляемый ThreadPool28.03.2018, 12:02. Показов 2015. Ответов 5
Метки нет (Все метки)
Доброго времени суток! В образовательных целях пишу что-то, напоминающее ftp-сервер. Задумал реализовать многопоточность.
Мне бы мог подойти ThreadPool. Вот только меня не устраивает то, что, как я понял, он на 90% неуправляемый для программиста. То есть поток добавил в него и тот начинает жить своей жизнью. Если не прав поправьте, пожалуйста. Мне же нужен механизм, который бы позволил управлять количеством одновременных подключений, но в то же время чтоб я мог их все завершить, без подавления исключения на каждом потоке(Операция ввода/вывода была прервана) и перезапуска приложения. Попытался написать свой, управляемый ThreadPool. Но результат нагрузки на процессор очень огорчил. Из 0-1% на 1 потоке загрузка ЦП выросла до 25-27%. Сервер, вроде как, неплохо работает, ну или по крайней мере я не смог вызвать ошибку. Но нужна полная оптимизация кода. Можете что-нибудь посоветовать? Вот код моего "ThreadPool" с комментариями по поводу моих ожиданий относительно него
0
|
||||||
| 28.03.2018, 12:02 | |
|
Ответы с готовыми решениями:
5
Закрытие ThreadPool ThreadPool и BlockingCollection |
|
17823 / 12973 / 3382
Регистрация: 17.09.2011
Сообщений: 21,261
|
|||||
| 28.03.2018, 12:09 | |||||
|
Поток выполняет метод, который вы ему сказали выполнять. У вас методы живут своей жизнью? Создайте список TcpClient/Socket/ЧтоВыИспользуете и будет готовый механизм управления имеющимися подключениями. Только опять не понятно, как завершение подключения относится к пулу потоков.
0
|
|||||
|
62 / 63 / 28
Регистрация: 10.01.2018
Сообщений: 360
|
|||||||
| 28.03.2018, 12:37 [ТС] | |||||||
|
Добавлено через 15 минут К стати, только заметил что в добавлении индекса есть баг, когда в список могут добавится одинаковые индексы. Но глобально на суть вопроса это не влияет.
0
|
|||||||
|
17823 / 12973 / 3382
Регистрация: 17.09.2011
Сообщений: 21,261
|
|||||||
| 28.03.2018, 12:52 | |||||||
|
Сделайте ограничение на количество соединений в списке и всего делов. Ну а раз ее все равно придется обрабатывать, то почему бы там же и не учесть завершение работы с вашей стороны? Или вы планировали использовать метод Abort? Вы планируете каждому клиенту выделать отдельный поток? 1000 клиентов — это 1000 потоков и 1ГБ оперативы только под стеки. Не жирно будет? ![]() Особенно если учесть, что 99% времени клиенты ФТП-сервера будут проводить в режиме IO и эти потоки будут сидеть замороженными без дела. Держите клиенты в обычном списке, а для того 1% времени, когда нужна локальная обработка, выполняйте ее в потоках пула путем использования асинхронной модели. Это приведет к тому, что пара десятков потоков пула у вас будет с легкостью обрабатывать сотни клиентов. Разумеется, свой пул для этого создавать не нужно — уже готовый работает просто отлично. Особенно с учетом специально имеющихся в нем потоков для обработки IO-завершений. Уничтожение потока вызовом Abort — это самовольно загнать свое же приложение в состояние полной неопределенности, т.к. поток уничтожается в прямом смысле на следующей же инструкции. Это значит, что поток может быть уничтожен на пол-пути вызова конструктора, выделения критичного ресурса, замыкания ограниченного ресурса ОС и т.д., превращая приложение в минное поле, когда оно может бомбануть в любой момент из-за того, что вон тот вон объект не закончил инициализацию из-за прерванного потока и теперь пытается лезть куда-нибудь в защищенную память.
2
|
|||||||
|
62 / 63 / 28
Регистрация: 10.01.2018
Сообщений: 360
|
|||||||||||
| 28.03.2018, 13:18 [ТС] | |||||||||||
0
|
|||||||||||
|
17823 / 12973 / 3382
Регистрация: 17.09.2011
Сообщений: 21,261
|
|||||
| 28.03.2018, 13:26 | |||||
Сообщение было отмечено Sternman как решение
РешениеПри подключении добавляйте клиента в список (класс List<T>), если список достиг определенного количества, вместо добавления сразу закрывайте соединение. Отключившихся/отвалившихся клиентов удаляйте из списка. Первый же клиент с нестабильным соединением повалит ваш сервер. Глянул на наш корпоративный Wi-Fi в офисе — на данный момент свыше полутора тысяч активных подключений — у каждого сотрудника в кармане мобилка, а то и две. Или вы о чем-то другом?
1
|
|||||
| 28.03.2018, 13:26 | |
|
Помогаю со студенческими работами здесь
6
Работа с потоками ThreadPool Сканирование портов в несколько потоков с помощью ThreadPool Потоки, мультипоточность Task or Async/Await or ThreadPool? Как в ThreadPool проверить, что все потоки завершены Ограниченное количество одновременно работающих потоков без ThreadPool Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
SDL3 для Web (WebAssembly): Работа со звуком через SDL3_mixer
8Observer8 08.02.2026
Содержание блога
Пошагово создадим проект для загрузки звукового файла и воспроизведения звука с помощью библиотеки SDL3_mixer. Звук будет воспроизводиться по клику мышки по холсту на Desktop и по. . .
|
SDL3 для Web (WebAssembly): Основы отладки веб-приложений на SDL3 по USB и Wi-Fi, запущенных в браузере мобильных устройств
8Observer8 07.02.2026
Содержание блога
Браузер Chrome имеет средства для отладки мобильных веб-приложений по USB. В этой пошаговой инструкции ограничимся работой с консолью. Вывод в консоль - это часть процесса. . .
|
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога
Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
|
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
|
|
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога
В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
|
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога
Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
|
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога
Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
|
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога
Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
|