AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 623054
Accepted
Alex
Alex
Asked: 2014-08-22 05:18:54 +0800 CST2014-08-22 05:18:54 +0800 CST 2014-08-22 05:18:54 +0800 CST

Centos 7. 由于优先级,Freeradius 无法在启动时启动

  • 772

我在搞乱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

因此,问题可能出在进程启动顺序或某种延迟上。也许 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
startup
  • 2 2 个回答
  • 27131 Views

2 个回答

  • Voted
  1. Best Answer
    Alex
    2014-08-23T00:53:06+08:002014-08-23T00:53:06+08:00

    谢谢你,dawud你把我推向了正确的方向。我必须在这里做的是 make radiusd.servicestart AFTER 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 启动正常。

    这个资源也帮助了我一点。

    • 10
  2. Michael Hampton
    2014-08-22T05:21:30+08:002014-08-22T05:21:30+08:00

    您将 FreeRADIUS 设置为连接到本地 MySQL 服务器,但该服务器未运行。启动服务器并重试。

    • 2

相关问题

  • 通过远程桌面登录 Windows Vista 时阻止某些启动程序运行

  • Jetty 7 给出 HTTP 错误:503 - 服务不可用

  • 如何禁用 OSX 启动声​​音?[关闭]

  • Windows XP 挂在登录屏幕上

  • 单人 ISV,您推荐哪种类型的服务器硬件?[关闭]

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve