I'm trying to understand multi-threaded processes but I'm sure I've missed something. The following script identifies fake email address (yes I know no address checker is a 100%) that some of our customers give when filling in webforms (there is a big fat opt-in/opt-out question so it's nothing sleezy.) The list of addresses is long so I wanted to use threading to speed up the proccess:

#!/usr/bin/perl -w #checks for valid email address #usage validemail <file containing email addresses> use warnings; use strict; use Email::Valid::Loose; use Net::DNS; use Parallel::ForkManager; use Fcntl qw/:flock :seek/; my $pm=new Parallel::ForkManager(20); my $resolver=Net::DNS::Resolver->new(); my $addrfile = $ARGV[0]; my ($is_valid, $host, $x, @mx, $add, @adds, $FH); #custom words that make emails invalid to you my @custom = qw( postmaster webmaster ); open (EMAILS, "$addrfile"); while (<EMAILS>){ $_ =~ s/\015//; chomp $_; push @adds, $_; } close (EMAILS); #warning, I will delete existing files $FH = "BADADDR"; open (FH, ">badmails") || die; $FH = "GOODADDR"; open (FH, ">goodmails") || die; foreach $add (@adds){ $pm->start and next; foreach $x (@custom){ if ($add =~ m/$x/){ $FH = "BADADDR"; writeaddr(); #address is bad $pm->finish; } } #if email is invalid move on if (!defined(Email::Valid::Loose->address($add))){ $FH = "BADADDR"; writeaddr(); #address is bad $pm->finish; } #if email is valid get domain name $is_valid = Email::Valid::Loose->address($add); if ($is_valid =~ m/\@(.*)$/) { $host = $1; } $is_valid=""; # perform dsn lookup to check domain @mx=mx($resolver, $host); if (@mx) { $FH = "GOODADDR"; writeaddr(); #address is good }else{ $FH = "BADADDR"; writeaddr(); #address is bad } $pm->finish; } $pm->wait_all_children; close (FH); close (FH); sub writeaddr{ flock FH, LOCK_EX or die "Flock failed: $!\n"; seek FH, SEEK_END, 0 or die "Seek failed: $!\n"; print FH "$add\n"; flock FH, LOCK_UN or die "unFlock failed: $!\n"; }

I receive no error messages but, nothing is written to the files. What have I missed?

Neil Watson
watson-wilson.ca


In reply to using Parallel::TaskManager and FileHandles. by neilwatson

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.