The PHP Script Server is a memory resident PHP interpreter that is launched
by each Cacti Data Collector or poller each polling cycle. If using
cmd.php
, there will be at most one PHP Script Server launched per poller
process. If using spine
poller, then up to 10 PHP Script Servers will be
launched in a pool for the various spine
threads to consume.
If you have a number of devices that must gather their data via a script, it's very important to utilize the PHP Script Server. This feature allows for the rapid execution of PHP based Scripts and Data Queries in Cacti thus reducing Data Collector polling times.
The reason that the PHP Script Server is so fast is that the PHP interpreter is started in memory one time, and for every Data Source polled, it's controlling function is interpreted only once. The resulting much faster script execution and reduced load average during the Data Collectors life cycle. Using the PHP Script Server process over the traditional exec() process nets roughly a 20+ fold speed improvement in Cacti's Data Collection process.
Since PHP is such a powerful language, this Cacti feature enables rapid collection of virtually any Data Source metric. It's an excellent choice for both SNMP and non-SNMP based data.
Cacti contains two sample PHP Script Server scripts for reference. They are for the collection of HostMib CPU and Disk Partition information. These two examples are based off the traditional POPEN version of the HostMib functions found in earlier versions of Cacti. Upgrading from these very old Data Input Methods to the PHP Script Server is not longer supported.
If you have Scripts or Data Queries that you wish to migrate, you must follow the steps below to migrate those scripts to the PHP Script Server format.
First, if your script is written in another languages, say Perl, or Python, you need to convert it to PHP. Then, each PHP Script file must be changed to the new Script Server format. The changes are not dramatic, but required for the proper operation of the PHP Script Server. Note that you should use PHP internal functions for calling services rather than forking binaries within the PHP script as this will defeat the purpose of the PHP Script Server. Follow the steps below to complete the migration.
-
Copy your existing script to a new name. The name must begin
ss_
followed by your script name. Thess_
identifies the script as being a script server variety of the a PHP script and is named that way to easily identify them in your install. For example, if you previously had a script calledget_mysql_stats.php
, it's new name would bess_get_mysql_stats.php
. -
Edit the new PHP script and add the following required lines to the file, where
ss_myfunction
is the same as your filename.<?php $no_http_headers = true; /* display No errors */ error_reporting(E_ERROR); if (!isset($called_by_script_server)) { array_shift($_SERVER["argv"]); print call_user_func_array("ss_myfunction", $_SERVER["argv"]); } ?>
-
What was originally just mainline code, must be replaced with a function name. For example, if your program previously contained the following three lines of code:
<?php $a = 100; $b = $a / 10; print $b; ?>
Would become:
function ss_myfunction() { $a = 100; $b = $a / 10; print $b; }
-
If you have any additional functions declared within your script file, you must prefix them to make them unique among all functions. Our recommendation would be to prefix all functions with the name of the main function. For example if you have a function called "meme" you would rename it to
ss_myfunction_meme
. This guarantee's correct PHP Script Server functionality. -
The last step is to change the function call that could have traditionally returned the value to the Cacti poller using the
print
function. You must change that line or lines in your code to utilize thereturn
function instead. However, this does not apply toprint
statements that are not called from the Poller. For a simple script, this results infunction ss_myfunction() { $a = 100; $b = $a / 10; return $b; }
Be careful, when writing Script Server Data Queries. Use the
return
function for returning results of the GET operation. But useprint
forindex
andquery
operations, e.g.if (($cmd == "index")) { ... print $some_index_data . PHP_EOL; } elseif ($cmd == "query") { ... print $some_query_data . PHP_EOL; } elseif ($cmd == "get") { ... return $some_get_data; }
If your Data Sources are based upon a Data Query, then you must also
change your XML file contents and location. Please reference the XML files in
the <path_cacti>/resource/script_server
directory for the specifics related to
your required modifications. However, you may also follow the instructions
below:
-
Modify the
<script_path>
tag. Change it from:<script_path>|path_php_binary| -q |path_cacti|/scripts/myfucntion.php</script_path>
to simply the following:
<script_path>|path_cacti|/scripts/ss_myfunction.php</script_path>
-
Add the following two XML tags below the
<script_path>
tag. Replacess_myfunction
with your function name:<script_function>ss_myfunction</script_function> <script_server>php</script_server>
-
Save the XML file.
Your Data Queries and Data Templates must be also modified. Although somewhat self explanatory by now, you must make the following changes:
-
If the Data Template is based upon a Script and not a Data Query, change it's Data Input Method to
Script Server
. -
If the Data Template is based upon a Data Query, edit the Data Query and change it's Data Input Method to
Get Script Server Data (Indexed)
and change the XML file path to point to the new XML file in the<path_cacti>/resources/script_server/
directory. -
Your final step is to go to the Console > System Utilities > Rebuild Poller Cache to apply the new settings.
If your PHP Script Server script is operating correctly, you should now be migrated to the PHP Script Server.
To test your script in the script server, simply follow the instructions below.
When you have finished you testing, simply type "quit" + <CR>
at the PHP
Script Server command line to exit the script server.
-
Start the script server - You can do this by typing the following command:
shell> php <path_cacti>/script_server.php
NOTE: Due to a bug in Windows implementation of PHP, you must type the full path name to the
script_server.php
file. -
Type in your command - Using the example from above, you would type in the following:
script server> /path_cacti/scripts/ss_myserver_file.php my_function argument1 argument2 ...
In the Windows environment, your example could be the following:
script server> c:\www\root\cacti\script\ss_myserver_file.php ss_myfunction argument1 argument2 ...
-
If your script and function is operating properly, you should get a result.
script server> c:\www\root\cacti\script\ss_myserver_file.php ss_myfunction argument1 argument2 ... nameA:valueA nameB:valueB ...
-
To quit the script server, simply type
quit <CR>
at the command line.Note: If there are errors in your script, you must restart the script server before your retest your code.
Copyright (c) 2004-2024 The Cacti Group