我们最近获得了一个备份服务器,以便在主服务器发生故障时将所有数据镜像到该服务器上。
我已经通过 rsync 更新了所有站点数据,并更新了所有 apache 配置和数据库。两台机器都使用 Ubuntu 9(主机器使用 9.04,备份机器使用 9.10)。
因此,目前看来,一切似乎都已同步(仍然需要弄清楚用户同步),然后我尝试启动 Apache。我得到了
* Starting web server apache2 [fail]
没有其他迹象表明问题可能出在哪里。
我知道我没有足够的信息来期望你们能给出解决方案,所以我只想知道我可以从哪里进一步调查这个问题。 会不会有错误日志?
谢谢!
答案1
在某些特定情况下,日志条目将不会写入磁盘 - 例如,如果日志不存在,或者 Apache 由于权限问题等而无法写入日志文件,就会发生这种情况。在这种情况下,诊断错误的最佳方法是使用“strace”:
[root@server ~]# strace -Ff apachectl start
虽然输出会非常详细,但如果 Apache 由于某种原因无法启动,您将在末尾看到一个 write(),其中包含以下内容会在日志中输入失败的原因(如果没有在错误日志中记录原因,则错误消息包含“无法打开日志”和日志路径时请不要感到惊讶;)。
尽管看了您关于 mod_fcgid 的评论,我还是建议查看 Apache 配置并检查对 mod_fcgid 的引用——听起来它正在尝试打开文字“mod_fcgid”文件,而不是加载模块。
答案2
httpd -t
将测试您的配置文件的语法并将任何错误输出到终端。
答案3
我在 Mac OS 上调试 Apache 服务器时遇到了类似的问题,因此决定分享我的经验并节省其他人的时间,我发现以下内容非常有用:
- 定位日志:
apachectl -S | grep log
- 在输出中你会发现一些日志文件,你可以开始查找错误示例:
tail -n 15 /var/log/apache2/ssl_engine.log
如果有多个日志文件,请继续跟踪它们,直到找到导致 Apache 无法启动的错误
答案4
端口 80 上正在运行其他程序并阻止进入或端口被锁定。我在 Windows 11 上的 IIS 管理器中运行了 FTP 服务器,该服务器阻止了 Apache。在浏览器中运行“localhost”,看看是否出现错误,否则干扰服务应该会弹出并提供更多信息。
- 还可以通过搜索“打开或关闭 Windows 功能”来关闭 Internet 信息服务。Windows 功能>Internet 信息服务>取消选中复选框>加载后重新启动 PC。