我有以下 C 程序,其主函数runTCPConnectivityCheck
打开一个 TCP 套接字,向它发送一串字节并关闭它:
#include <arpa/inet.h>
#include <netinet/in.h>
#include <stdio.h>
#include <string.h>
#include <unistd.h>
static int runTCPConnectivityCheck(const int port)
{
int fd = socket(AF_INET, SOCK_STREAM, 0);
if (fd < 0)
{
printf("socket failed\n");
return 1;
}
int reuseAddrTrue = 1;
if (setsockopt(fd, SOL_SOCKET, SO_REUSEADDR, &reuseAddrTrue, sizeof(reuseAddrTrue)) != 0)
{
printf("setsockopt failed\n");
return 1;
}
struct sockaddr_in serv_addr = { 0 };
serv_addr.sin_family = AF_INET;
serv_addr.sin_port = htons(port);
if (inet_pton(AF_INET, "127.0.0.1", &serv_addr.sin_addr) != 1)
{
printf("inet_pton failed\n");
return 1;
}
if (connect(fd, (struct sockaddr*)(&serv_addr), sizeof(serv_addr)) != 0)
{
printf("connect failed\n");
return 1;
}
const char* message = "hello";
const size_t messageLength = strlen(message);
if (send(fd, message, messageLength, 0) != messageLength)
{
printf("send failed\n");
return 1;
}
shutdown(fd, SHUT_RDWR);
close(fd);
return 0;
}
int main()
{
for (int i = 0; i < 10; ++i)
{
printf("%s\n", runTCPConnectivityCheck(5555) == 0 ? "success" : "failure");
//sleep(1);
}
}
如果我尝试重复测试同一个端口,第一次调用就runTCPConnectivityCheck
可以正常工作,但所有后续调用都会在调用connect
. 如果我将调用添加到sleep
in,那么它也可以工作。据推测,1 秒的延迟给了网络堆栈足够的时间来清理套接字,以便我可以再次连接到同一个端口。
首先:我是否正确关闭了套接字?其次:如果我正确关闭它,确定网络堆栈何时准备好再次连接到同一主机和端口的标准方法是什么(而不是sleep
我目前使用的la脚)?
更新
更多详细信息:失败并显示错误connect
代码 61 或返回“连接被拒绝”。ECONNREFUSED
strerror
本例中的服务器是在与测试程序相同的机器上循环运行的netstat
/命令:nc
#!/bin/bash
while true; do
nc -l 5555
done
程序现在是 C,真的。