Come riavviare il servizio nginx di Discourse all'interno del contenitore Docker?

Qual è il modo corretto per riavviare nginx all’interno del container Docker di Discourse?

Il container Docker sembra eseguire Debian 10, ma il solito approccio systemd per riavviare nginx fallisce

[root@osestaging1 discourse]# ./launcher enter discourse_ose
root@osestaging1-discourse-ose:/var/www/discourse# cat /etc/issue
Debian GNU/Linux 10 \n \l

root@osestaging1-discourse-ose:/var/www/discourse# systemctl restart nginx
System has not been booted with systemd as init system (PID 1). Can't operate.
Failed to connect to bus: Host is down
root@osestaging1-discourse-ose:/var/www/discourse# 

Sembra esserci uno script init.d, ma l’esecuzione fallisce. I log indicano che il problema è dovuto all’impossibilità di associarsi a un indirizzo già in uso.

root@osestaging1-discourse-ose:/etc/nginx/conf.d# /etc/init.d/nginx restart
[FAIL] Restarting nginx: nginx failed!
root@osestaging1-discourse-ose:/etc/nginx/conf.d# tail /var/log/nginx/error.log
2019/11/12 10:32:45 [emerg] 1123#1123: bind() to unix:/shared/nginx.http.sock failed (98: Address already in use)
2019/11/12 10:32:45 [emerg] 1123#1123: bind() to unix:/shared/nginx.http.sock failed (98: Address already in use)
2019/11/12 10:32:45 [emerg] 1123#1123: bind() to unix:/shared/nginx.http.sock failed (98: Address already in use)
2019/11/12 10:32:45 [emerg] 1123#1123: bind() to unix:/shared/nginx.http.sock failed (98: Address already in use)
2019/11/12 10:32:45 [emerg] 1123#1123: bind() to unix:/shared/nginx.http.sock failed (98: Address already in use)
2019/11/12 10:32:45 [emerg] 1123#1123: still could not bind()
2019/11/12 10:32:47 [emerg] 1127#1127: bind() to unix:/shared/nginx.http.sock failed (98: Address already in use)
2019/11/12 10:32:47 [emerg] 1127#1127: bind() to unix:/shared/nginx.http.sock failed (98: Address already in use)
2019/11/12 10:32:47 [emerg] 1127#1127: bind() to unix:/shared/nginx.http.sock failed (98: Address already in use)
2019/11/12 10:32:47 [emerg] 1127#1127: bind() to unix:/shared/nginx.http.sock failed (98: Address already in use)

Infatti, nginx è già in esecuzione

root@osestaging1-discourse-ose:/etc/nginx/conf.d# ps -ef | grep -i nginx
root        46    40  0 10:19 ?        00:00:00 runsv nginx
root      1174    46  1 10:33 ?        00:00:00 /usr/sbin/nginx
root      1177   108  0 10:33 pts/1    00:00:00 grep -i nginx
root@osestaging1-discourse-ose:/etc/nginx/conf.d# 

Qual è il modo corretto per terminare il processo nginx sopra indicato e riavviarlo?

Il modo corretto per riavviare nginx all’interno del contenitore Docker di Discourse è utilizzare il comando sv, che fa parte del supervisore dei servizi runit.

root@osestaging1-discourse-ose:/var/www/discourse# sv stop nginx
ok: down: nginx: 1s, normally up
root@osestaging1-discourse-ose:/var/www/discourse# sv start nginx
ok: run: nginx: (pid 269) 0s
root@osestaging1-discourse-ose:/var/www/discourse# 

Quindi sembra che Ruby on Rails utilizzi runit

Ho trovato il comando sv poiché è citato nel file templates/web.template.yml

Quasi… Ruby on Rails è agnostico riguardo a cosa si possa utilizzare. Potrebbe essere systemd, un diretto pid 1 in Docker o una miriade di altri strumenti.

Abbiamo scelto di utilizzare runit nella nostra immagine Docker ufficiale perché è leggero e molto semplice da comprendere. È uno strumento che funziona semplicemente.