|
1303 / 843 / 409
Регистрация: 12.03.2018
Сообщений: 2,305
|
|
Протокол взаимодействия приложений. Сокеты04.07.2019, 11:17. Показов 1606. Ответов 6
Метки нет (Все метки)
Имеется приложение П, которое работает самостоятельно. Данное приложение в своей памяти хранит некоторые данные, которые мне необходимо получить.
Допустим, я хочу получать данные через web интерфейс. У меня есть сервер на flask. Я хочу использовать приложение П в качестве источника данных. В момент запуска определенной функции в приложении П, я создаю сокет localhost (и приложение П и сервер работают на одной системе). В момент запуска сервера, я подключаюсь к сокету, отрытому в приложении П. На сервер каждую секунду отправляется GET запрос. В параметрах запроса указывается строка вида "var1,var2,...,varn". Эта строка с помощью split(',') разбивается на список имен переменных, значения которых нужно получить от приложения П. Была поставлена задача разработать протокол взаимодействия сервера и приложения П через сокет. Выбрал следующую структуру: [N0 ... N7][T0][L0 ... L22], где N (8 бит) - номер запроса. T (1 бит) - тип запроса GET:0/SET:1 L (23 бита) - длина данных, которые нужно принять в следующем сообщении. (наверное здесь будет использоваться len(pickle.dumps(список_переменных_после _сплит))) После этого идут данные. Вопрос: как правильно передавать биты в сокет? Ведь socket.send принимает только объекты типа bytes. Например, как правильно в этом случае передать длину? Или нужно самому извернуться и передавать строку вида b'0xaa8000ff', а затем парсить ее?
0
|
|
| 04.07.2019, 11:17 | |
|
Ответы с готовыми решениями:
6
Протокол взаимодействия с MS SQl Протокол взаимодействия UDP Выбрать протокол взаимодействия с сервером |
|
1303 / 843 / 409
Регистрация: 12.03.2018
Сообщений: 2,305
|
|
| 04.07.2019, 11:47 [ТС] | |
|
Welemir1, спасибо, погуглю на эту тему.
Протокол хотел использовать, чтобы знать точное количество байт, которое нужно принять из сокета. Иначе, как полагаю, можно захватить данные уже из следующего пакета, например (если всегда читать, например, по 1024).
0
|
|
|
Автоматизируй это!
|
|
| 04.07.2019, 11:51 | |
|
ioprst, понял, но насколько я помню сокет сам легко определяет что больше ничего не передают(то есть конец сообщения), просто условие нужно -пока есть что читать -читаем. Запросы же раз в секунду. Я бы рекомендовал проверить, даже на пересылке простых сообщений, мне кажется нормально он будет отличать один запрос от другого, но могу ошибаться.
0
|
|
|
Просто Лис
|
||
| 05.07.2019, 21:11 | ||
|
Для ТСа тоже советую обратить внимание на json и не трогать сокеты, а пользоваться высокоуровневыми библиотеками (requests для http).
1
|
||
|
1303 / 843 / 409
Регистрация: 12.03.2018
Сообщений: 2,305
|
|
| 07.07.2019, 20:12 [ТС] | |
|
Рыжий Лис, спасибо за совет. Не могли бы, пожалуйста, уточнить. Как именно здесь должна будет использоваться библиотека requests?
Мне необходимо связать два процесса, чтобы обмениваться данными. Один процесс (основной) в режиме реального времени выполняет какие-то действия и в некотором словаре хранит текущие значения некоторых данных. Мне необходимо эти данные перенаправить в другой процесс, запущенный на той же linux системе (тот сервер на flask). А уже с сервера клиенты получают данные, которые сейчас в основной программе. Можно, конечно, запускать сервер непосредственно в основной программе, но этого хотелось бы избежать. Т.к. предполагается, что сервер является отдельной службой. Плюс, основной процесс иногда неактивен, а сервер должен работать всегда.
0
|
|
|
|
|
| 07.07.2019, 22:08 | |
|
1
|
|
| 07.07.2019, 22:08 | |
|
Помогаю со студенческими работами здесь
7
Клиент-серверное приложение. Протокол взаимодействия Простейший почтовый сервер и протокол взаимодействия с ним Асинхронные сокеты: организация взаимодействия сервера и клиента Для взаимодействия приложения с сервером настроить HTTPS-протокол Низкоуровневые сокеты (ICMP протокол), Ошибка с типами, Клиент-Сервер Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Фото всей Земли с борта корабля Orion миссии Artemis II
kumehtar 04.04.2026
Это первое подобное фото сделанное человеком за 50 лет. Снимок называют новым вариантом легендарной фотографии «The Blue Marble» 1972 года, сделанной с борта корабля «Аполлон-17». Новое фото. . .
|
Вывод диалогового окна перед закрытием, если документ не проведён
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2.
Задача: реализовать программный контроль на предмет проведения документа. . .
|
Программный контроль заполнения реквизита табличной части документа
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2.
Задача: реализовать контроль заполнения реквизита "ПричинаСписания". . .
|
wmic не является внутренней или внешней командой
Maks 02.04.2026
Решение:
DISM / Online / Add-Capability / CapabilityName:WMIC~~~~
Отсюда: https:/ / winitpro. ru/ index. php/ 2025/ 02/ 14/ komanda-wmic-ne-naydena/
|
|
Программная установка даты и запрет ее изменения
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2.
Задача: при создании документов установить период списания автоматически. . .
|
Вывод данных в справочнике через динамический список
Maks 01.04.2026
Реализация из решения ниже выполнена на примере нетипового справочника "Спецтехника" разработанного в конфигурации КА2.
Задача: вывести данные из ТЧ нетипового документа. . .
|
Программное заполнения текстового поля в реквизите формы документа
Maks 01.04.2026
Алгоритм из решения ниже реализован на нетиповом документе "ВыдачаОборудованияНаСпецтехнику" разработанного в конфигурации КА2, в дополнении к предыдущему решению.
На форме документа создается. . .
|
К слову об оптимизации
kumehtar 01.04.2026
Вспоминаю начало 2000-х, университет, когда я писал на Delphi. Тогда среди программистов на форумах активно обсуждали аккуратную работу с памятью: нужно было следить за переменными, вовремя. . .
|