Another trick is to reduce the parent’s role strictly to managing the children. Spin-off the process of creating the %dataset and of determining the number of workers to a single child ... call it the project manager. The PM then informs the parent how many children are needed, and the parent spawns them. Worker processes can, say, ask the PM for another unit of work, which the PM doles-out and sends to them. There is also another child process which is the recipient and filer of completed work units.
Now, you have a dumb parent who has two gifted children (the PM and the filer), as well as a variable number of hired grunts. No large chunks of memory get duplicated on-fork, and that should eliminate your memory problem. The parent’s only job is to see to it that its children are alive. The children talk among themselves. Like any good bureaucrat, the parent is responsible for everything but basically does nothing . . . :-)
Posts are HTML formatted. Put <p> </p> tags around your paragraphs. Put <code> </code> tags around your code and data!
Read Where should I post X? if you're not absolutely sure you're posting in the right place.
Please read these before you post! —
Posts may use any of the Perl Monks Approved HTML tags:
You may need to use entities for some characters, as follows. (Exception: Within code tags, you can put the characters literally.)
- a, abbr, b, big, blockquote, br, caption, center, col, colgroup, dd, del, div, dl, dt, em, font, h1, h2, h3, h4, h5, h6, hr, i, ins, li, ol, p, pre, readmore, small, span, spoiler, strike, strong, sub, sup, table, tbody, td, tfoot, th, thead, tr, tt, u, ul, wbr
Link using PerlMonks shortcuts! What shortcuts can I use for linking?
See Writeup Formatting Tips and other pages linked from there for more info.
| & || & |
| < || < |
| > || > |
| [ || [ |
| ] || ] ||