I am running my code on CodeIgniter - Ubuntu Server.
I have been researching for async ways to run functions.
This is my function:
<?php
// Registers a new keyword for prod to the DB.
public function add_keyword() {
$keyword_p = $this->input->post('key_word');
$prod = $this->input->post('prod_name');
$prod = $this->kas_model->search_prod_name($prod);
$prod = $prod[0]->prod_id;
$country = $this->input->post('key_country');
$keyword = explode(", ", $keyword_p);
var_dump($keyword);
$keyword_count = count($keyword);
echo "the keyword count: $keyword_count";
// problematic part that needs forking
for ($i=0; $i < $keyword_count ; $i++) {
// get new vars from $keyword_count
// run API functions to get new data_arrays
// inserts new data for each $keyword_count to the DB
}
// Redirect to main page.
redirect('banana/kas');
}
The "foreach" uses variables with slow APIs, and updates the database.
I saw some tutorials using fork but haven't quite understood the syntax part of it. Most of the things I found were just explanations of how it works (2 processes: parent-child ect') but non-gave a good explanation of how applying this on the code.
Can someone explain how I work with the fork() syntax?
Continue PHP execution after sending HTTP response
http://www.onlinetechtutorials.com/2014/06/how-to-run-php-code-asynchronously.html
http://php.net/manual/en/function.pcntl-fork.php (more general)
From the server side: https://www.youtube.com/watch?v=xVSPv-9x3gk
EDIT:
Did I get it right?
<?php
// Registers a new keyword for prod to the DB.
public function add_keyword() {
$keyword_p = $this->input->post('key_word');
$prod = $this->input->post('prod_name');
$prod = $this->kas_model->search_prod_name($prod);
$prod = $prod[0]->prod_id;
$country = $this->input->post('key_country');
$keyword = explode(", ", $keyword_p);
var_dump($keyword);
$keyword_count = count($keyword);
echo "the keyword count: $keyword_count";
for ($i=0; $i < $keyword_count ; $i++) {
// create your next fork
$pid = pcntl_fork();
if(!$pid){
//*** get new vars from $keyword_count
//*** run API functions to get new data_arrays
//*** inserts new data for each $keyword_count to the DB
print "In child $i\n";
exit($i);
// end child
}
}
// we are the parent (main), check child's (optional)
while(pcntl_waitpid(0, $status) != -1){
$status = pcntl_wexitstatus($status);
echo "Child $status completed\n";
}
// your other main code: Redirect to main page.
redirect('banana/kas');
}
?>
This won't cause any problem with using this inside a loop? will it know to stack each process?
As far as I am aware of, you can achieve this in two ways...
Use:
Pthreads is a parallel processing library, while amp is a pure asynchronous framework...
So, the way for using pthreads would be to first download/enable the pthreads extension and add
extension=/path/to/pthread.so
in the php.ini file...And then create a class, which extends the
Thread
Class and override the method run, and put everything inside it, which you want to do parallely.So for your specific purpose the the class could be something like this:
To use that, just instantiate the class, and put the the DB connection variable, and the data to be processed in the ctor. And call the start method of the object. Like:
Where
$dbConn
stores the DB connection and$data
stores the necessary data.And that's it...
You have one fork after your pcntl_fork(), check $pid and then you can use it. Repeat for more forks.
For async http requests you can use multicurl: http://php.net/manual/en/function.curl-multi-init.php
You must mention what's the operating system that you are using, because pcntl extensions are not available on Windows platform
Also you must be aware that activating process control on Linux/Unix within a web server can give you unexpected results, so only CLI/CGI mode is recommended to use PCNTL
Please read carefully this PCNTL Introduction
Now, your code seems to be correct and well implemented, but you must compile your PHP with this option
--enable-pcntl
to enable pcntl functions likeint pcntl_fork(void)
otherwise you will getFor me, the best solution to run functions/methods in asynchronous way is to use pthreads, if you are interested by this advice i can edit my response by adding examples and how to install it on Windows or Linux platforms
Read this article to know how to compile PHP