本文執行個體講述了PHP訊息佇列用法。分享給大家供大家參考,具體如下:
該訊息佇列用於linux下,進程通訊
#根據路徑和尾碼建立一個id$key = ftok(__DIR__, 'R');#擷取隊列中的訊息$q = msg_get_queue($key);#刪除隊列msg_remove_queue($q);#擷取隊列的狀態資訊$status = msg_stat_queue($q);print_r($status);echo "\n";for($i=0;$i<100;$i++){ /** * 向隊列裡添加訊息 * resource $queue , int $msgtype , mixed $message [, bool $serialize = true [, bool $blocking = true [, int &$errorcode ]]] * $msgtype :訊息的類型 * $message : 具體的資料 * $serialize:是否要序列化 * $blocking: 是否阻塞 , 當隊列中滿時,會進行阻塞,設為非阻塞會產生一個 MSG_EAGAIN 的 錯誤訊息 */ $flag = msg_send($q, 111, array('a'=>1), true, false , $errorcode); var_dump($errorcode);}/**接收訊息resource $queue , int $desiredmsgtype , int &$msgtype , int $maxsize , mixed &$message [, bool $unserialize = true [, int $flags = 0 [, int &$errorcode ]]] $desiredmsgtype:0表示從隊列最前面開始返回資料, bigger 0:具體的某個隊列$maxsize:資料最大值,擷取的訊息如果》此值則出錯$msgtype:訊息的具體類型, 因為$desiredmsgtype可以不指定類型,即指定為0$flags:MSG_IPC_NOWAIT 如果隊列為空白直接返回(不阻塞), MSG_EXCEPT MSG_NOERROR 參見手冊*/$data = msg_receive($q, 0, $type, 200, $msg);var_dump($data);echo "\n";var_dump($type);echo "\n";var_dump($msg);echo "\n";
隊列狀態資訊:具體參考手冊
Array([msg_perm.uid] => 1015[msg_perm.gid] => 100[msg_perm.mode] => 438[msg_stime] => 0[msg_rtime] => 0[msg_ctime] => 1411830331[msg_qnum] => 0[msg_qbytes] => 65536[msg_lspid] => 0[msg_lrpid] => 0)
linux下 用 ipc命令查看 ,用 ipcrm 命令可以刪除
更多關於PHP相關內容感興趣的讀者可查看本站專題:《PHP基本文法入門教程》、《PHP錯誤與異常處理方法總結》、《php程式設計演算法總結》及《php物件導向程式設計入門教程》
希望本文所述對大家PHP程式設計有所協助。
以上就介紹了PHP訊息佇列用法執行個體分析,包括了方面的內容,希望對PHP教程有興趣的朋友有所協助。