Não é possível iniciar o nginx: “code = exited, status = 1 / FAILURE”

1

Acabei de instalar o nginx no Debian Jessie e não consigo iniciá-lo:

$ sudo /etc/init.d/nginx start
[....] Starting nginx (via systemctl): nginx.serviceJob for nginx.service failed. See 'systemctl status nginx.service' and 'journalctl -xn' for details.
 failed!

$ systemctl status nginx.service
● nginx.service - A high performance web server and a reverse proxy server
   Loaded: loaded (/lib/systemd/system/nginx.service; enabled)
   Active: failed (Result: exit-code) since Sat 2015-08-29 17:54:15 EDT; 6s ago
  Process: 16824 ExecStop=/sbin/start-stop-daemon --quiet --stop --retry QUIT/5 --pidfile /run/nginx.pid (code=exited, status=0/SUCCESS)
  Process: 8407 ExecStartPre=/usr/sbin/nginx -t -q -g daemon on; master_process on; (code=exited, status=1/FAILURE)
 Main PID: 691 (code=exited, status=0/SUCCESS)

Eu corri netstat -a -b e examinei a lista, mas não consigo ver nada mais em execução na porta 80.

Como posso depurar isso?

UPDATE: tentou sudo nginx -t para ver se produziu alguma coisa útil:

$ sudo nginx -t
nginx: [emerg] BIO_new_file("/etc/nginx/certificates/certificate-178724.crt") failed (SSL: error:02001002:system library:fopen:No such file or directory:fopen('/etc/nginx/certificates/certificate-123353.crt','r') error:2006D080:BIO routines:BIO_new_file:no such file)
nginx: configuration file /etc/nginx/nginx.conf test failed
    
por Richard 30.08.2015 / 00:07

1 resposta

0

A saída de nginx -t informa tudo o que você precisa saber - não foi possível ler um arquivo de certificado em sua configuração referenciada. Grep em torno de /etc/nginx para menções desse arquivo, e você teria encontrado o arquivo que foi referenciado.

Curiosamente, nos dias escuros e terríveis antes do systemd, o script init do nginx teria lhe dado esse erro. Giz outra vitória de usabilidade para a nova ordem mundial!

    
por 30.08.2015 / 00:21

Tags