最新下载
热门教程
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
XAMPP常见问题汇总:新手入门最容易踩的十个服务无法启动坑
时间:2026-06-19 08:20:57 编辑:袖梨 来源:一聚教程网
MySQL启动后立刻变灰且日志提示“blocked port, missing dependencies”,本质是3306端口被Skype、Docker Desktop或旧MySQL服务等占用;应优先用管理员CMD执行netstat -ano | findstr :3306查PID,再tasklist确认进程名,避免误杀svchost.exe等系统进程,确为无关程序后taskkill /f /pid结束,或修改my.ini中[mysqld]段port=3307并同步更新phpMyAdmin、php.ini及应用配置。
MySQL 启动后立刻变灰,日志里反复出现 “blocked port, missing dependencies”
这基本就是 3306 端口被占了,不是配置错、不是文件损坏,就是端口冲突。Windows 上 Skype、Docker Desktop、旧版 MySQL 服务、甚至某些国产软件的后台模块,都爱抢这个端口。
别靠任务管理器猜,进管理员 CMD 执行:netstat -ano | findstr :3306。如果返回带 PID 的行,再用 tasklist | findstr "12345"(把 12345 换成实际 PID)确认进程名。看到 svchost.exe 别急着 kill——它可能是系统更新或网络服务,强行结束会导致其他功能异常。
- 确认是无关程序后,再执行
taskkill /f /pid 12345 - 如果是另一个 MySQL 实例(比如服务名是
MySQL80),进services.msc停止它,并把启动类型改为“手动” - 如果是 Docker 容器,先运行
docker ps,再用docker stop $(docker ps -q --filter ancestor=mysql)
改了 my.ini 的 port=3307,但 phpMyAdmin 还是连不上
只改 MySQL 配置文件里的端口,等于只换了一扇门,没告诉其他人新门在哪。phpMyAdmin、PHP 应用、甚至 PHP 自身的默认连接逻辑,全还盯着 3306。
必须同步三处:
-
xamppphpMyAdminconfig.inc.php中找到$cfg['Servers'][$i]['port'],改成'3307' -
xamppphpphp.ini里检查mysqli.default_port和pdo_mysql.default_socket——前者要设为3307,后者可留空或删掉(Windows 下 socket 不生效) - 你自己写的 PHP 项目(如 Laravel 的
.env、WordPress 的wp-config.php)里所有DB_HOST或数据库连接字符串,都要显式加上:3307,例如127.0.0.1:3307
Apache 显示 running,但 http://localhost/phpmyadmin 报 ERR_CONNECTION_REFUSED
控制面板显示 Apache 在跑,不代表它真在监听 80 端口。XAMPP 检测到 80 被占,会自动 fallback 到 8080,但不会主动告诉你。
先验证它到底听哪个端口:netstat -ano | findstr :80 和 netstat -ano | findstr :8080 都跑一遍。如果只有 8080 有输出,那浏览器就得访问 http://localhost:8080/phpmyadmin。
- 想长期用 80 端口?打开
xampppacheconfhttpd.conf,改两处:Listen 80和ServerName localhost:80 - 改完别忘了重启 Apache——只点 Start 不够,得先 Stop 再 Start,否则旧配置还在内存里
- Mac 用户注意:
sudo apachectl stop必须先执行,否则系统自带 Apache 会死守 80
MySQL 启动卡在 “Starting…”,error.log 提示 innodb_system data file 'ibdata1' must be writable
这不是权限设置问题,而是 datadir 路径指向了一个它没写入权限的位置,或者该目录下核心文件(ibdata1、ib_logfile0、ib_logfile1)被删/损坏/只读。
最稳妥的做法是重置 data 目录,但别直接删——先备份整个 xamppmysqldata 文件夹,再从 xamppmysqlackup 复制一份干净的过来。
- 复制前确保 MySQL 已完全停止:任务管理器里搜
mysqld.exe,一个都不能剩 - 复制后打开
my.ini,核对datadir是否指向你刚放好的新 data 目录,路径里用正斜杠/或双反斜杠,别用单反斜杠 - 如果之前自己建过库,恢复时只需把原
data里对应数据库文件夹(不含mysql、performance_schema等系统库)拷回新 data 目录即可
apachectl、Linux 下缺失的 libnsl.so.1——它们不报错,只让服务悄悄失效。
相关文章
- 《明日方舟终末地》陈千语怎么样-陈千语值得培养吗 07-04
- 《明日方舟终末地》余烬怎样配队-余烬阵容搭配推荐 07-04
- 《明日方舟终末地》骏卫怎么样-骏卫值得培养吗 07-04
- 《明日方舟终末地》莱万汀怎样配队-莱万汀强力配队推荐 07-04
- 《明日方舟终末地》原木怎样获得-原木获得方法 07-04
- 《长生天机降世》太虚境十天智遗迹幻境通关攻略-详细打法解析 07-04