Ale*_*lex 6 startup freeradius mariadb centos7
我是瞎搞与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.
Run Code Online (Sandbox Code Playgroud)
/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"
Run Code Online (Sandbox Code Playgroud)
看到这个后,我试图复制问题,杀死mariadb.service
并再次开始运行调试模式。它会吐出与radius.log
.
我尝试禁用iptables
和firewalld
重新启动,但没有运气:
systemctl disable iptables
systemctl disable firewalld
Run Code Online (Sandbox Code Playgroud)
因此,问题可能出在流程启动顺序或某种延迟上。也许 FreeRADIUS 的 SQL 模块无法连接到尚未启动的 MariaDB?如果是,我该如何解决这个问题?
在 RHEL/CENTOS 的早期版本中,我知道您很容易在 rc.d 或其他内容中看到服务启动顺序,现在是 IDK。我是 Centos 7 引入的这种花哨的“systemd”、“systemctl”、“firewalld”东西的新手,抱歉我有点困惑。还有这个新FreeRADIUS 3
结构...
附注。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
Run Code Online (Sandbox Code Playgroud)
Ale*_*lex 10
谢谢你,dawud
你把我推向了正确的方向。我在这里必须做的是 make radiusd.service
start AFTER mariadb.service
。
我解雇了vim
,在/etc/systemd/system/multi-user.target.wants/radiusd.service
和添加了一行[Unit]
部分:
After=mariadb.service
Run Code Online (Sandbox Code Playgroud)
所以它看起来像这样:
[Unit]
Description=FreeRADIUS high performance RADIUS server.
After=syslog.target network.target
After=mariadb.service
Run Code Online (Sandbox Code Playgroud)
重新启动后,FreeRADIUS 启动正常。
同时此资源帮我一点点。
归档时间: |
|
查看次数: |
25182 次 |
最近记录: |