Mac M2 Pro安装MySQL 8.4.3

絮絮叨叨

  • MacBook Pro,芯片:Apple M2 Pro, macOS: Sonoma 14.0
  • 一直知道很多软件对Mac M1或M2的支持不好,但没想到在安装MySQL 8.x上也让我吃尽了苦头
  • 本文除了介绍如何安装MySQL 8.4.3外,还会记录笔者遇到的一些问题以及解决方法

MySQL 8.4.3的安装

下载.dmg的安装包

图形化界面安装

  • 由于笔者忘记截图了,这里推荐参考文档:Macbook M2配置MySQL 8.x记录
  • 注意:记住安装时,输入的密码!!! 笔者偷懒,直接是12345678 😂
  • 安装结束后,在 系统设置 最底部就能看到MySQL服务,绿色小圆点表示服务运行中

配置系统环境变量

  • 这时候,还不能通过mysql -uroot -p这样的命令登录MySQL,还需要配置一下系统环境变量

    bash 复制代码
    vim ~/.zshrc
  • 在文件尾部加入以下内容,/usr/local/mysql是对应的默认安装目录

    bash 复制代码
    export PATH=$PATH:/usr/local/mysql/bin
    export PATH=$PATH:/usr/local/mysql/support-files
  • 让环境变量生效

    bash 复制代码
    source ~/.zshrc
  • 通过 mysql -V 验证环境变量是否生效,如果生效会显示MySQL的版本信息

  • 这时候MySQL服务基本上就已经安装完成了

笔者遇到的一些问题记录

环境变量不生效

  • 如果 mysql -V无法执行,一般都是环境变量配置有问题

  • 可以通过echo $PATH,查看MySQL的环境变量是否正确加载

  • 首先,检查安装路径是否正确,也就是/usr/local/mysql这个路径是否正确

  • 笔者是安装路径没有问题,但是自己鬼使神差地通过echo写入,导致上述配置到了整个$PATH之后

登录失败

  • 使用如下方式登录MySQL均失败

    bash 复制代码
    mysql -u root -p
    mysql -h 127.0.0.1 -u root -p
  • 报错如下:

  • 可能是服务未启动

  • 使用如下命令可以查看MySQL服务的状态,启动、停止、重启MySQL服务。参考文档:MAC MySql 安装(详细步骤)

    bash 复制代码
    # 查看MySQL服务状态
    sudo mysql.server status
    # 开启MySQL服务(需要输入电脑密码,不是数据库登录密码)
    sudo mysql.server start
    # 停止MySQL服务
    sudo mysql.server stop
    # 重启MySQL服务
    sudo mysql.server restart

使用mysql-native-passwod插件进行用户认证

  • 从MySQL 8.0 开始,将默认密码认证插件从mysql-native-password调整为 caching_sha2_password,感兴趣的可以看这边文档:从源码分析 MySQL 身份验证插件的实现细节

  • 由于工作需要,本地部署的MySQL服务对root用户应该使用mysql-native-password插件进行认证

  • 由于使用默认的 caching_sha2_password插件,通过程序访问MySQL报错

    bash 复制代码
    MySQL 8.0 - Client does not support authentication protocol requested by server; consider upgrading MySQL client
  • 这时需要配置/my.cnf文件。首先,执行如下命令,查看/my.cnf文件的地址

    bash 复制代码
    mysql --help | grep -A 1 "Default options"
  • 笔者选择在/usr/local/mysql/etc目录下创建my.cnf文件,注意: /usr/local/目录的更新,一般都需要使用sudo

  • 添加如下内容:

    bash 复制代码
    [mysqld]
    port=3306
    bind-address=0.0.0.0
    mysql_native_password=ON # 开启mysql_native_password插件
  • 创建好后,重启MySQL服务。命令行登录MySQL后,执行如下SQL

    bash 复制代码
    USE mysql;
    SELECT user, host, plugin FROM user;
  • 这时,自建用户(如root用户)的认证方式将变成mysql_native_password

  • 感谢文档:mysql_native_password DISABLED,这次一向很好用的stackoverflow和 chatGPT 竟然都没帮上我

相关推荐
A__tao38 分钟前
一键将 SQL 转为 Java 实体类,全面支持 MySQL / PostgreSQL / Oracle!
java·sql·mysql
一只fish1 小时前
MySQL 8.0 OCP 1Z0-908 题目解析(17)
数据库·mysql
叁沐2 小时前
MySQL 06 全局锁和表锁:给表加个字段怎么有这么多阻碍?
mysql
power 雀儿4 小时前
集群聊天服务器---MySQL数据库的建立
服务器·数据库·mysql
Edingbrugh.南空6 小时前
Flink MySQL CDC 环境配置与验证
mysql·adb·flink
BD_Marathon6 小时前
Ubuntu:Mysql服务器
服务器·mysql·ubuntu
程序猿小D7 小时前
[附源码+数据库+毕业论文]基于Spring+MyBatis+MySQL+Maven+jsp实现的电影小说网站管理系统,推荐!
java·数据库·mysql·spring·毕业设计·ssm框架·电影小说网站
羊小猪~~7 小时前
数据库学习笔记(十七)--触发器的使用
数据库·人工智能·后端·sql·深度学习·mysql·考研
叁沐8 小时前
MySQL 05 深入浅出索引(下)
mysql
陈卓4109 小时前
MySQL-主从复制&分库分表
android·mysql·adb