Q Language - межпроцессное взаимодействие
KDB + позволяет одному процессу взаимодействовать с другим процессом посредством межпроцессного взаимодействия. Процессы Kdb + могут подключаться к любому другому kdb + на том же компьютере, в той же сети или даже удаленно. Нам просто нужно указать порт, и тогда клиенты смогут разговаривать с этим портом. Любыеq процесс может общаться с любым другим q процесс, пока он доступен в сети и прослушивает соединения.
серверный процесс прослушивает соединения и обрабатывает любые запросы
клиентский процесс инициирует соединение и отправляет команды для выполнения
Клиент и сервер могут находиться на одной или на разных машинах. Процесс может быть как клиентом, так и сервером.
Общение может быть,
Synchronous (дождитесь возврата результата)
Asynchronous (без ожидания и результата не было)
Инициализировать сервер
А q сервер инициализируется указанием порта для прослушивания,
q –p 5001 / command line
\p 5001 / session command
Ручка связи
Маркер связи - это символ, который начинается с «:» и имеет форму -
`:[server]:port-number
пример
`::5001 / server and client on same machine
`:jack:5001 / server on machine jack
`:192.168.0.156 / server on specific IP address
`:www.myfx.com:5001 / server at www.myfx.com
Чтобы начать соединение, мы используем функцию «hopen», которая возвращает целочисленный дескриптор соединения. Этот дескриптор используется для всех последующих клиентских запросов. Например -
q)h:hopen `::5001
q)h"til 5"
0 1 2 3 4
q)hclose h
Синхронные и асинхронные сообщения
Получив дескриптор, мы можем отправить сообщение синхронно или асинхронно.
Synchronous Message- Как только сообщение отправлено, оно ждет и возвращает результат. Его формат следующий -
handle “message”
Asynchronous Message- После отправки сообщения немедленно начните обработку следующего оператора без ожидания и возврата результата. Его формат следующий -
neg[handle] “message”
Сообщения, требующие ответа, например вызовы функций или операторы выбора, обычно используют синхронную форму; тогда как сообщения, которые не должны возвращать вывод, например, вставка обновлений в таблицу, будут асинхронными.