1

当我的程序无法连接另一台主机时,我的文件描述符用完了。close() 系统调用不起作用,打开的套接字数量增加。我可以用

cat /proc/sys/fs/file-nr

从控制台打印:

连接:没有到主机的路由

关闭:错误的文件描述符

连接:没有到主机的路由

关闭:错误的文件描述符

..

代码:

#include <stdio.h>
#include <stdlib.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <netdb.h>
#include <string.h>
#include <iostream>
using namespace std;

#define PORT            1238
#define MESSAGE         "Yow!!! Are we having fun yet?!?"
#define SERVERHOST      "192.168.9.101"

void
write_to_server (int filedes)
{
  int nbytes;

  nbytes = write (filedes, MESSAGE, strlen (MESSAGE) + 1);
  if (nbytes < 0)
    {
      perror ("write");
    }
}

void
init_sockaddr (struct sockaddr_in *name,
               const char *hostname,
               uint16_t port)
{
  struct hostent *hostinfo;

  name->sin_family = AF_INET;
  name->sin_port = htons (port);
  hostinfo = gethostbyname (hostname);
  if (hostinfo == NULL)
    {
      fprintf (stderr, "Unknown host %s.\n", hostname);
    }
  name->sin_addr = *(struct in_addr *) hostinfo->h_addr;
}

int main() 
{
 for (;;)
 {
  sleep(1);
  int sock;
  struct sockaddr_in servername;

  /* Create the socket. */
  sock = socket (PF_INET, SOCK_STREAM, 0);
  if (sock < 0)
  {
   perror ("socket (client)");
  }

  /* Connect to the server. */
  init_sockaddr (&servername, SERVERHOST, PORT);
  if (0 > connect (sock,
    (struct sockaddr *) &servername,
    sizeof (servername)))
  {
   perror ("connect");
   sock = -1;
  }

  /* Send data to the server. */
  if (sock > -1)
   write_to_server (sock);
  if (close (sock) != 0)
   perror("close");
 }
return 0;
}

使固定:

  if (0 > connect (sock,
    (struct sockaddr *) &servername,
    sizeof (servername)))
  {
   perror ("connect");
  }

  else
   write_to_server (sock);

  if (close (sock) != 0)
   perror("close");
4

1 回答 1

12

看起来问题出在程序的结构上。每次通过无限循环,您都在创建一个新套接字。我建议将其移出循环并重新使用它。

但是,如果您只想修复现在的操作方式,请在您现在拥有的“connect” failed if 语句中使用 close 。描述符由“socket”调用分配,并且只与“connect”调用连接。通过将“sock”变量设置为-1,您将丢弃“socket”分配的描述符。调用close,然后将其设置为-1,您应该被设置。

于 2010-04-20T12:23:47.020 回答