Centos 7. Freeradius falha ao inicializar devido a prioridade

4

Eu estava brincando com FreeRADIUS e MySQL (MariaDB) e parece que o serviço FreeRADIUS não pode ser iniciado corretamente na inicialização. Mas ele começa bem usando root user ou no modo de depuração ( radiusd -X ) e funciona muito bem! O modo de depuração não mostra erros.

O comando

systemctl mostra que o radiusd.service falhou ao iniciar.

/ var / log / messages output:

Aug 21 15:52:29 nexus-test systemd: Starting The Apache HTTP Server...
Aug 21 15:52:29 nexus-test systemd: Starting MariaDB database server...
Aug 21 15:52:29 nexus-test systemd: Starting FreeRADIUS high performance RADIUS server....
Aug 21 15:52:29 nexus-test systemd: Started OpenSSH server daemon.
Aug 21 15:52:29 nexus-test mysqld_safe: 140821 15:52:29 mysqld_safe Logging to '/var/log/mariadb/mariadb.log'.
Aug 21 15:52:29 nexus-test mysqld_safe: 140821 15:52:29 mysqld_safe Starting mysqld daemon with databases from /var/lib/mysql
Aug 21 15:52:30 nexus-test systemd: Started Postfix Mail Transport Agent.
Aug 21 15:52:30 nexus-test avahi-daemon[604]: Registering new address record for fe80::250:56ff:fe85:e4af on eth0.*.
Aug 21 15:52:30 nexus-test systemd: radiusd.service: control process exited, code=exited status=1
Aug 21 15:52:30 nexus-test systemd: Failed to start FreeRADIUS high performance RADIUS server..
Aug 21 15:52:30 nexus-test systemd: Unit radiusd.service entered failed state.
Aug 21 15:52:31 nexus-test kdumpctl: kexec: loaded kdump kernel
Aug 21 15:52:31 nexus-test kdumpctl: Starting kdump: [OK]
Aug 21 15:52:31 nexus-test systemd: Started Crash recovery kernel arming.
Aug 21 15:52:31 nexus-test systemd: Started The Apache HTTP Server.
Aug 21 15:52:31 nexus-test systemd: Started MariaDB database server.

/var/log/radius/radius.log output:

Thu Aug 21 15:24:16 2014 : Info: rlm_sql (sql): Driver rlm_sql_mysql (module rlm_sql_mysql) loaded and linked
Thu Aug 21 15:24:16 2014 : Info: rlm_sql (sql): Attempting to connect to database "radius"
Thu Aug 21 15:24:16 2014 : Info: rlm_sql (sql): Opening additional connection (0)
Thu Aug 21 15:24:16 2014 : Error: rlm_sql_mysql: Couldn't connect socket to MySQL server radius@localhost:radius
Thu Aug 21 15:24:16 2014 : Error: rlm_sql_mysql: Mysql error 'Can't connect to local MySQL server through socket '/var/lib/mysql/mysql.sock' (2)'
Thu Aug 21 15:24:16 2014 : Error: rlm_sql (sql): Opening connection failed (0)
Thu Aug 21 15:24:16 2014 : Error: /etc/raddb/mods-enabled/sql[47]: Instantiation failed for module "sql"

Depois de ver isso, tentei replicar o problema, matei mariadb.service e comecei a executar o modo de depuração novamente. E isso cospe o mesmo problema que no radius.log .

Eu tentei desativar iptables e firewalld e reinicializar, mas sem sorte:

systemctl disable iptables
systemctl disable firewalld

Então, talvez o problema esteja na ordem de inicialização do processo ou no atraso de algum tipo. Talvez o módulo SQL do FreeRADIUS não possa se conectar ao ainda não iniciado o MariaDB? Se for, como posso consertar isso?

Em versões anteriores do RHEL / CENTOS eu sei que você vê facilmente a ordem de início do serviço como rc.d ou outras coisas, agora IDK. Eu sou novo para este fantasia "systemd", "systemctl", "firewalld" coisas Centos 7 introduzido tão desculpe estou um pouco confuso. Também esta nova estrutura FreeRADIUS 3 ...

PS. O MariaDB está ativado na inicialização, as credenciais na configuração do FR DB estão corretas

Uma pequena atualização:

cat /etc/systemd/system/multi-user.target.wants/radiusd.service output:

[Unit]
Description=FreeRADIUS high performance RADIUS server.
After=syslog.target network.target

[Service]
Type=forking
PIDFile=/var/run/radiusd/radiusd.pid
ExecStartPre=-/bin/chown -R radiusd.radiusd /var/run/radiusd
ExecStartPre=/usr/sbin/radiusd -C
ExecStart=/usr/sbin/radiusd -d /etc/raddb
ExecReload=/usr/sbin/radiusd -C
ExecReload=/bin/kill -HUP $MAINPID

[Install]
WantedBy=multi-user.target
    
por Alex 21.08.2014 / 15:18

2 respostas

7

Obrigado, dawud , você me empurrou na direção certa. O que eu tive que fazer aqui é tornar radiusd.service start AFTER mariadb.service .

Eu ativei vim at /etc/systemd/system/multi-user.target.wants/radiusd.service e adicionei uma linha na seção [Unit] :

After=mariadb.service

Então parece com isso:

[Unit]
Description=FreeRADIUS high performance RADIUS server.
After=syslog.target network.target
After=mariadb.service

Após a reinicialização, o FreeRADIUS começou bem.

Também este recurso me ajudou um pouco.

    
por 22.08.2014 / 10:53
2

Você configura o FreeRADIUS para conectar-se a um servidor MySQL local, mas esse servidor não está em execução. Inicie o servidor e tente novamente.

    
por 21.08.2014 / 15:21