MySQL 8 常见故障及解决方案

一、安装与启动故障

  1. 配置文件错误

    • 现象‌:启动时提示语法错误或配置无效。
    • 解决‌:使用 mysqld --validate-config 校验配置文件 my.cnf,修正错误参数并重启服务。
    bashCopy Code
    mysqld --validate-config # 检查配置语法 systemctl restart mysqld # 重启服务
  2. 端口冲突

    • 现象‌:启动失败,日志提示 3306 端口被占用。
    • 解决‌:通过 netstat -tuln | grep 3306 检查端口占用情况,终止冲突进程或修改 MySQL 端口配置。
    iniCopy Code
    # my.cnf 中修改端口 [mysqld] port=3307
  3. 数据目录权限问题

    • 现象‌:日志显示 Permission denied
    • 解决‌:确保数据目录权限为 mysql:mysql,执行以下命令修正权限:
    bashCopy Code
    chown -R mysql:mysql /var/lib/mysql chmod -R 755 /var/lib/mysql ```:ml-citation{ref="6,7" data="citationList"}

二、连接与认证问题

  1. 身份验证插件不兼容
    • 现象‌:旧客户端无法连接,报错 caching_sha2_password not supported
    • 解决‌:修改用户认证插件为 mysql_native_password
    sqlCopy Code
    ALTER USER 'username'@'host' IDENTIFIED WITH mysql_native_password BY 'password'; FLUSH PRIVILEGES; ```:ml-citation{ref="2" data="citationList"}
  2. 拒绝访问(ERROR 1130)
    • 现象‌:远程连接失败,提示 Host 'xxx' is not allowed to connect
    • 解决‌:检查用户权限是否绑定正确主机(如 % 允许所有 IP),并执行 FLUSH PRIVILEGES

三、密码管理故障

  1. 密码遗忘

    • 现象‌:无法登录数据库。
    • 解决‌:
      1. 编辑 my.cnf 添加 skip-grant-tables,重启服务。
      2. 使用 UPDATE 语句重置密码后移除配置并重启45
      sqlCopy Code
      UPDATE mysql.user SET authentication_string=password('new_pass') WHERE user='root'; FLUSH PRIVILEGES;
  2. 密码策略限制(ERROR 1819)

    • 现象‌:设置简单密码时报错。
    • 解决‌:查询当前策略 SHOW VARIABLES LIKE 'validate_password%';,调整策略或使用复杂密码。

四、性能与兼容性问题

  1. 查询性能下降

    • 原因‌:MySQL 8 移除了查询缓存,依赖缓存的查询可能变慢。
    • 解决‌:优化 SQL 语句并添加合适的索引,避免全表扫描。
  2. 大小写敏感冲突

    • 现象‌:Linux 环境下表名大小写敏感导致 Table not found
    • 解决‌:在 my.cnf 中设置 lower_case_table_names=1(需在初始化前配置)。

五、依赖与安装环境问题

  1. CentOS 7 安装失败
    • 现象‌:密钥校验失败或依赖冲突。
    • 解决‌:使用 --nogpgcheck 跳过校验,或手动导入密钥。
    bashCopy Code
    sudo yum install mysql-server --nogpgcheck

总结排查流程

  1. 日志优先‌:查看 /var/log/mysqld.log 或 journalctl -xe 定位错误类型。
  2. 分步验证‌:从配置、权限、端口到 SQL 语句逐层排查。
  3. 版本适配‌:确保客户端库与 MySQL 8 新特性兼容。