[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[Xen-devel] [PATCH] tools/xenconsoled: Increase file descriptor limit



XenServer's VM density testing uncovered a regression when moving from
sysvinit to systemd where the file descriptor limit dropped from 4096 to
1024. (XenServer had previously inserted a ulimit statement into its
initscripts.)

One solution is to use LimitNOFILE=4096 in xenconsoled.service to match the
lost ulimit, but that is only a stopgap solution.

As Xenconsoled genuinely needs a large number of file descriptors if a large
number of domains are running, and is well behaved with its descriptors,
attempt to up the limit to the system maximum.

Signed-off-by: Andrew Cooper <andrew.cooper3@xxxxxxxxxx>
CC: Ian Campbell <Ian.Campbell@xxxxxxxxxx>
CC: Ian Jackson <Ian.Jackson@xxxxxxxxxxxxx>
CC: Wei Liu <wei.liu2@xxxxxxxxxx>
---
 tools/console/daemon/main.c |   31 +++++++++++++++++++++++++++++++
 1 file changed, 31 insertions(+)

diff --git a/tools/console/daemon/main.c b/tools/console/daemon/main.c
index 92d2fc4..759c061 100644
--- a/tools/console/daemon/main.c
+++ b/tools/console/daemon/main.c
@@ -26,6 +26,7 @@
 #include <string.h>
 #include <signal.h>
 #include <sys/types.h>
+#include <sys/resource.h>
 
 #include "xenctrl.h"
 
@@ -55,6 +56,34 @@ static void version(char *name)
        printf("Xen Console Daemon 3.0\n");
 }
 
+/*
+ * Xenconsoled requires one file descriptor for each PV console, which can
+ * easily exceed the default of 1024 if many guests are running.  Try to set
+ * the fd limit to the system maximum, falling back to a default of 4096.
+ */
+static void increase_fd_limit(void)
+{
+       FILE *fs_nr_open;
+       struct rlimit lim;
+       long nr_open = 4096;
+       int rc;
+
+       rc = getrlimit(RLIMIT_NOFILE, &lim);
+       if (rc)
+               return;
+
+       fs_nr_open = fopen("/proc/sys/fs/nr_open", "r");
+       if (fs_nr_open) {
+               fscanf(fs_nr_open, "%ld", &nr_open);
+               fclose(fs_nr_open);
+       }
+
+       if ((nr_open > lim.rlim_cur) || (nr_open > lim.rlim_max)) {
+               lim.rlim_cur = lim.rlim_max = nr_open;
+               setrlimit(RLIMIT_NOFILE, &lim);
+       }
+}
+
 int main(int argc, char **argv)
 {
        const char *sopts = "hVvit:o:";
@@ -154,6 +183,8 @@ int main(int argc, char **argv)
        openlog("xenconsoled", syslog_option, LOG_DAEMON);
        setlogmask(syslog_mask);
 
+       increase_fd_limit();
+
        if (!is_interactive) {
                daemonize(pidfile ? pidfile : "/var/run/xenconsoled.pid");
        }
-- 
1.7.10.4


_______________________________________________
Xen-devel mailing list
Xen-devel@xxxxxxxxxxxxx
http://lists.xen.org/xen-devel


 


Rackspace

Lists.xenproject.org is hosted with RackSpace, monitoring our
servers 24x7x365 and backed by RackSpace's Fanatical Support®.