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”

Сообщения, требующие ответа, например вызовы функций или операторы выбора, обычно используют синхронную форму; тогда как сообщения, которые не должны возвращать вывод, например, вставка обновлений в таблицу, будут асинхронными.