Server IP : 85.214.239.14 / Your IP : 3.138.137.175 Web Server : Apache/2.4.62 (Debian) System : Linux h2886529.stratoserver.net 4.9.0 #1 SMP Tue Jan 9 19:45:01 MSK 2024 x86_64 User : www-data ( 33) PHP Version : 7.4.18 Disable Function : pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare, MySQL : OFF | cURL : OFF | WGET : ON | Perl : ON | Python : ON | Sudo : ON | Pkexec : OFF Directory : /proc/3/cwd/usr/share/doc/libnet-server-perl/examples/ |
Upload File : |
#!/usr/bin/perl =head1 NAME LoadTester.pl - Allow for testing load agains various servers =head1 SYNOPIS # start - or find a server somewhere perl -e 'use base qw(Net::Server::PreForkSimple); __PACKAGE__->run' # change parameters in sub configure_hook # setup the load to test against the server in sub load # run this script LoadTester.pl =cut use strict; use warnings; use base qw(Net::Server::PreFork); use IO::Socket; BEGIN { Time::HiRes->import('time') if eval { require Time::HiRes }; } $| = 1; __PACKAGE__->run(min_servers => 100, max_servers => 255, max_spare_servers => 101); exit; ###----------------------------------------------------------------### ### set up the test parameters sub configure_hook { my $self = shift; $self->{'addr'} = 'localhost'; # choose a remote addr $self->{'port'} = 20203; # choose a remote port $self->{'file'} = '/tmp/mysock'; # sock file for Load testing a unix socket $self->{'failed'} = 0; # failed hits (server was blocked) $self->{'hits'} = 0; # log hits $self->{'hits2'} = 0; # log hits $self->{'report_hits'} = 1000; # how many hits in between reports $self->{'max_hits'} = 20_000; # how many impressions to do $self->{'time_begin'} = time; # keep track of time $self->{'time_begin2'} = time; # keep track of time $self->{'sleep'} = 0; # sleep between hits? $self->{'ssl'} = 0; # use SSL ? } ### these generally deal with sockets - ignore them sub pre_bind { require IO::Socket::SSL if shift->{'ssl'} } sub bind { shift()->log(2, "Running under pid $$") } sub accept { 1 } sub post_accept {} sub get_client_info {} sub allow_deny { 1 } sub post_process_request {} sub process_request { my $self = shift; sleep $self->{'sleep'} if $self->{'sleep'}; ### try to connect and deliver the load my $class = $self->{'ssl'} ? 'IO::Socket::SSL' : 'IO::Socket::INET'; if ($self->{'remote'} = $class->new(PeerAddr => $self->{'addr'}, PeerPort => $self->{'port'})) { $self->load; return; } #if ($self->{remote} = IO::Socket::UNIX->new(Peer => $self->{'file'})) { # $self->load; # return; #} print { $self->{'server'}->{'_WRITE'} } "$$ failed [$!]\n"; } sub load { my $self = shift; my $handle = $self->{'remote'}; $handle->autoflush(1); my $line = <$handle>; print $handle "quit\n"; } sub parent_read_hook { my ($self, $status) = @_; if ($status =~ /failed/i) { $self->{'failed'}++; print $status; if ($self->{'failed'} >= 300) { $self->{'time_end'} = time; $self->print_report; $self->server_close; } return 1; } return if $status !~ /processing/i; $self->{'hits'}++; $self->{'hits2'}++; print "*" if not $self->{'hits'} % 100; if (not $self->{'hits'} % $self->{'report_hits'}) { $self->{'time_end'} = time; $self->print_report; $self->{'hits2'} = 0; $self->{'time_begin2'} = time; } $self->server_close if $self->{'hits'} >= $self->{'max_hits'}; } sub print_report { my $self = shift; my $time = $self->{'time_end'} - $self->{'time_begin'}; my $time2 = $self->{'time_end'} - $self->{'time_begin2'}; print "\n$0 Results\n"; print "--------------------------------------------\n"; printf "(%d) overall hits in (%.3f) seconds: %.3f hits per second\n", $self->{'hits'}, $time, ($time ? $self->{'hits'}/$time : $self->{'hits'}); printf "(%d) hits in (%.3f) seconds: %.3f hits per second\n", $self->{'hits2'}, $time2, ($time2 ? $self->{'hits2'}/$time2 : $self->{'hits2'}); print "($self->{failed}) failed hits\n"; }