我在同一台机器上运行的两个进程之间打开了一个unix数据报套接字。但是,我的客户端进程正在向自身而不是服务器发送请求。
我保留了套接字绑定不同的文件路径。但是,如果我保持文件路径相同,那么尽管客户端能够向服务器发送请求,但服务器会向自身发送响应。请查看此链接以获取与此问题相关的问题。那里几乎有完整的代码。
无法在一对 unix 套接字客户端服务器之间交换消息以交换消息 randonly
以下是客户端有问题的代码片段:
int msimcli_ConnectToSocket(const char* socketFile,int isSockTypeStreaming, SOCKET_PARAMS* socketParam)
{
int rc = ROK;
int result = 0;
char buffer[CLI_MAX_BUF_SIZE];
int buffer_size = CLI_MAX_BUF_SIZE;
int option = 1;
socklen_t len;
MSIM_ZERO(*socketParam);
pthread_t snd_tid;
pthread_t rx_tid;
if (isSockTypeStreaming)
{
socketParam->type = SOCK_STREAM;
}
else
{
socketParam->type = SOCK_DGRAM;
}
socketParam->fd = socket(AF_UNIX, socketParam->type, 0);
if (0 > socketParam->fd)
{
rc = RFAILED;
goto Exit;
}
else{
printf("socket created successfully with socket descriptor %dn",socketParam->fd);
}
rc = setsockopt(socketParam->fd, SOL_SOCKET, (SO_REUSEADDR), &option, sizeof(option));
if (-1 == rc)
{
printf("setsockopt failedrn");
close(socketParam->fd);
socketParam->fd = -1;
goto Exit;
}
/* Bind Unix socket to a FilePath */
socketParam->remote.sun_family = AF_UNIX;
unlink(socketParam->remote.sun_path);
strcpy(socketParam->remote.sun_path, socketFile);
socketParam->len = strlen(socketParam->remote.sun_path) + sizeof(socketParam->remote.sun_family) + 1;
rc = bind(socketParam->fd, (struct sockaddr*)&socketParam->remote, socketParam->len);
if (-1 == rc)
{
printf("setsockopt failedrn");
close(socketParam->fd);
socketParam->fd = -1;
goto Exit;
}
/* Create Receiver thread */
if(ROK != (rc = pthread_create(&rx_tid,NULL,msimcli_RecvFromSocket,NULL)))
{
printf("Thread create for Receiver failedn");
goto Exit;
}
Exit:
if (ROK != rc)
{
printf("%s: errno=0x%x %srn", __FUNCTION__,errno, strerror(errno));
if (-1 < socketParam->fd)
{
close(socketParam->fd);
socketParam->fd = -1;
}
}
printf("<< rc %drn", rc);
return rc;
}
int msimcli_SendToSocket(void* buf)
{
int rc = ROK;
/*Test buffer*/
cliCmd *buff = (cliCmd *)buf;
printf("Buff %sn", ((cliCmd *)buf)->buf);
for (int i = 0; i < buff->hdr.msglen; i++)
{
printf("[%x]", buff[i]);
}
printf("n");
printf("sending on socket [%d]n",datagramSocket.fd);
rc = sendto(datagramSocket.fd, buf, buff->hdr.msglen, 0,
(struct sockaddr *)&datagramSocket.remote, datagramSocket.len);
if (rc == -1) {
printf("%s: errno=0x%x %srn", __FUNCTION__,errno, strerror(errno));
printf("SENDTO ERRORn");
close(datagramSocket.fd);
return 0;
}
else {
printf("Data sent!n");
return rc;
}
}
我希望两个进程之间的消息交换顺畅。
您没有包含最小的可重现示例;也不清楚 datagramSocket 在发送函数中来自何处。
但是,对我来说,发送方和接收方似乎都使用完全相同的套接字。
您需要做的是使用一对套接字;即套接字对:
C/Unix 中的套接字((