HAProxy funciona bem executado manualmente, mas como um serviço Systemd não consegue carregar o arquivo pem SSL

4

Estou tentando configurar o SSL em um servidor Fedora 22 executando o HAProxy. Aqui está a configuração ( /etc/haproxy/haproxy.cfg ):

global
    log         127.0.0.1 local2
    chroot      /var/lib/haproxy
    pidfile     /var/run/haproxy.pid
    maxconn     4000
    user        haproxy
    group       haproxy
    daemon
    tune.ssl.default-dh-param 2048

defaults
    log     global
    mode    http
    option  httplog
    option  dontlognull
    option  http-server-close
    option  forwardfor
    option  redispatch
    retries 3
    timeout http-request    10s
    timeout queue           1m
    timeout connect         10s
    timeout client          1m
    timeout server          1m
    timeout http-keep-alive 10s
    timeout check           10s

frontend main
    bind *:80
    bind *:443 ssl crt /etc/haproxy/certificate.pem
    redirect scheme https if !{ ssl_fc }
    default_backend app

backend app
    balance roundrobin
    server app1 127.0.0.1:8000 check

Agora, quando executo systemctl restart haproxy && journalctl -u haproxy.service -f , recebo este erro:

Sep 13 15:39:31 fedora-server systemd[1]: Started HAProxy Load Balancer.
Sep 13 15:39:31 fedora-server systemd[1]: Starting HAProxy Load Balancer...
Sep 13 15:39:31 fedora-server haproxy-systemd-wrapper[15620]: haproxy-systemd-wrapper: executing /usr/sbin/haproxy -f /etc/haproxy/haproxy.cfg -p /run/haproxy.pid -Ds
Sep 13 15:39:31 fedora-server haproxy-systemd-wrapper[15620]: [ALERT] 255/153931 (15621) : parsing [/etc/haproxy/haproxy.cfg:30] : 'bind *:443' : unable to load SSL private key from PEM file '/etc/haproxy/certificate.pem'.
Sep 13 15:39:31 fedora-server haproxy-systemd-wrapper[15620]: [ALERT] 255/153931 (15621) : Error(s) found in configuration file : /etc/haproxy/haproxy.cfg
Sep 13 15:39:31 fedora-server haproxy-systemd-wrapper[15620]: [ALERT] 255/153931 (15621) : Proxy 'main': no SSL certificate specified for bind '*:443' at [/etc/haproxy/haproxy.cfg:30] (use 'crt').
Sep 13 15:39:31 fedora-server haproxy-systemd-wrapper[15620]: [ALERT] 255/153931 (15621) : Fatal errors found in configuration.
Sep 13 15:39:31 fedora-server haproxy-systemd-wrapper[15620]: haproxy-systemd-wrapper: exit, haproxy RC=256

Aqui está a configuração do serviço:

# cat /usr/lib/systemd/system/haproxy.service
[Unit]
Description=HAProxy Load Balancer
After=syslog.target network.target

[Service]
EnvironmentFile=/etc/sysconfig/haproxy
ExecStart=/usr/sbin/haproxy-systemd-wrapper -f /etc/haproxy/haproxy.cfg -p /run/haproxy.pid $OPTIONS
ExecReload=/bin/kill -USR2 $MAINPID

[Install]
WantedBy=multi-user.target

No entanto, posso copiar o comando que o serviço tenta executar e funciona bem.

Primeiro, isso funciona quando eu o executo manualmente (tirado da configuração do serviço):

# whoami
root
# /usr/sbin/haproxy-systemd-wrapper -f /etc/haproxy/haproxy.cfg -p /run/haproxy.pid

Isso também funciona (obtido dos logs de serviço, aparentemente haproxy-systemd-wrapper executa isso:

# whoami
root
# /usr/sbin/haproxy -f /etc/haproxy/haproxy.cfg -p /run/haproxy.pid -Ds

Para esclarecer: quando eu executo um desses comandos manualmente como root, eles funcionam e eu posso acessar meu site via SSL.

Então, estou assumindo que, quando executado como um serviço, o HAProxy não consegue ler o certificado.

Veja o que tentei até agora:

  • chown haproxy:haproxy /etc/haproxy/certificate.pem
  • Como alternar usuário e grupo para root em haproxy.cfg
  • Adicionando User=root e Group=root à configuração do serviço em [Service]
  • sudo -u haproxy /usr/sbin/haproxy -f /etc/haproxy/haproxy.cfg -p /run/haproxy.pid -Ds dá um erro diferente (em relação às portas), então o mais provável é que o usuário haproxy não seja usado pelo serviço, caso contrário, ele iria ficar ainda mais

Eu posso acessar o arquivo como usuário haproxy, sudo -u haproxy cat /etc/haproxy/certificate.pem .

Editar:

Aqui está a configuração do serviço atualizada com base na sua resposta:

[Unit]
Description=HAProxy Load Balancer
After=syslog.target network.target
SELinuxContext=unconfined_u:object_r:var_t:s0

O que acontece agora:

Sep 13 17:51:21 ServiceName systemd[1]: Starting HAProxy Load Balancer...
Sep 13 17:51:21 ServiceName systemd[1]: haproxy.service: main process exited, code=exited, status=203/EXEC
Sep 13 17:51:21 ServiceName systemd[1]: Unit haproxy.service entered failed state.
Sep 13 17:51:21 ServiceName systemd[1]: haproxy.service failed.

Como obtive o valor para SELinuxContext :

# ls -lZ /etc/haproxy/certificate.pem
-rw-r--r--. 1 root root unconfined_u:object_r:var_t:s0 9245 Sep 13 17:43 /etc/haproxy/certificate.pem
    
por Martti Laine 13.09.2015 / 17:54

1 resposta

2

Você está no Fedora, que usa o SELinux . Os serviços do Systemd são executados em um ambiente limpo - eles não são gerados diretamente pelo systemctl - então, entre outras coisas, eles iniciam em um contexto diferente do SELinux (acho que o padrão é system_u:system_r:init_t:s0 ?).

Verifique se o contexto correto do SELinux está definido, tanto para o arquivo de certificado (usando ls -lZ e chcon ) quanto para o processo haproxy (possivelmente usando SELinuxContext= na unidade systemd).

Tente executar id para ver o contexto atual do seu (ou do serviço).

    
por 13.09.2015 / 19:15