0 / 0 / 0
Регистрация: 23.08.2014
Сообщений: 1
|
|
1 | |
Использование EPOLLONESHOT в многопоточной среде c++ linux10.08.2015, 19:32. Показов 1054. Ответов 1
Метки нет (Все метки)
Появилась необходимость написать многопоточный сервер на c++, используя механизм EPOLL.
Реализация с пулом потоков не подходит, так как передача задания в пул потоков занимает много драгоценного времени, вследствие чего иногда ощущаются подлагивания. Решил реализовать след образом: несколько потоков будут ожидать события от одного дескриптора Epoll'а. Вопрос: как нужно правильно использовать опцию EPOLLONESHOT? Нужно ли что-то синхронизировать мьютексами, или же реализация epoll'a уже позаботилась об этом? Принципиально ли использовать egde-triggered режим? По возможности прошу предоставить код/псевдокод подобной реализации. Поиск в гугле/яндексе ничего толкового не дал.
0
|
10.08.2015, 19:32 | |
Ответы с готовыми решениями:
1
Использование Linux в среде Windows 10 QSQLITE в многопоточной среде Random выдает нули в многопоточной среде Java.sql.SQLException: Operation not allowed after ResultSet в многопоточной среде |
1978 / 1082 / 87
Регистрация: 29.11.2013
Сообщений: 3,353
|
|
11.08.2015, 16:09 | 2 |
После генерации события данный дескриптор больше не мониторится. Вы должны после обработки события опять вызвать epoll_ctl с параметром EPOLL_CTL_MOD для данного дескриптора. man 2 epoll_ctl
Функции epoll не атомарные, значит нужно. Это Вам решать. В edge-triggered режиме пока данные не записаны epoll_wait не вернет результат. Потому что надо искать в manpages. man 7 epoll
0
|
11.08.2015, 16:09 | |
11.08.2015, 16:09 | |
Помогаю со студенческими работами здесь
2
Проблемы с Sudo в среде Linux Разработка приложений в среде Linux Скомпилировать файлы в среде Linux Программирование в BASH в среде Linux Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |