Dzięki nowemu systemowi możesz stworzyć usługę.
Musisz utworzyć plik lub dowiązania w /etc/systemd/system/
, np. myphpdaemon.service i umieść zawartość taką jak ta, myphpdaemon będzie nazwą usługi:
[Unit]
Description=My PHP Daemon Service
#May your script needs MySQL or other services to run, eg. MySQL Memcached
Requires=mysqld.service memcached.service
After=mysqld.service memcached.service
[Service]
User=root
Type=simple
TimeoutSec=0
PIDFile=/var/run/myphpdaemon.pid
ExecStart=/usr/bin/php -f /srv/www/myphpdaemon.php arg1 arg2> /dev/null 2>/dev/null
#ExecStop=/bin/kill -HUP $MAINPID #It's the default you can change whats happens on stop command
#ExecReload=/bin/kill -HUP $MAINPID
KillMode=process
Restart=on-failure
RestartSec=42s
StandardOutput=null #If you don't want to make toms of logs you can set it null if you sent a file or some other options it will send all php output to this one.
StandardError=/var/log/myphpdaemon.log
[Install]
WantedBy=default.target
Będziesz mógł uruchomić, uzyskać status, zrestartować i zatrzymać usługi za pomocą polecenia
systemctl <start|status|restart|stop|enable> myphpdaemon
Skrypt PHP powinien mieć rodzaj „pętli”, aby kontynuować działanie.
<?php
gc_enable();//
while (!connection_aborted() || PHP_SAPI == "cli") {
//Code Logic
//sleep and usleep could be useful
if (PHP_SAPI == "cli") {
if (rand(5, 100) % 5 == 0) {
gc_collect_cycles(); //Forces collection of any existing garbage cycles
}
}
}
Przykład pracy:
[Unit]
Description=PHP APP Sync Service
Requires=mysqld.service memcached.service
After=mysqld.service memcached.service
[Service]
User=root
Type=simple
TimeoutSec=0
PIDFile=/var/run/php_app_sync.pid
ExecStart=/bin/sh -c '/usr/bin/php -f /var/www/app/private/server/cron/app_sync.php 2>&1 > /var/log/app_sync.log'
KillMode=mixed
Restart=on-failure
RestartSec=42s
[Install]
WantedBy=default.target
Jeśli twoja procedura PHP powinna być wykonywana raz w cyklu (jak diggest), możesz użyć powłoki lub skryptu bash do wywołania w pliku usługi systemd zamiast bezpośrednio PHP, na przykład:
#!/usr/bin/env bash
script_path="/app/services/"
while [ : ]
do
# clear
php -f "$script_path"${1}".php" fixedparameter ${2} > /dev/null 2>/dev/null
sleep 1
done
Jeśli wybrałeś tę opcję, powinieneś zmienić KillMode na mixed
procesy, zabić bash (main) i PHP (child).
ExecStart=/app/phpservice/runner.sh phpfile parameter > /dev/null 2>/dev/null
KillMode=process
This method also is effective if you're facing a memory leak.
Uwaga: Za każdym razem, gdy zmieniasz "myphpdaemon.service", musisz uruchomić `systemctl daemon-reload ', ale martw się, jeśli tego nie zrobisz, zostanie on ostrzeżony, gdy będzie potrzebny.