我是C的新手,尤其是套接字。这是我的代码:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <pthread.h>
#include <netinet/in.h>
#include <errno.h>
#include <string.h>
int main(int argc, char *argv[])
{
int time_me = 0;
int yes = 1;
char buffer[1024];
int newsockfd, recv_length, sockfd;
struct sockaddr_in serv_addr, cli_addr;
ssize_t number;
if (sockfd < 0)
error("ERROR opening socket");
bzero((char *) &serv_addr, sizeof(serv_addr));
serv_addr.sin_family = AF_INET;
serv_addr.sin_addr.s_addr = 0;
serv_addr.sin_port = htons(80);
//write(sockfd,"From Server",11);
sockfd = socket(AF_INET, SOCK_STREAM, 0);
connect(sockfd,(struct sockaddr *) &serv_addr,sizeof(serv_addr));
send(sockfd, "GET /1/ HTTP/1.0\r\n\r\n", strlen("GET /1/ HTTP/1.0\r\n\r\n"), 0);
while(yes)
{
sleep(1);
if(send(sockfd, "as\r\n\r\n", strlen("as\r\n\r\n"), 0) > 0)
{
printf("Alive on %d Second\n", time_me);
}
else
{
printf("Dead on %d Second\n", time_me);
}
time_me++;
printf("I'm Done\n");
}
}
基本上我要做的是做一个正确的HTTP GET请求,然后发出一些错误的请求,看看socket保持活动多长时间。我知道我可以检查apache.conf中的套接字超时文件,它说300秒。但我的问题是,31秒后程序停止工作。它甚至没有进入其他声明,也没有说我做完我无法弄清楚原因。希望你能帮忙。谢谢。
答案 0 :(得分:0)
服务器没有读取您正在发送的所有数据,这使得套接字缓冲区被填满,导致send(2)
调用阻塞。
在31个send(2)
调用之后,缓冲区被数据填充,而在阻塞模式下打开的套接字无法处理更多字节。您应该将套接字设置为非阻止模式,或使用select(2)
,poll(2)
或类似的东西来执行您想要的操作。请查看setsockopt(2)
手册(O_NONBLOCK
标志)。
如果您使用select(2)
或使用非阻塞套接字,则应在send(2)
返回-1
且errno
为EAGAIN
(或EWOULDBLOCK
时等待}),因为那是你的程序冻结的地方。您应该非常好地研究套接字手册(至少socket(2)
和setsockopt(2)
)以了解如何实现您期望的目标。
AND,正如Blake在下面提到的那样,你还应检查每个函数调用返回值,以检查是否有错误。在send(2)
或任何与libc相关的调用上收到错误后,您应该使用errno
变量,perror(3)
或strerror(3)
函数检查错误。
无论如何,如果您想知道连接/套接字何时被删除,请使用select(2)
检查套接字的读取状态。这将做你想要的。
答案 1 :(得分:0)
如果您尝试捕获每个可能的错误,它将帮助您调试代码。
在每个系统功能下放置这样的东西。大多数人在出错时返回-1,成功时返回0或更多。
if (returned < 0) {
printf("called_function(): %s\n", strerror(errno));
return 1;
}
为了便于使用,只需将printf中的called_function()名称更改为您捕获错误的函数,并返回到调用变量的任何函数。