提交 a4458597 编写于 作者: D Daniel P. Berrange 提交者: Daniel Veillard

Report error if unable to bind to any socket

When setting up a server socket, we must skip EADDRINUSE errors
from bind, since the IPv6 socket bind may have already bound to
the IPv4 socket too. If we don't manage to bind to any sockets
at all though, we should then report the EADDRINUSE error as
normal.

This fixes the case where libvirtd would not exit if some other
program was listening on its TCP/TLS ports.

* src/rpc/virnetsocket.c: Report EADDRINUSE
上级 4bfd0cf7
...@@ -192,6 +192,7 @@ int virNetSocketNewListenTCP(const char *nodename, ...@@ -192,6 +192,7 @@ int virNetSocketNewListenTCP(const char *nodename,
struct addrinfo hints; struct addrinfo hints;
int fd = -1; int fd = -1;
int i; int i;
int addrInUse = false;
*retsocks = NULL; *retsocks = NULL;
*nretsocks = 0; *nretsocks = 0;
...@@ -250,7 +251,9 @@ int virNetSocketNewListenTCP(const char *nodename, ...@@ -250,7 +251,9 @@ int virNetSocketNewListenTCP(const char *nodename,
virReportSystemError(errno, "%s", _("Unable to bind to port")); virReportSystemError(errno, "%s", _("Unable to bind to port"));
goto error; goto error;
} }
addrInUse = true;
VIR_FORCE_CLOSE(fd); VIR_FORCE_CLOSE(fd);
runp = runp->ai_next;
continue; continue;
} }
...@@ -273,6 +276,12 @@ int virNetSocketNewListenTCP(const char *nodename, ...@@ -273,6 +276,12 @@ int virNetSocketNewListenTCP(const char *nodename,
fd = -1; fd = -1;
} }
if (nsocks == 0 &&
addrInUse) {
virReportSystemError(EADDRINUSE, "%s", _("Unable to bind to port"));
goto error;
}
freeaddrinfo(ai); freeaddrinfo(ai);
*retsocks = socks; *retsocks = socks;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册