Я возился с FreeRADIUS
и MySQL (MariaDB)
и кажется, что служба FreeRADIUS не запускается должным образом при запуске. Но начинает нормально использовать root
пользователем или в режиме отладки (radiusd -X
) и отлично работает! В режиме отладки ошибок нет.
systemctl
показывает, что служба radiusd.service не запустилась.
/ var / log / вывод сообщений:
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
Спасибо, dawud
, ты подтолкнул меня в правильном направлении. Что мне здесь нужно было сделать, так это сделать radiusd.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 запустился нормально.
Также этот ресурс мне немного помогло.
Вы настроили FreeRADIUS для подключения к локальному серверу MySQL, но этот сервер не работает. Запустите сервер и попробуйте еще раз.