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及应用配置。
这基本就是 3306 端口被占了,不是配置错、不是文件损坏,就是端口冲突。Windows 上 Skype、Docker Desktop、旧版 MySQL 服务、甚至某些国产软件的后台模块,都爱抢这个端口。
别靠任务管理器猜,进管理员 CMD 执行:netstat -ano | findstr :3306。如果返回带 PID 的行,再用 tasklist | findstr "12345"(把 12345 换成实际 PID)确认进程名。看到 svchost.exe 别急着 kill——它可能是系统更新或网络服务,强行结束会导致其他功能异常。
taskkill /f /pid 12345
MySQL80),进 services.msc 停止它,并把启动类型改为“手动”docker ps,再用 docker stop $(docker ps -q --filter ancestor=mysql)
只改 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 不生效).env、WordPress 的 wp-config.php)里所有 DB_HOST 或数据库连接字符串,都要显式加上 :3307,例如 127.0.0.1:3307
控制面板显示 Apache 在跑,不代表它真在监听 80 端口。XAMPP 检测到 80 被占,会自动 fallback 到 8080,但不会主动告诉你。
先验证它到底听哪个端口:netstat -ano | findstr :80 和 netstat -ano | findstr :8080 都跑一遍。如果只有 8080 有输出,那浏览器就得访问 http://localhost:8080/phpmyadmin。
xampppacheconfhttpd.conf,改两处:Listen 80 和 ServerName localhost:80
sudo apachectl stop 必须先执行,否则系统自带 Apache 会死守 80这不是权限设置问题,而是 datadir 路径指向了一个它没写入权限的位置,或者该目录下核心文件(ibdata1、ib_logfile0、ib_logfile1)被删/损坏/只读。
最稳妥的做法是重置 data 目录,但别直接删——先备份整个 xamppmysqldata 文件夹,再从 xamppmysqlackup 复制一份干净的过来。
mysqld.exe,一个都不能剩my.ini,核对 datadir 是否指向你刚放好的新 data 目录,路径里用正斜杠 / 或双反斜杠 ,别用单反斜杠
data 里对应数据库文件夹(不含 mysql、performance_schema 等系统库)拷回新 data 目录即可apachectl、Linux 下缺失的 libnsl.so.1——它们不报错,只让服务悄悄失效。