PHP Apache shutdown unexpectedly启动错误解释及解决的方法

时间:2023-03-09 02:10:55
PHP Apache shutdown unexpectedly启动错误解释及解决的方法

在学PHP的时候,偶然发现XAMPP窗体Apache的启动出现错误,出现下面的错误提示:

9:52:41  [Apache] Attempting to start Apache app...

9:52:41  [Apache] Status change detected: running

9:52:42  [Apache] Status change detected: stopped

9:52:42  [Apache] Error: Apache shutdown unexpectedly.

9:52:42  [Apache] This may be due to a blocked port, missing dependencies, 

9:52:42  [Apache] improper privileges, a crash, or a shutdown by another method.

9:52:42  [Apache] Check the "/xampp/apache/logs/error.log" file

9:52:42  [Apache] and the Windows Event Viewer for more clues

PHP Apache shutdown unexpectedly启动错误解释及解决的方法
这个问题比較常见, 一般是80、443port被占用



cmd 通过执行apache/bin/httpd.exe 打印例如以下log: 
通过执行cmd ,输入命令行 netstat -a 查看全部的被占用的port;例如以下图:


PHP Apache shutdown unexpectedly启动错误解释及解决的方法
如图可知, 443的port被占用了,导致Apache 无法正常启动;

解决的方法例如以下:


(OS 10048)通常每一个套接字地址(协议/网络地址/port)仅仅同意使用一次。 : make_sock: could not bind to address 0.0.0.0:443


或者后面是80port被占用



(OS 10048)通常每一个套接字地址(协议/网络地址/port)仅仅同意使用一次。

: make_sock: could not bind to address 0.0.0.0:80 或[ : : ]:80




一、最快的处理方法就是改动port号:



1、443port被占用。apache无法监听443port,该怎样解决呢?



在/xampp/apache/conf/extra/httpd-ssl.conf



把Listen 443 改动为 444(可自己定义)





2、80port被占用,apache无法监听80port。该怎样解决呢?



在/xampp/apache/conf/extra/httpd.conf



把Listen 80 改动为 88 (可自己定义)



假设配置了vhosts的话请把httpd-vhosts.conf 中port改为88(同上port号)





二、最直接的方法是关闭占用80、443port的进程:

1. 通过cmd中netstat -ano 看看本机80、 443port被占用没 ----- --这里 可能会被其它程序占用如iis、虚拟机等

2.通过cmd中打印tasklist,查找占用80、443port的进程名称。

3.taskkill /pid port号 杀掉此进程名称。XAMPP重新启动apache就可以。



综上所述第一种方法推荐使用,另外一种每次启动都或多或少的再次遇到。