我正在nanomsg
使用IPC
并想使用此处SURVEY
描述的 -archetype 架构。在这种情况下,进程作为客户端和服务器运行并交换数据。现在服务器有以下代码(也在提供的链接中列出):
int server (const char *url)
{
int sock = nn_socket (AF_SP, NN_SURVEYOR);
assert (sock >= 0);
assert (nn_bind (sock, url) >= 0);
sleep(1); // wait for connections
int sz_d = strlen(DATE) + 1; // '\0' too
printf ("SERVER: SENDING DATE SURVEY REQUEST\n");
int bytes = nn_send (sock, DATE, sz_d, 0);
assert (bytes == sz_d);
while (1)
{
char *buf = NULL;
int bytes = nn_recv (sock, &buf, NN_MSG, 0);
if (bytes == ETIMEDOUT) break;
if (bytes >= 0)
{
printf ("SERVER: RECEIVED \"%s\" SURVEY RESPONSE\n", buf);
nn_freemsg (buf);
}
}
return nn_shutdown (sock, 0);
}
由于套接字类型为NN_SURVEYOR
,while
-loop 不会在nn_recv
. 对于客户端,套接字类型是NN_RESPONDENT
等,客户端中的while循环等待nn_recv
。
现在,由于这个 while 循环连续无限地运行,CPU 使用率飙升至 99%。你能告诉我有没有其他方法可以使用nanomsg
.