8
0
mirror of https://github.com/FirebirdSQL/firebird.git synced 2025-01-25 02:03:03 +01:00

Raise NPROC limit on unix to avoid errors when starting many threads

This commit is contained in:
alexpeshkoff 2010-05-20 10:30:43 +00:00
parent 18ed4f65c8
commit dc4452eb0e

View File

@ -128,6 +128,9 @@ static USHORT INET_SERVER_flag = 0;
static bool serverClosing = false; static bool serverClosing = false;
#if defined(UNIX) && defined(HAVE_SETRLIMIT) && defined(HAVE_GETRLIMIT)
static void raiseLimit(int resource);
#endif
extern "C" { extern "C" {
@ -269,24 +272,14 @@ int FB_EXPORTED server_main( int argc, char** argv)
#endif #endif
#if defined(UNIX) && defined(HAVE_SETRLIMIT) && defined(HAVE_GETRLIMIT) #if defined(UNIX) && defined(HAVE_SETRLIMIT) && defined(HAVE_GETRLIMIT)
raiseLimit(RLIMIT_NPROC);
#if !(defined(DEV_BUILD)) #if !(defined(DEV_BUILD))
if (Config::getBugcheckAbort()) if (Config::getBugcheckAbort())
#endif #endif
{ {
// try to force core files creation // try to force core files creation
struct rlimit core; raiseLimit(RLIMIT_CORE);
if (getrlimit(RLIMIT_CORE, &core) == 0)
{
core.rlim_cur = core.rlim_max;
if (setrlimit(RLIMIT_CORE, &core) != 0)
{
gds__log("setrlimit() failed, errno=%d", errno);
}
}
else
{
gds__log("getrlimit() failed, errno=%d", errno);
}
// we need some writable directory for core file // we need some writable directory for core file
// on any unix /tmp seems to be the best place // on any unix /tmp seems to be the best place
@ -298,30 +291,10 @@ int FB_EXPORTED server_main( int argc, char** argv)
} }
#if defined(SUPERSERVER) && (defined SOLARIS || defined HPUX || defined LINUX) #if defined(SUPERSERVER) && (defined SOLARIS || defined HPUX || defined LINUX)
{
// Increase max open files to hard limit for Unix // Increase max open files to hard limit for Unix
// platforms which are known to have low soft limits. // platforms which are known to have low soft limits.
struct rlimit old; raiseLimit(RLIMIT_NOFILE);
if (getrlimit(RLIMIT_NOFILE, &old) == 0 && old.rlim_cur < old.rlim_max)
{
struct rlimit new_max;
new_max.rlim_cur = new_max.rlim_max = old.rlim_max;
if (setrlimit(RLIMIT_NOFILE, &new_max) == 0)
{
#if _FILE_OFFSET_BITS == 64
gds__log("64 bit i/o support is on.");
gds__log("Open file limit increased from %lld to %lld",
old.rlim_cur, new_max.rlim_cur);
#else
gds__log("Open file limit increased from %d to %d",
old.rlim_cur, new_max.rlim_cur);
#endif
}
}
}
#endif #endif
#endif #endif
@ -583,3 +556,25 @@ static int tryStopMainThread()
return serverClosing ? 1 : 0; return serverClosing ? 1 : 0;
} }
#endif #endif
#if defined(UNIX) && defined(HAVE_SETRLIMIT) && defined(HAVE_GETRLIMIT)
static void raiseLimit(int resource)
{
struct rlimit lim;
if (getrlimit(resource, &lim) == 0)
{
if (lim.rlim_cur != lim.rlim_max)
{
lim.rlim_cur = lim.rlim_max;
if (setrlimit(RLIMIT_CORE, &lim) != 0)
{
gds__log("setrlimit() failed, errno=%d", errno);
}
}
}
else
{
gds__log("getrlimit() failed, errno=%d", errno);
}
}
#endif