синхронизация сокетов в разных потоках |
Здравствуйте, гость ( Вход | Регистрация )
синхронизация сокетов в разных потоках |
borune |
23.10.2013, 18:10
Сообщение
#1
|
Участник Группа: Участник Сообщений: 152 Регистрация: 1.1.2011 Пользователь №: 2314 Спасибо сказали: 0 раз(а) Репутация: 0 |
Ребят, вопросик.
Есть сеть. На каждой машине сети запускается клиентское ПО, которое производит тестирование сети путем передачи пакетов между машиной, на которой оно запущенно, и всеми остальными машинами по типу "точка-точка". Т.е. если в сети n компьютеров, то каждый клиент будет общаться с n-1 компьютером. Как это организовано. При инициализации клиента ему передается список адресов машин, с которыми ему нужно обмениваться сообщениями, а также список портов (обмен с каждой машиной осуществляется по уникальному для каждой пары порту). В клиенте происходит следующее: 1. Для каждого компа из переданного списка создается поток, в котором открывается QTcpServer на прослушивание заданного порта, при приходе сигнала newConnection() создается сокет для чтения. Раскрывающийся текст
Раскрывающийся текст
Раскрывающийся текст
Раскрывающийся текст
Такая конструкция работает нестабильно - иногда все нормально, а иногда некоторые сокеты не создаются. Я точно не знаю, в чем дело, но вот если в обработчике read_thread::processIncomingConnection() убрать условие if(isConnected) return;, то для одного и того же хоста может создастся несколько сокетов, то есть сигнал newConnection() может приходить неоднократно. Непонятно, из-за чего такое может происходить. Как грамотно организовать создание потоков в моем случае? Сообщение отредактировал borune - 23.10.2013, 18:14 |
|
|
Алексей1153 |
25.10.2013, 9:41
Сообщение
#2
|
фрилансер Группа: Участник Сообщений: 2941 Регистрация: 19.6.2010 Из: Обливион Пользователь №: 1822 Спасибо сказали: 215 раз(а) Репутация: 34 |
не пытайся всё отладить сразу. Пусть сначала будет всего 2 машины в сети. Тестируй. Потом добавишь третью. Тестируй. И всё увидишь
Сообщение отредактировал Алексей1153 - 25.10.2013, 9:41 |
|
|
Yuriy |
25.10.2013, 10:21
Сообщение
#3
|
Новичок Группа: Новичок Сообщений: 7 Регистрация: 8.10.2013 Пользователь №: 3949 Спасибо сказали: 1 раз(а) Репутация: 0 |
... При инициализации клиента ему передается список адресов машин, с которыми ему нужно обмениваться сообщениями, а также список портов (обмен с каждой машиной осуществляется по уникальному для каждой пары порту). В клиенте происходит следующее: 1. Для каждого компа из переданного списка создается поток, в котором открывается QTcpServer на прослушивание заданного порта, при приходе сигнала newConnection() создается сокет для чтения. ... 2. Для каждого компа из переданного списка создается поток, содержащий сокет, который пытается подключиться к компу ... Такая конструкция работает нестабильно - ... Как грамотно организовать создание потоков в моем случае? Во-первых - слишком много потоков. Сервер нужен один, который слушает все порты. В случае, если происходит новое соединение из списка, то тогда можно создать сокет и поместить его в отдельный поток. Зачем запускать кучу серверов в отдельных потоках - не понятно. Одного сокета на соединение достаточно, зачем нужно их два (на чтение и запись) - мне не оч. понятно. Ну и прежде всего - начните с проекта. Есть ли общий сервер в сети, откуда берется список адресов-портов, кто инициатор соединения, что происходит при включении-отключении и т.д. |
|
|
borune |
25.10.2013, 20:41
Сообщение
#4
|
Участник Группа: Участник Сообщений: 152 Регистрация: 1.1.2011 Пользователь №: 2314 Спасибо сказали: 0 раз(а) Репутация: 0 |
Во-первых - слишком много потоков. Сервер нужен один, который слушает все порты. В случае, если происходит новое соединение из списка, то тогда можно создать сокет и поместить его в отдельный поток. Зачем запускать кучу серверов в отдельных потоках - не понятно. По сути Вы предлагаете практически такой же вариант - число потоков не уменьшится. Просто они будут создаваться чуть позже Одного сокета на соединение достаточно, зачем нужно их два (на чтение и запись) - мне не оч. понятно. Объясню. Если для обмена создавать один сокет, то стороны (клиенты) будут неравнозначны - одна должна слушать порт, вторая в него писать. А у меня клиенты все одинаковы.upd а как кстати заставить сервер слушать все порты? Сообщение отредактировал borune - 29.10.2013, 10:37 |
|
|
Текстовая версия | Сейчас: 28.11.2024, 20:43 |