क्यू लैंग्वेज - इंटर-प्रोसेस कम्युनिकेशन

केडीबी + एक प्रक्रिया को इंटरप्रोसेस संचार के माध्यम से दूसरी प्रक्रिया के साथ संवाद करने की अनुमति देता है। 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

कनेक्शन शुरू करने के लिए, हम फ़ंक्शन "हॉप" का उपयोग करते हैं जो पूर्णांक कनेक्शन हैंडल देता है। यह हैंडल सभी बाद के क्लाइंट अनुरोधों के लिए उपयोग किया जाता है। उदाहरण के लिए -

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”

ऐसे संदेश जिनमें प्रतिक्रिया की आवश्यकता होती है, उदाहरण के लिए फ़ंक्शन कॉल या स्टेटमेंट्स का चयन करें, सामान्य रूप से सिंक्रोनस फॉर्म का उपयोग करेंगे; जबकि संदेश जो आउटपुट को वापस करने की आवश्यकता नहीं है, उदाहरण के लिए तालिका में अपडेट सम्मिलित करना, अतुल्यकालिक होगा।