Bahasa Q - Penangan Pesan
Ketika sebuah q Proses terhubung ke yang lain qproses melalui komunikasi antar proses, diproses oleh penangan pesan. Penangan pesan ini memiliki perilaku default. Misalnya, dalam kasus penanganan pesan sinkron, penangan mengembalikan nilai kueri. Penangan sinkron dalam kasus ini adalah.z.pg, yang dapat kami ganti sesuai kebutuhan.
Proses Kdb + memiliki beberapa penangan pesan yang telah ditentukan sebelumnya. Penangan pesan penting untuk mengkonfigurasi database. Beberapa penggunaan termasuk -
Logging - Catat pesan masuk (berguna jika terjadi kesalahan fatal),
Security- Izinkan / larang akses ke database, panggilan fungsi tertentu, dll., Berdasarkan nama pengguna / alamat ip. Ini membantu dalam memberikan akses ke pelanggan resmi saja.
Handle connections/disconnections dari proses lain.
Penangan Pesan Standar
Beberapa penangan pesan standar dibahas di bawah ini.
.z.pg
Ini adalah penangan pesan sinkron (proses get). Fungsi ini dipanggil secara otomatis setiap kali pesan sinkronisasi diterima pada instance kdb +.
Parameter adalah panggilan string / fungsi yang akan dijalankan, yaitu pesan yang dilewatkan. Secara default, ini didefinisikan sebagai berikut -
.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
Ini adalah penangan pesan asinkron (set proses). Ini adalah penangan yang setara untuk pesan asinkron. Parameter adalah panggilan string / fungsi yang akan dijalankan. Secara default, ini didefinisikan sebagai,
.z.pg : {value x} / Can be overriden for a customized action.
Berikut adalah penanganan pesan yang disesuaikan untuk pesan asinkron, di mana kami telah menggunakan eksekusi yang dilindungi,
.z.pg: {@[value; x; errhandler x]}
Sini errhandler adalah fungsi yang digunakan jika terjadi kesalahan yang tidak terduga.
.z.po []
Ini adalah penangan koneksi terbuka (proses terbuka). Ini dijalankan ketika proses jarak jauh membuka koneksi. Untuk melihat pegangan ketika koneksi ke proses dibuka, kita dapat mendefinisikan .z.po sebagai,
.z.po : {Show “Connection opened by” , string h: .z.h}
.z.pc []
Ini adalah penangan koneksi dekat (proses-tutup). Ini dipanggil ketika koneksi ditutup. Kita dapat membuat penangan dekat kita sendiri yang dapat mengatur ulang pegangan koneksi global ke 0 dan mengeluarkan perintah untuk mengatur pengatur waktu agar menyala (dieksekusi) setiap 3 detik (3000 milidetik).
.z.pc : { h::0; value “\\t 3000”}
Pengatur waktu (.z.ts) mencoba membuka kembali koneksi. Jika berhasil, pengatur waktu akan mati.
.z.ts : { h:: hopen `::5001; if [h>0; value “\\t 0”] }
.z.pi []
PI adalah singkatan dari proses input. Ini disebut untuk segala jenis masukan. Ini dapat digunakan untuk menangani input konsol atau input klien jarak jauh. Menggunakan .z.pi [], seseorang dapat memvalidasi input konsol atau mengganti tampilan default. Selain itu, ini dapat digunakan untuk segala jenis operasi logging.
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
Ini adalah pengendali koneksi validasi (otentikasi pengguna). Ini menambahkan panggilan balik ekstra ketika koneksi dibuka ke sesi kdb +. Ini dipanggil setelah pemeriksaan –u / -U dan sebelum .z.po (port open).
.z.pw : {[user_id;passwd] 1b}
Masukan adalah userid (simbol) dan password (teks).