Форум программистов, компьютерный форум, киберфорум
C/С++ под Linux
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.56/9: Рейтинг темы: голосов - 9, средняя оценка - 4.56
0 / 0 / 0
Регистрация: 11.01.2018
Сообщений: 72

Клиент/серверное приложение используя очереди сообщений

12.05.2021, 13:48. Показов 2026. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Написать код для реализации системы Клиент / Сервер.
Сервер получает сообщение от клиентов, тип сообщения задается при запуске клиента (число от 1 до 10).
Сервер печатает полученное сообщение с указанием типа и времени получения.
Сервер подтверждает получение сообщения от клиента, переслав ему соответствующее сообщение. После подтверждения клиент передает серверу следующее сообщение.
Сервер прекращает общение с каждым клиентом после получения N (задается при запуске сервера) сообщений от клиента, послав клиенту сообщение с определенным текстом.
Клиент завершает работу после получения от сервера сообщение с определенным текстом.

Помогите, пожалуйста, с объяснением задания. Я так понимаю, что нужно запустить 11 терминалов (1 сервер и 10 клиентов). В сервере программа запускается с аргументом, что задает количество максимально полученных сообщений от клиента, а в каждом клиенте должна запуститься с аргументом от 1 до 10 (можно сделать через getopt()). Потом каждый клиент должен иметь возможность отправить сообщение, которые появится в терминале сервер. При получении и выводе сообщения, терминал должен отправлять ответ в клиент, что сообщение было доставлено и клиент ждет дальнейший ввод. А оффнуть сервер можно с помощью стоп слова. Я правильно понял задание? Если да, то подскажите вкратце, как это можно реализовать.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
12.05.2021, 13:48
Ответы с готовыми решениями:

Прокомментировать клиент-серверное приложение
здаврствуйте, нужна ваша помошь. есть клиент-серверное приложение. И то и другое полностью работает на как я не понимаю. Кто может...

Клиент-серверное приложение на С с использованием RPC
Имеется такая проблема. С использованием RPC реализовать клиент-серверное приложение. На вход клиенту задается имя файла, которое...

Очереди сообщение (создание очереди из N сообщений)
Нужна помощь в создании очереди из n сообщений как создать простую очередь я знаю но как указать конкретное возможное количество...

1
13 / 13 / 0
Регистрация: 21.10.2011
Сообщений: 58
13.05.2021, 11:44
Сервер может работать в асинхронном или синхронном режиме. Сервер может работать в одном потоке или под каждое соединение можно создавать отдельный поток.

Для простоты возьмем сервер с синхронным режимом и с одним управляющим потоком (один управляющий поток более быстрый и тратит меньше ресурсов)

Если мы говорим об синхронном режиме, это предполагает, что на каждый запрос клиента нужно давать ответ севера. Взаимодействие между сервером и клиентом описывается протоколом. Т.е. нам нужно разработать протокол.
К примеру пусть параметры сообщения у нас будут передаваться в формате: <key1>=<val1>&<key2>=<val2>...

при подключении клиента, клиент должен передать сообщение типа:
method=connect&client-id=1

на что сервер должен ответить:
result=1

С протоколом определились. Теперь, что представляет из себя сервер. Создаем сокет (функция socket()), биндим на интерфейс и порт (функция bind()), и начинаем слушать (функция listen()). После чего записываем этот сокет в специальный массив, под индексом 0. Последующие подключения будем так же писать в этот же массив, каждый раз увеличивая номер индекса

Дальше начинается самое интересное. Входим в бесконечный цикл, в котором мы будем выполнять одну и ту же последовательность действий:
1) функцией poll() будем определять, что событие случилось (новое подключение, отключение, пришло сообщение)
2) аксептим новые подключения (функция accept())
3) реагируем на сообщение

Особенности реализации:
1) функция poll() принимает на вход 3 параметра: массив сокетов, которые мы мониторим, количество активных сокетов, и таймаут (сколько мы максимально ждем - это нужно, чтобы не зависнуть на вечно). Массивом сокетов нужно будет управлять (добавлять новые, убирать старые, следить, чтобы не было битых сокетов). Читающих сокет (на котором мы слушаем новые подключения) будет в массиве под индексом 0
2) поскольку мы договорились работать в синхронном режиме в одном управляющем потоке, мы должны писать в сокет с определенным таймаутом (т.к. внешняя система может не прочитать наше сообщение (умышленно или не умышленно), чем повесит наш сервер)
3) читать сообщения будем функцией read(), писать функцией write()
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
13.05.2021, 11:44
Помогаю со студенческими работами здесь

Как написать клиент-серверное приложение?
Хочу написать такую программу. Есть сервер у меня на компютере и есть клиент на другом компютере. Клиент посылает какую-то строку серверу а...

Клиент-серверное приложение отправка сообщений
Помогите разобраться создаю клиент-серверное приложение отправка сообщений. //Сервер package ClientServer; import...

Клиент-серверное приложение, сохранение сообщений переписки
Здраствуйте!):help: У меня есть два приложения: одно-клиентская часть, второе-серверная часть. Передача сообщений между ними по IP налажена...

Клиент-серверное приложение перстает работать при отправке/приеме 3-4 сообщений
Здравствуйте! При создании сервера (пока он ещё на начальном этапе и я сделал только самое простое) у меня возникла проблема: сначала...

Как создать клиент-серверное приложение, используя виндовс сокеты
Здравствуйте. Не подскажите как создать клиент-серверное приложение используя виндовс сокеты. Может есть какие то примеры или...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Настройка записи справочника по регистру сведений
Maks 29.03.2026
Решение ниже реализовано на примере нетипового справочника "ТарифыМобильнойСвязи" разработанного в конфигурации КА2, с целью учета корпоративной мобильной связи в коммерческом предприятии. . . .
Автозаполнение реквизита при выборе элемента справочника
Maks 27.03.2026
Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. При выборе "Спецтехники" (Тип Справочник. Спецтехника), заполняется. . .
Сумматор с применением элементов трёх состояний.
Hrethgir 26.03.2026
Тут. https:/ / fips. ru/ EGD/ ab3c85c8-836d-4866-871b-c2f0c5d77fbc Первый документ красиво выглядит, но без схемы. Это конечно не даёт никаких плюсов автору, но тем не менее. . . всё может быть. . .
Автозаполнение реквизитов при создании документа
Maks 26.03.2026
Программный код из решения ниже размещается в модуле объекта документа, в процедуре "ПриСозданииНаСервере". Алгоритм проверки заполнения реализован для исключения перезаписи значения реквизита,. . .
Команды формы и диалоговое окно
Maks 26.03.2026
1. Команда формы "ЗаполнитьЗапчасти". Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. В качестве источника данных. . .
Кому нужен AOT?
DevAlt 26.03.2026
Решил сделать простой ланчер Написал заготовку: dotnet new console --aot -o UrlHandler var items = args. Split(":"); var tag = items; var id = items; var executable = args;. . .
Отправка уведомления на почту при создании или изменении элементов справочника
Maks 24.03.2026
Программная отправка письма электронной почты на примере типового справочника "Склады" в конфигурации БП3. Перед реализацией необходимо выполнить настройку системной учетной записи электронной. . .
модель ЗдравоСохранения 5. Меньше увольнений- больше дохода!
anaschu 24.03.2026
Теперь система здравосохранения уменьшает количество увольнений. 9TO2GP2bpX4 a42b81fb172ffc12ca589c7898261ccb/ https:/ / rutube. ru/ video/ a42b81fb172ffc12ca589c7898261ccb/ Слева синяя линия -. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru