Tracing PHP process killed on Mac does not work

General Tech Bugs & Fixes 2 years ago

0 2 0 0 0 tuteeHUB earn credit +10 pts

5 Star Rating 1 Rating

Posted on 16 Aug 2022, this text provides information on Bugs & Fixes related to General Tech. Please note that while accuracy is prioritized, the data presented might not be entirely correct or up-to-date. This information is offered for general knowledge and informational purposes only, and should not be considered as a substitute for professional advice.

Take Quiz To Earn Credits!

Turn Your Knowledge into Earnings.

tuteehub_quiz

Answers (2)

Post Answer
profilepic.png
manpreet Tuteehub forum best answer Best Answer 2 years ago

 

I'm running a simple PHP process that uses a tiny bit of memory and CPU. The max memory limit is 2G and the script is run from console.

The memory used never exceeds 200 MB. CPU use fluctuates between 10 - 80% of a single core.

At random, the process will be killed with message Killed: 9. There is nothing else given in the error message in the console and nothing appears in the logs.

This even happens if I pause the script using XDebug so that no additional memory can be used.

This happens if I disable Xdebug as well, so I don't suspect that is the culprit.

I've tried rebooting, but still happens.

The PHP script simply pulls a list of ads from Facebook using their PHP SDK v3.2 and then adds them to a database. There is only one worker running. Very simple process.

I have 32 GB RAM and 1TB HD. Running PHP 7.2 with nginx, MySQL 5.7 and redis.

My sw_vers output:

ProductName:    Mac OS X
ProductVersion: 10.14.2
BuildVersion:   18C54

System Integrity Protection status: enabled

This is the essence of the script:

$ads = $this->getApiAdAccount()->getAds($fields, $params);

$ads->setUseImplicitFetch(true);
$ads->rewind();

if (!$ads->valid()) {
    return false;
}

while ($ads->valid()) {
    $adData = $ads->current()->getData();

    try {
        if (!Campaign::find($adData['campaign'])) {
            dispatch(new ImportCampaign($adData['campaign']));
        }

        Ad::updateOrCreate(['id' => $adData['id']], $adData);
    } catch (\Exception $e) {
        $this->error($e);
    }

    $ads->next();
}

There is no specific spot it fails. I can run the Laravel job worker (redis queue) to process the code and insert/update the tiny array of data it processes on each loop.

How can I trace the source of this crash?

I've tried dmesg and dmesg | grep -E -i -B100 'killed process' as suggested elsewhere, but no useful information comes out.

profilepic.png
manpreet 2 years ago

The behavior you're seeing is not a problem with the hardware, the operating system, or lack or resources.

Instead it is simply the way that Laravel queueing works. If the worker takes too long to process a job, there's a timeout and the worker is killed with signal 9. Similar if the memory usage exceeds a set amount, the worker is killed.

You can set these limits with for example the --memory option.


0 views   0 shares

No matter what stage you're at in your education or career, TuteeHub will help you reach the next level that you're aiming for. Simply,Choose a subject/topic and get started in self-paced practice sessions to improve your knowledge and scores.