Keeping the Platform Running
Rather than running the various workers and other long running commands in tmux
you can instead use supervisor
to launch and monitor your processes. The big advantage of using supervisor
is that it will restart your commands should they stop running.
- First lets install
supervisor
:
sudo apt-get update
sudo apt-get install supervisor
- Next we need to add a configuration for each of the workers and commands we would like supervisor to manage, starting with the queue worker:
sudo nano /etc/supervisor/conf.d/platform-queue.conf
[program:platform-queue]
process_name=%(program_name)s_%(process_num)02d
command=php /var/www/laravel/artisan queue:work
autostart=true
autorestart=true
user=www-data
numprocs=1
redirect_stderr=true
stdout_logfile=/var/www/laravel/storage/logs/platform-queue.log
- Save the queue config with
ctrl-x
y
. Now lets set up the websocket process (if using Laravel Reverb):
sudo nano /etc/supervisor/conf.d/platform-websocket.conf
[program:platform-websocket]
process_name=%(program_name)s_%(process_num)02d
command=php /var/www/laravel/artisan reverb:start
autostart=true
autorestart=true
user=www-data
numprocs=1
redirect_stderr=true
stdout_logfile=/var/www/laravel/storage/logs/platform-websocket.log
- Save the websocket config with
ctrl-x
y
. Now lets set up the ingest process:
It is advised to run
php artisan platform:sync
from your platform's installation folder before starting the ingest command.
sudo nano /etc/supervisor/conf.d/platform-ingest.conf
[program:platform-ingest]
process_name=%(program_name)s_%(process_num)02d
command=php /var/www/laravel/artisan platform:ingest
autostart=true
autorestart=true
user=www-data
numprocs=1
redirect_stderr=true
stdout_logfile=/var/www/laravel/storage/logs/platform-ingest.log
- Save the ingest config with
ctrl-x
y
. We can also do the same with the platform decoder, the template is the same, however make sure to update the path to the command to match your folder structure, and use the full path to the server command, you should also take note to update theuser=
field to your platform user, or a user which has access to the location of the platform decoder app:
sudo nano /etc/supervisor/conf.d/platform-decoder.conf
[program:platform-decoder]
process_name=%(program_name)s_%(process_num)02d
command=/home/platform/enjin/platform-decoder/bin/server
autostart=true
autorestart=true
user=platform
numprocs=1
redirect_stderr=true
stdout_logfile=/var/www/laravel/storage/logs/platform-decoder.log
Although it's not recommended to run your wallet daemon on the same server as your platform installation you can also add it to supervisor to manage, whether on the same server, or on a different server.
- Before the Wallet Daemon will run under supervisor you will need to update the path to the
store
directory inmaster_key
property of the daemon'sconfig.json
file to use the full path to the directory e.g.:
nano /home/platform/enjin/wallet-daemon/config.json
{
"node": "wss://rpc.matrix.canary.enjin.io:443",
"api": "https://your_platform_url.com/graphql",
"master_key": "/home/platform/enjin/wallet-daemon/store"
}
- Save the wallet daemon config with
ctrl-x
y
, and then set up the supervisor config, please not that you will need to add yourKEY_PASS
andPLATFORM_KEY
environment variables to the config using theenvironment=
key as well:
sudo nano /etc/supervisor/conf.d/platform-wallet.conf
[program:platform-wallet]
process_name=%(program_name)s_%(process_num)02d
command=/home/platform/enjin/wallet-daemon/target/release/wallet-daemon
autostart=true
autorestart=true
user=platform
numprocs=1
redirect_stderr=true
stdout_logfile=/var/www/laravel/storage/logs/platform-wallet.log
environment=KEY_PASS="your_key_pass",PLATFORM_KEY="your_platform_key"
- Save the wallet supervisor config with
ctrl-x
y
. With the configs saved we can now load them into supervisor and get them running:
sudo supervisorctl reread
sudo supervisorctl update
sudo supervisorctl start platform-decoder:*
sudo supervisorctl start platform-websocket:*
sudo supervisorctl start platform-queue:*
sudo supervisorctl start platform-ingest:*
sudo supervisorctl start platform-wallet:*
Each worker will output to the log files specified in the configs above, and you can check the overall status of your workers with this command:
sudo supervisorctl status
Updated 2 months ago