我创建了一个示例,演示如何通过消息队列与用C编写的程序进行通信。先运行C程序(它将创建队列),然后运行PHP脚本。
C代码编译命令:gcc -std=c99 -o test_queue test_queue.c
test_queue.c
/**
* 使用System V消息队列与PHP和C程序的示例。
* 这是一个简单的服务器,它创建消息队列并从中接收消息。
* 基于Beej's Guide to Unix IPC
* 作者:Jan Drazil, <qeekin at gmail dot com>
*/
#include <stdio.h>
#include <stdlib.h>
#include <errno.h>
#include <string.h>
#include <sys/types.h>
#include <sys/ipc.h>
#include <sys/msg.h>
/* 用于接收消息的缓冲区结构 */
struct php_buf {
long mtype;
char msg[200];
};
int main(void)
{
struct php_buf buf;
int msqid;
key_t key;
/* 生成密钥(/var/www/index.php必须是可访问的文件)*/
if((key = ftok("/var/www/index.php", 'G')) == -1) {
perror("ftok");
exit(EXIT_FAILURE);
}
/* 创建消息队列 */
if((msqid = msgget(key, 0666 | IPC_CREAT)) == -1) {
perror("msgget");
exit(EXIT_FAILURE);
}
printf("Ready to get string from PHP!\n");
/* 接收消息 */
if(msgrcv(msqid, &buf, sizeof(buf.msg)-1, 0, 0) == -1) {
perror("msgrcv");
exit(EXIT_FAILURE);
}
/* 消除段错误 */
buf.msg[199] = '\0';
printf("Recieved from PHP: %s\n", buf.msg);
/* 销毁消息队列 */
if(msgctl(msqid, IPC_RMID, NULL) == -1) {
perror("msgctl");
exit(EXIT_FAILURE);
}
return EXIT_SUCCESS;
}
test_queue.php
<?php
if(($key = ftok("/var/www/index.php", "G")) == -1)
die("ftok");
if(!msg_queue_exists($key))
die("消息队列不存在");
if(($msqid = msg_get_queue($key)) === FALSE)
die("msg_get_queue");
echo "发送文本到消息队列。\n";
if(!msg_send($msqid, 12, "Hello from PHP!\0", false))
die("msg_send");
echo "完成"
?>