Re: shm_open and EMFILE
Re: shm_open and EMFILE
- Subject: Re: shm_open and EMFILE
- From: David McGavran <email@hidden>
- Date: Mon, 18 Feb 2008 20:39:22 +0100
Interesting but it is 100% consistent. If I debug from xcode
getrlimit returns 10240. If I log from launching on the finder it
says -1 for max and I can open 253. If I run from xcode it is 2000
something or other.
In any case using setrlimit fixes it to be consistent. I would also
think XCode shouldn't do this. Maybe I am inheriting their value
because they are launching us?
Cheers
Dave
On Feb 18, 2008, at 8:37 PM, Terry Lambert wrote:
I don't know what Xcode does here, but I'd be surprised if it did
this to you, since you more or less want it to emulate the runtime
environment you get normally. If it doesn't, you will want to
report it.
My guess before your second message was that it was the client that
was limiting the connections to the server, but that assumes a
single client process. Additionally, if it were on the same machine,
I'd expect closer to 5120, given half the decriptors would go to
each process.
-- Terry
On Feb 16, 2008, at 2:28 PM, David McGavran <email@hidden>
wrote:
Like I said asking for help always let you find the answer.
Let me guess XCode sets your limits much higher than running from
the finder? Here are my guess:
Debug in XCode 10240
Run in XCode 2200 something like that
Finder or LSLaunchApplication 253
I never enabled the setrlimit code because when I tested it in the
debugger it wasn't doing anything, because I was already at max.
Is that correct?
Cheers
Dave
On Feb 16, 2008, at 10:40 PM, David McGavran wrote:
Ok, I am officially confused. So hopefully I will solve it as
soon as I write this email ;)
If I launch my app (which is a server) and just loop on creating
files I get 10237 which is cool.
If I launch my app and have a client connect to it using
NSConnection and loop on creating files I get 253, very
consistently.
Any ideas why that would be? Are there any debugging tricks for
this? If I look in activity monitor it is showing the 253 files
but not too much else.
Cheers
Dave
On Feb 16, 2008, at 7:17 AM, Terry Lambert wrote:
There are some descriptors used up for normal housekeeping. Also
realize that for ach one you have open, that's a file, socket,
pipe, etc. that you are not going to be able to open.
stdin, stdout, stderr = 3
10237 + 3 = 10240
-- Terry
On Feb 14, 2008, at 11:46 PM, David McGavran wrote:
Ok I guess this is good news then :)
Thanks! I love it when I am wrong :)
I did a much more simple test and was able to hit 10237 which is
much closer to the max of 10240 as I hoped. There must be
something else wrong, I will have to dig deeper.
Cheers
Dave
On Feb 15, 2008, at 2:05 AM, Terry Lambert wrote:
On Feb 14, 2008, at 11:43 AM, David McGavran wrote:
I would guess this has been asked and answered so any pointers
are fine. I tried to check the digest but didn't find the
answer.
I am trying to setup a lot of mem mapped files. But at or
around 240 I get EMFILE which man page says means I have too
many open.
If I am not mistaken on 10.5 at least we are allowed 12000 or
so open files? Why can I only open 240 or so memory mapped
files?
You are mistaken.
The limit on the number of files for a process is by default
256, as a soft constraint, and the value of maxfiles, as a hard
constraint. The value of maxfiles represents the maximum
number of files permitted an individual process.
In addition, there is a hard constraint based on whatever your
parent process decides to constrain you to; the default value
of this is "unlimited" (by which it means "whatever the current
sysctl-based hard limits are"). Once lowered the value of the
hard limit cannot be reaised except by a process with root
privilege.
The value of maxfiles is reported by the sysctlbyname() value
for "kern.maxfilesperproc"; this in turn is constrained by the
the sysctlbyname() value for "kern.maxfiles", which is a
compile time system limit.
Note that the use of actual file descriptors to implement POSIX
shared memory is an implementation detail, so all of the above
is potentially subject to change in its relevency if that
implementation detail ever changes.
What can I do to open more?
man 2 setrlimit
Also note that other administrative constraints other than
number of available file descriptors (such as available kernel
memory) will potentially also cause your attempt to ail (e.g.
ENOMEM, ENOSPC, SPERM, EACCES, etc.).
-- Terry
_______________________________________________
Do not post admin requests to the list. They will be ignored.
Darwin-dev mailing list (email@hidden)
Help/Unsubscribe/Update your Subscription:
This email sent to email@hidden
_______________________________________________
Do not post admin requests to the list. They will be ignored.
Darwin-dev mailing list (email@hidden)
Help/Unsubscribe/Update your Subscription:
This email sent to email@hidden