क्यू लैंग्वेज - मैसेज हैंडलर

जब एक q प्रक्रिया दूसरे से जुड़ती है qअंतर-प्रक्रिया संचार के माध्यम से प्रक्रिया, यह संदेश संचालकों द्वारा संसाधित किया जाता है। इन संदेश संचालकों का डिफ़ॉल्ट व्यवहार होता है। उदाहरण के लिए, सिंक्रोनस मैसेज हैंडलिंग के मामले में, हैंडलर क्वेरी का मान लौटाता है। इस मामले में सिंक्रोनस हैंडलर है.z.pg, जिसे हम आवश्यकता के अनुसार ओवरराइड कर सकते थे।

Kdb + प्रक्रियाओं में कई पूर्व-परिभाषित संदेश हैंडलर होते हैं। डेटाबेस को कॉन्फ़िगर करने के लिए संदेश हैंडलर महत्वपूर्ण हैं। कुछ उपयोगों में शामिल हैं -

  • Logging - आने वाले संदेशों को लॉग करें (किसी भी घातक त्रुटि के मामले में सहायक),

  • Security- उपयोगकर्ता नाम / आईपी पते के आधार पर, डेटाबेस, कुछ फ़ंक्शन कॉल, आदि तक पहुंच की अनुमति न दें। यह केवल अधिकृत ग्राहकों तक पहुंच प्रदान करने में मदद करता है।

  • Handle connections/disconnections अन्य प्रक्रियाओं से।

पूर्वनिर्धारित संदेश संचालकों

पूर्वनिर्धारित संदेश संचालकों में से कुछ नीचे चर्चा कर रहे हैं।

.z.pg

यह एक सिंक्रोनस मैसेज हैंडलर (प्रोसेस गेट) है। जब भी एक kdb + आवृत्ति पर एक सिंक संदेश प्राप्त होता है, तो यह फ़ंक्शन स्वचालित रूप से कहलाता है।

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

.z.pg: {value x}                / simply execute the message 
                                received but we can overwrite it to
give any customized result.
.z.pg : {handle::.z.w;value x}  / this will store the remote handle
.z.pg : {show .z.w;value x}     / this will show the remote handle

.z.ps

यह एक अतुल्यकालिक संदेश हैंडलर (प्रक्रिया सेट) है। यह अतुल्यकालिक संदेशों के लिए बराबर हैंडलर है। पैरामीटर निष्पादित करने के लिए स्ट्रिंग / फ़ंक्शन कॉल है। डिफ़ॉल्ट रूप से, इसे निम्न के रूप में परिभाषित किया जाता है:

.z.pg : {value x}        / Can be overriden for a customized action.

अतुल्यकालिक संदेशों के लिए अनुकूलित संदेश हैंडलर निम्नलिखित है, जहां हमने संरक्षित निष्पादन का उपयोग किया है,

.z.pg: {@[value; x; errhandler x]}

यहाँ errhandler किसी भी अप्रत्याशित त्रुटि के मामले में उपयोग किया जाने वाला कार्य है।

.z.po []

यह एक कनेक्शन ओपन हैंडलर (प्रोसेस-ओपन) है। इसे निष्पादित किया जाता है जब एक दूरस्थ प्रक्रिया एक कनेक्शन खोलती है। जब किसी प्रक्रिया का कनेक्शन खोला जाता है तो हैंडल को देखने के लिए, हम .z.po को इस प्रकार परिभाषित कर सकते हैं,

.z.po : {Show “Connection opened by” , string h: .z.h}

.z.pc []

यह एक करीबी कनेक्शन हैंडलर (प्रक्रिया-करीबी) है। कनेक्शन बंद होने पर इसे कहा जाता है। हम अपना खुद का करीबी हैंडलर बना सकते हैं जो वैश्विक कनेक्शन हैंडल को 0 पर रीसेट कर सकता है और टाइमर को हर 3 सेकंड (3000 मिली सेकेंड) में आग लगाने (निष्पादित) के लिए एक कमांड जारी कर सकता है।

.z.pc : { h::0; value “\\t 3000”}

टाइमर हैंडलर (.z.ts) कनेक्शन को फिर से खोलने का प्रयास करता है। सफलता मिलने पर, यह टाइमर को बंद कर देता है।

.z.ts : { h:: hopen `::5001; if [h>0; value “\\t 0”] }

.z.pi []

PI प्रक्रिया इनपुट के लिए है। इसे किसी भी प्रकार के इनपुट के लिए कहा जाता है। इसका उपयोग कंसोल इनपुट या रिमोट क्लाइंट इनपुट को संभालने के लिए किया जा सकता है। .Z.pi [] का उपयोग करके, कोई कंसोल इनपुट को मान्य कर सकता है या डिफ़ॉल्ट डिस्प्ले को बदल सकता है। इसके अलावा, इसका उपयोग किसी भी प्रकार के लॉगिंग ऑपरेशन के लिए किया जा सकता है।

q).z.pi
'.z.pi

q).z.pi:{">", .Q.s value x}

q)5+4
>9

q)30+42
>72

q)30*2
>60

q)\x .z.pi
>q)

q)5+4
9

.z.pw

यह एक सत्यापन कनेक्शन हैंडलर (उपयोगकर्ता प्रमाणीकरण) है। यह एक अतिरिक्त कॉलबैक जोड़ता है जब एक कनेक्शन को kdb + सत्र में खोला जा रहा है। इसे -u / -U चेक और .z.po (पोर्ट ओपन) से पहले कहा जाता है।

.z.pw : {[user_id;passwd] 1b}

इनपुट्स हैं userid (प्रतीक) और password (पाठ)।