FreeRADIUS
とMySQL (MariaDB)
をいじってみましたが、起動時にFreeRADIUSサービスが正しく開始できないようです。しかし、root
ユーザーまたはデバッグモード(radiusd -X
)を使用すると正常に開始され、正常に動作します。デバッグモードではエラーは表示されません。
systemctl
コマンドは、radiusd.serviceの開始に失敗したことを示しています。
/ 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出力:
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
おそらく問題は、プロセスの起動順序または何らかの遅延にあります。 FreeRADIUSのSQLモジュールがまだ起動していないMariaDBに接続できないのではないでしょうか?もしそうなら、どうすればこれを修正できますか?
以前のバージョンのRHEL/CENTOSでは、rc.dなどのサービスの開始順序を簡単に確認できます。現在はIDKです。 Centos 7が導入したこの「systemd」、「systemctl」、「firewalld」のようなものは初めてなので、少し混乱しています。また、この新しいFreeRADIUS 3
構造...
PS。起動時にMariaDBが有効になり、FR DB構成の資格情報が正しい
少し更新:
cat /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
の後に開始することです。
/etc/systemd/system/multi-user.target.wants/radiusd.service
でvim
を起動し、[Unit]
セクションに行を追加しました。
After=mariadb.service
したがって、次のようになります。
[Unit]
Description=FreeRADIUS high performance RADIUS server.
After=syslog.target network.target
After=mariadb.service
再起動後、FreeRADIUSは問題なく起動しました。
また、 このリソース は少し役立ちました。
ローカルのMySQLサーバーに接続するようにFreeRADIUSを設定しましたが、そのサーバーが実行されていません。サーバーを始動して、再試行してください。