Apache incapaz de iniciar quando SSLEngine está ativado

Apache incapaz de iniciar quando SSLEngine está ativado

Meu host virtual SSL é tão simples quanto isso:

LoadModule ssl_module modules/mod_ssl.so

Listen 443
<VirtualHost *:443>
        DocumentRoot "/srv/www/test"
        ServerName <my_website_domain>

        SSLEngine on
        SSLCertificateFile    /etc/ssl/certs/apache-selfsigned.crt
        SSLCertificateKeyFile /etc/ssl/private/apache-selfsigned.key
</VirtualHost>

Quando tento reiniciar o apache, apache2ctl configtest && systemctl restart apache2recebo:

Sintaxe OK
A tarefa para apache2.service falhou porque o processo de controle foi encerrado com código de erro. Consulte "systemctl status apache2.service" e "journalctl -xe" para obter detalhes.

Mas quando desligo o SSLEngine com SSLEngine offo apache inicia normalmente e ok.

Quando corro systemctl status apache2depois de começar com SSLEngine on, recebo:

Syntax OK
● apache2.service - The Apache Webserver
   Loaded: loaded (/usr/lib/systemd/system/apache2.service; enabled; vendor preset: disabled)
   Active: failed (Result: exit-code) since Fri 2020-08-14 18:06:55 CEST; 1min 9s ago
  Process: 22352 ExecStop=/usr/sbin/start_apache2 -DSYSTEMD -DFOREGROUND -k graceful-stop (code=exited, status=0/SUCCESS)
  Process: 19851 ExecReload=/usr/sbin/start_apache2 -DSYSTEMD -DFOREGROUND -k graceful (code=exited, status=0/SUCCESS)
  Process: 22346 ExecStart=/usr/sbin/start_apache2 -DSYSTEMD -DFOREGROUND -k start (code=exited, status=1/FAILURE)
 Main PID: 22346 (code=exited, status=1/FAILURE)

Aug 14 18:06:55 luu056d start_apache2[22352]: [Fri Aug 14 18:06:55.351148 2020] [so:warn] [pid 22352] AH01574: module authn_core_module is already loaded, skipping
Aug 14 18:06:55 luu056d start_apache2[22352]: [Fri Aug 14 18:06:55.351163 2020] [so:warn] [pid 22352] AH01574: module authz_core_module is already loaded, skipping
Aug 14 18:06:55 luu056d start_apache2[22352]: [Fri Aug 14 18:06:55.351170 2020] [so:warn] [pid 22352] AH01574: module php5_module is already loaded, skipping
Aug 14 18:06:55 luu056d start_apache2[22352]: [Fri Aug 14 18:06:55.351179 2020] [so:warn] [pid 22352] AH01574: module ssl_module is already loaded, skipping
Aug 14 18:06:55 luu056d start_apache2[22352]: [Fri Aug 14 18:06:55.352998 2020] [so:warn] [pid 22352] AH01574: module ssl_module is already loaded, skipping
Aug 14 18:06:55 luu056d start_apache2[22352]: [Fri Aug 14 18:06:55.356261 2020] [core:warn] [pid 22352] AH00117: Ignoring deprecated use of DefaultType in line 143 of /etc/apa.../httpd.conf.
Aug 14 18:06:55 luu056d start_apache2[22352]: httpd (no pid file) not running
Aug 14 18:06:55 luu056d systemd[1]: Failed to start The Apache Webserver.
Aug 14 18:06:55 luu056d systemd[1]: apache2.service: Unit entered failed state.
Aug 14 18:06:55 luu056d systemd[1]: apache2.service: Failed with result 'exit-code'.
Hint: Some lines were ellipsized, use -l to show in full.

Por que estou recebendo esse erro httpd (no pid file) not runningquando ligo SSLEngine?
Nada está bloqueando a porta 443, pois quando executo lsof -i :443o resultado fica vazio.

Estou usando Apache/2.4.23 para Linux/SUSE

Responder1

Isso é indicativo de um problema com os certificados, o httpd não consegue carregá-los e, portanto, não consegue inicializar corretamente. Geralmente, esses erros não aparecem, a menos que você tenha um alto nível de registro de erros para SSL. Basta configurá-lo LogLevel ssl:trace8para teste e removê-lo quando começar a funcionar.

Certifique-se de que os certificados estejam no formato PEM (ASCII), que correspondam entre si e existam no caminho que você aponta para eles:

openssl x509 -in /etc/ssl/certs/apache-selfsigned.crt -noout -modulus
openssl rsa -in /etc/ssl/private/apache-selfsigned.key -noout -modulus

A saída de ambos os comandos deve retornar o mesmo resultado; caso contrário, eles não estão corretos.

Responder2

Gostaria de agradecer a todas as outras pessoas que responderam, mas o problema residia no arquivo ssl-globals.conf.

Essas duas diretivas estavam travando o apache

SSLUseStapling on
SSLStaplingCache "shmcb:logs/stapling-cache(150000)"

Acabei de comentá-los e agora está funcionando. Não tenho ideia do porquê, mas a Ciência se baseia em evidências.

informação relacionada