It's now time to deploy my RoR 5.2.4 application to the validation environment. Inspired by this post and some other readings, I try to setup Sidekiq as a service on SLES15. Here is the service file:
#
# This file tells systemd how to run Sidekiq as a 24/7 long-running daemon.
#
# Unit file is created into /etc/systemd/system/ for execution on SLES15@BFS
# The Unit file drives only one instance of the process. To run multiple processes,
# create multiple Unit files and register multiple services
#
# Register and control service:
# - systemctl enable sidekiq
# - systemctl {start,stop,restart} sidekiq
# - journalctl -u sidekiq -rn 100 (shows the last 100 lines of log output)
[Unit]
# Start the service only once the network and logging subsystems are available,
# consider adding redis-server.service if Redis is local and systemd-managed.
Description=sidekiq
After=syslog.target network.target redis-server.service
[Service]
# Sidekiq automatically supports systemd's `Type=notify` and watchdog service monitoring.
# If your Sidekiq process locks up, systemd's watchdog will restart it within seconds.
Type=notify
WatchdogSec=10
WorkingDirectory=/home/a80838986/sis-portal
# If you use rbenv:
ExecStart=/bin/bash -lc 'exec /home/a80838986/.rbenv/shims/bundle exec sidekiq -e validation -C /home/a80838986/sis-portal/config/sidekiq.yml'
# Use `systemctl kill -s TSTP sidekiq` to quiet the Sidekiq process
# !!! Change this to your deploy user account !!!
User=a80838986
Group=linuxusers
UMask=0002
# Greatly reduce Ruby memory fragmentation and heap usage
Environment=MALLOC_ARENA_MAX=2
# if we crash, restart
RestartSec=1
Restart=on-failure
# output goes to /var/log/syslog (Ubuntu) or /var/log/messages (CentOS)
StandardOutput=syslog
StandardError=syslog
# This will default to "bundler" if we don't specify it
SyslogIdentifier=sidekiq
[Install]
WantedBy=multi-user.target
But this way, Sidekiq issues an error:
LOGIN[117401]: ORIGINUSER= PPID=1
sidekiq[117376]: bundler: command not found: sis-portal/sidekiq
sidekiq[117376]: Install missing gem executables with `bundle install`
systemd[1]: sidekiq.service: Main process exited, code=exited, status=127
Never the less, ExecStart's statement executes correctly when ran from the application folder /home/a80838986/sis-portal
.
How to configure this service so that Sidekiq actually works?
As suspected, the ExecStat statement did not find the path to bundle. I updated it giving the path with the -r option:
ExecStart=/bin/bash -lc 'exec /home/a80838986/.rbenv/shims/bundle exec sidekiq
-e validation
-C /home/a80838986/sis-portal/config/sidekiq.yml
-r /home/a80838986/sis-portal'
Sidekiq is now up and running, showing a green Active status on the console.