logo
Apache Lounge
Webmasters

 

About Forum Index Downloads Search Register Log in RSS X


Keep Server Online

If you find the Apache Lounge, the downloads and overall help useful, please express your satisfaction with a donation.

or

Bitcoin

A donation makes a contribution towards the costs, the time and effort that's going in this site and building.

Thank You! Steffen

Your donations will help to keep this site alive and well, and continuing building binaries. Apache Lounge is not sponsored.
Post new topic   Forum Index -> Coding & Scripting Corner View previous topic :: View next topic
Reply to topic   Topic: Script to count number of specific processes
Author
Brian



Joined: 21 Oct 2005
Posts: 209
Location: Puyallup, WA USA

PostPosted: Mon 17 Aug '09 4:19    Post subject: Script to count number of specific processes Reply with quote

Potentially this is too much to ask, but I will give it a shot.

I want to know how I can create in PHP or Perl, preferably PHP, a script to count the number of system processes that are using a specific executable.

I want to have a script to check the total number of "CMD.EXE" processes running, and then have it notify me when there are more than perhaps five. The notification portion I already have, but how to actually count the number of individual processes spawned running CMD.EXE is what I need.

Is this even possible to determine via PHP, or Perl?

Thanks.
Back to top
paranid



Joined: 02 Mar 2009
Posts: 11

PostPosted: Mon 17 Aug '09 10:23    Post subject: Reply with quote

I do not know how to do this the secure/better way, because you need to have enabled shell_exec() function!

PHP:
Code:

$output = shell_exec("tasklist");
echo "<pre>";
print_r ($output);
echo "</pre>";


(It will invoke another cmd console.)
Back to top
glsmith
Moderator


Joined: 16 Oct 2007
Posts: 2268
Location: Sun Diego, USA

PostPosted: Mon 17 Aug '09 11:11    Post subject: Reply with quote

This is almost verbatim out of the ActivePerl docs
Win32::Process::Info

Code:

    use Win32::Process::Info;
    $pi = Win32::Process::Info->new ();
    $pi->Set (elapsed_in_seconds => 0);    # In clunks, not seconds.
    @info = $pi->GetProcInfo ();   # Get the max
    @info = grep {$_->{Name} =~ m/cmd\.exe/}
    $pi->GetProcInfo ();        # All processes with 'cmd.exe' in name.
    $pcount=@info;
    print "There are ".$pcount." processes named cmd.exe\n\n";
    foreach my $info (@info) {
        print "ProcessId: ".$info->{ProcessId}." Name: ".$info->{Name}."\n";
    }
    exit 0;



C:\build\tmp>perl cmdcount.pl
There are 1 processes named cmd.exe

ProcessId: 2824 Name: cmd.exe
Back to top
Brian



Joined: 21 Oct 2005
Posts: 209
Location: Puyallup, WA USA

PostPosted: Mon 17 Aug '09 20:11    Post subject: Reply with quote

Thank you both for your reply, they were quite helpful.
Back to top
James Blond
Moderator


Joined: 19 Jan 2006
Posts: 7371
Location: Germany, Next to Hamburg

PostPosted: Fri 21 Aug '09 22:00    Post subject: Reply with quote

here a working php script like the great perl script from Gregg.

Code:

<?php
$wmi = new COM('winmgmts://');
$processes = $wmi->ExecQuery("SELECT * FROM Win32_Process WHERE Name = 'CMD.EXE'");
foreach($processes as $process){
    echo 'cmd line: '. $process->CommandLine . ' --> pid: '. $process->ProcessId . "\r\n";
}
//reference http://msdn2.microsoft.com/en-us/library/aa394372.aspx
?>
Back to top
glsmith
Moderator


Joined: 16 Oct 2007
Posts: 2268
Location: Sun Diego, USA

PostPosted: Tue 25 Aug '09 3:16    Post subject: Reply with quote

... and there are the keys to almost anything in the Windows OS, either tapping directly into the Windows API (as the Win32::Process::Info module does on NT) or the WMI as James has done in his php snipit and Win32::Process::Info will as one of it's backups if it cannot directly talk to the API.
Back to top
Brian



Joined: 21 Oct 2005
Posts: 209
Location: Puyallup, WA USA

PostPosted: Sun 08 Nov '09 8:06    Post subject: VBS solution Reply with quote

I did not write this, but I did adapt it for my purposes. The issue is that while I must run PHP in Apache Module, I cannot use F/CGI for what I am doing.

So occasionally some of the modules that Image Magick calls crash, they are not thread safe. IM creator claims that IM is itself threadsafe but that he cannot say the same about modules that IM uses.

I was using a chron job to run a PHP script via CLI, but that was not reliable. I have not had the time to investigate. I am trying this VBS that I adapted, here is the script I am using with a chron running every 120 seconds:

Code:
strComputer = "."
Set objWMIService = GetObject("winmgmts:" & "{impersonationLevel=impersonate}!\\" & strComputer & "\root\cimv2")
Set colProcess = objWMIService.ExecQuery ("Select Name from Win32_Process WHERE Name='cmd.exe'")
If colProcess.Count > 6 Then
  Set wshShell = WScript.CreateObject ("WSCript.shell")
  wshshell.run """c:/path/to/script/script_name.vbs""", 6, True
  set objWMIService=Nothing
  set colProcess=Nothing
  Wscript.quit
End If
 
Wscript.quit


I found that if the CMD.exe count is higher than four or five typically this is a solid indication that there was a crash. This is far from scientific, it is a terrible solution to a problem that just mystifies me. Why can't a crashed thread internal to Apache be detected and dealt with? I understand that it is PHP calling a script that calls an executable that then calls other DLL's, but ultimately the crash must be detectable by the server, isn't it?
Back to top
glsmith
Moderator


Joined: 16 Oct 2007
Posts: 2268
Location: Sun Diego, USA

PostPosted: Sun 08 Nov '09 11:19    Post subject: Reply with quote

*shrugs*

But in this case I think PHP should be doing that since it's the one spawning off a child process ... I think. mod_fcgid AFAIK handles the processes it spawns off itself.

However, I found this to be an interesting comment on the dev list. It's covers a few thing but a process management module is what is being talked about in it as well. Heck interesting, it actually sounds real good to me .. all of it .. plugins included.

http://marc.info/?l=apache-httpd-dev&m=125746748513752&w=2
Back to top
James Blond
Moderator


Joined: 19 Jan 2006
Posts: 7371
Location: Germany, Next to Hamburg

PostPosted: Sun 08 Nov '09 13:21    Post subject: Re: VBS solution Reply with quote

Back to your problem

[code]
<?php
$wmi = new COM('winmgmts://');
$processes = $wmi->ExecQuery("SELECT * FROM Win32_Process WHERE Name = 'CMD.EXE'");
$instance = 0;
foreach($processes as $process){
$instances[$instance] = $process->ProcessId . "\r\n";
}

$result = count($instances);
if($result >= 4){
foreach($instances as $instance){
exec("Taskkill /F /PID $instance >nul 2>&1");
}
}
?>

That should kill the cmd.exe's

I wonder which part of your program causes all that cmd.exe's
You call imagemagick from the command line with exec?
Back to top
Brian



Joined: 21 Oct 2005
Posts: 209
Location: Puyallup, WA USA

PostPosted: Sun 08 Nov '09 21:22    Post subject: PHP would work except... Reply with quote

PHP would work except that I found it just doesn't work reliably.

The script I was using via CLI and a chron job would work most of the time, but not all of the time. The advantage of this VBS solution is it does not require PHP or Apache, it is purely an OS scheduled task running a native language that the OS understands (Visual Basic Script).

When a thread crashes it will have two programs open. I make an EXEC call to an Image Magick executable, such as CONVERT.EXE and that opens a CMD.EXE window, thus I count the CMD's because Image Magick has other programs like MOGRIFY.EXE and others. If convert calls a library that is not thread safe and crashes it brings the entire server down.

This is insane!

The work around is either:

A) Use Linux -> learn Linux and how to administrate a server and all the components such as Apache, Perl, PHP, MySQL, and so on...

- or -

B) Use F/CGI -> lose the ability to run the module and thus each vhost uses same INI file. If I want I could run some in cgi and some as module - that is that really the right way to go?

If an EXEC call in PHP results in a crash, calling subsequent EXEC functions will not necessarily execute at all - thus there is no assurance that the process will work.

This has been a problem for Windows and Apache with any type of SAPI interface since the beginning. Non-Thread safe programs bringing down the server.

As I said, this is nuts, why has this never been addressed? There are many WAMP servers out there but I still feel that Apache shoots itself in the foot wanting to be for *nix but lets Windows play with it a little bit.

Frustrating Smile
Back to top
James Blond
Moderator


Joined: 19 Jan 2006
Posts: 7371
Location: Germany, Next to Hamburg

PostPosted: Sun 08 Nov '09 22:06    Post subject: Re: PHP would work except... Reply with quote

Brian wrote:

B) Use F/CGI -> lose the ability to run the module and thus each vhost uses same INI file. If I want I could run some in cgi and some as module - that is that really the right way to go?

You can also in FCGID define different php.ini files or use php_admin_value in each vhost to define the differences. What is the advantage of the module? OK cgi is slow and some session things do not work, but with fcgid it is different. I haven't found a software from my script that don't run.

Brian wrote:

If an EXEC call in PHP results in a crash, calling subsequent EXEC functions will not necessarily execute at all - thus there is no assurance that the process will work.

Did you try the @ operator? OK it is ugly, but sometimes it prevents aborting of the script.
Back to top
Brian



Joined: 21 Oct 2005
Posts: 209
Location: Puyallup, WA USA

PostPosted: Sun 08 Nov '09 22:15    Post subject: Reply with quote

I thought that the "@" operator essentially just turned of error reporting / checking, such as during a SQL connection, file open operation and so on.

F/CGI does not work with some things I do, I have tested it.

Speed is very important, my server is very heavy in image manipulation - heavy CPU and a plethora of session activity, connections to SQL, and constant updating info in SQL and session...

So a server that breathes easy is very important.
Back to top
James Blond
Moderator


Joined: 19 Jan 2006
Posts: 7371
Location: Germany, Next to Hamburg

PostPosted: Sun 08 Nov '09 22:48    Post subject: Reply with quote

Did you ever think of putting the session data into the DB to speed up your applications?
Back to top
Brian



Joined: 21 Oct 2005
Posts: 209
Location: Puyallup, WA USA

PostPosted: Sun 08 Nov '09 23:03    Post subject: Reply with quote

Okay you are hitting two key points that I want to address.

I should not HAVE to re-design my programs to do things differently. I should not HAVE to design around what seems to be a weakness or flaw - though I do have to if I want to avoid any risk of this issue coming up.

I had built a comprehensive platform for file management, integrating mail, stripping attachments, online image manipulation, and build web pages.

I integrated a a number of open source scripts into my own framework and programming.

I am using PHP, Perl, and a lot of command line calls.

In order for me to make the entire system work under a different model would be an immense undertaking.

Likewise my services did not grow over night, so there was a breaking point where the services I was adding, the integration of services and conveniences would grow at a rate that just did not make starting over very attractive.

Redesign - testing, debugging, more testing, more debugging...

When the point I am driving at is that Apache should not be brought down because of a JPG conversion module called by IM which was called by PHP which was called from within Apache crashes. I guess to some degree I am venting, for that I am sorry.

But to a larger degree I am looking at a bandaid solution to a problem that consumes far less time and effort and hopefully produces satisfactory "enough" results.

It seems that if Apache could not be brought to it's knees by a subsequent call to a non-thread safe module, then that would be the best solution.

Does that make sense?
Back to top


Reply to topic   Topic: Script to count number of specific processes View previous topic :: View next topic
Post new topic   Forum Index -> Coding & Scripting Corner