in reply to TCP port test

The following Perl function uses the IO::Socket and Net::Nslookup perl modules (available on CPAN) to test a TCP socket connection from the machine running the script to a remote host. The function accepts either an ip address or a hostname. If a hostname is passed to the function it will first be resolved to an ip address, producing an error if the hostname is not resolveable.

This is a good replacement for those that rely on the telnet command to test for TCP port availability.

sub socketConnect(){ #This function requires two arguments; a host and a TCP port. Example +: socketConnect("server1","80"); use IO::Socket; use Net::Nslookup; my ($peeraddr,$peerport) = @_; my $sock = new IO::Socket::INET ( Timeout => 5, PeerAddr => $peeraddr +, PeerPort => $peerport, Proto => 'TCP' ); if ($sock){ if ( print $sock "HELO\n" ) { print "$peeraddr TCP/$peerport" . " connection allowed\n"; } close($sock); } else { #Socket open failed or could not resolve hostname if (nslookup $peeraddr){ print "$peeraddr TCP/$peerport" . " connection refused\n"; } else { print "Could not resolve $peeraddr\n"; } } }

Source: ApplicationBistro.com