Centos 7. Freeradius не удается запуститься на начальной загрузке из-за приоритета

Я бездельничал с FreeRADIUS и MySQL (MariaDB) и кажется, что услуги FreeRADIUS не могут запуститься правильно на запуске. Но это запускает прекрасное использование root пользователь или в режиме отладки (radiusd -X) и работает просто великолепно! Режим отладки не показывает ошибок.

systemctl управляйте показывает, что radiusd.service не удалось запуститься.

/var/log/messages вывод:

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 производит:

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"

После наблюдения этого я пытался копировать проблему, уничтоженную mariadb.service и начал выполнять режим отладки снова. И это выкладывает ту же проблему как в radius.log.

Я пытался отключить iptables и firewalld и перезагрузка, но никакая удача:

systemctl disable iptables
systemctl disable firewalld

Таким образом, возможно, проблема находится в порядке запуска процесса или задержке некоторого вида. Возможно, модуль SQL FreeRADIUS не может соединиться с еще запущенным MariaDB? Если это, как я могу зафиксировать это?

В более ранних версиях RHEL/CENTOS я знаю, что Вы легко видите, что сервис запускает порядок в подобном rc.d или материале, теперь IDK. Я плохо знаком с этим воображением "systemd", "systemctl", "firewalld" Centos 7 материала представил очень жаль, я немного смущен. Также это новое FreeRADIUS 3 структура...

PS. MariaDB включают на запуске, учетных данных в FR, конфигурация DB корректна


Немного обновления:

кошка/etc/systemd/system/multi-user.target.wants/radiusd.service произвела:

[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
6
задан 25 August 2014 в 09:48
2 ответа

Спасибо, Дауд , ты толкнул меня в правильном направлении. Что я должен был здесь сделать, так это заставить радиусd.service начать ПОСЛЕ mariadb.service.

Я запустил vim на /etc/systemd/system/multi-user. target.wants/radiusd.service и добавил строку в раздел [Unit]:

After=mariadb.service

Так что выглядит так:

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

После перезагрузки FreeRADIUS начал работу просто отлично. Также

этот ресурс немного помог мне.

9
ответ дан 3 December 2019 в 00:12

Вы настраиваете FreeRADIUS на подключение к локальному серверу MySQL, но этот сервер не работает. Запустите сервер и повторите попытку.

2
ответ дан 3 December 2019 в 00:12

Теги

Похожие вопросы