I've used fork in a somewhat more specialized version of my Fork::Queue node. I'm using it in an error event processor. Basically, I don't want the clients that are sending events to have to wait on the server to process the event.

I fork off one child, who can work the queue of events while the main process is free to handle client requests as fast as possible.

I also use fork() when I need simple multitasking, and don't want to serialize file i/o ( or some other long-running or blocking operation).

As an example, I have a unix box with 3 web servers on it. I have a perl script that grabs lines from each web server log and grinds out some stats. So, the parent forks off three children, each with a pipe back to the parent. Each child process grinds on the individual stats, then passes a small amount of aggregate stats back to the parent over the pipe. The parent can then spit out "global" stats for the box. This runs, as you can imagine, almost three times faster than doing it serially.


In reply to Re: Practical, efficient uses for fork() by kschwab
in thread Practical, efficient uses for fork() by vilk

Title:
Use:  <p> text here (a paragraph) </p>
and:  <code> code here </code>
to format your post, it's "PerlMonks-approved HTML":



  • Posts are HTML formatted. Put <p> </p> tags around your paragraphs. Put <code> </code> tags around your code and data!
  • Titles consisting of a single word are discouraged, and in most cases are disallowed outright.
  • 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:
    a, abbr, b, big, blockquote, br, caption, center, col, colgroup, dd, del, details, 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, summary, sup, table, tbody, td, tfoot, th, thead, tr, tt, u, ul, wbr
  • You may need to use entities for some characters, as follows. (Exception: Within code tags, you can put the characters literally.)
            For:     Use:
    & &amp;
    < &lt;
    > &gt;
    [ &#91;
    ] &#93;
  • Link using PerlMonks shortcuts! What shortcuts can I use for linking?
  • See Writeup Formatting Tips and other pages linked from there for more info.