Mac 局域网内连接 MySQL

1. 前言

本文记录在 mac 局域网下实现数据库资源共享的问题

项目开发初期,都是在本地进行开发调试,数据库也在本地。那么和你配合开发的同事,就可能想要连接你 mac 电脑的数据库,连接过程中可能就会遇到问题。本文详细记录这些问题及解决方案

2. 绑定地址

一般情况下,你的 MySQL 的 bind-address 取值可能是下面这样的

复制代码
  1. [mysqld]
  2. # Only allow connections from localhost
  3. bind-address = 127.0.0.1

同一局域网内的电脑连接 MySQL 将会报以下错误,目前 MySQL 只能本机访问,不支持局域网内其他电脑访问

复制代码
  1. SQLSTATE[HY000] [1130] Host 'MACBOOKPRO-FB6C' is not allowed to connect to this MySQL server

MySQL 的配置项 bind-address 用于指定哪些 IP 可以连接数据库,下面是最常见的取值:

说明
127.0.0.1 只能本地连接
0.0.0.0 允许所有 IP 访问

可以通过命令查看当前 bind_address 配置

复制代码
  1. select @@bind_address;

下面是我的配置,如果你的查询结果是 127.0.0.1,那么只有你自己的电脑才能连接,别人都访问不了

3. 查找配置文件

下面这个命令可以用于查看数据库配置,以及 MySQL 引用了哪些配置文件和配置文件的加载顺序

复制代码
  1. mysql --verbose --help

Mac 中通过命令查找 MySQL 配置文件所在位置

特别注意:Mac 中 MySQL 的配置文件是 my.cnf,在 Windows 中是 my.ini

复制代码
  1. mysql --verbose --help | grep my.cnf

下面显示多个配置文件的优先加载顺序,在当前使用的配置文件中修改配置即可

4. 修改访问权限

注意:将修改权限命令的用户密码修改为你的正常密码,我的用户名是 root 密码是 123456

复制代码
  1. -- 修改权限
  2. grant all privileges on *.* to root@"%" identified by '123456' with grant option;
  3. -- 刷新权限
  4. flush privileges;
相关推荐
TDengine (老段)30 分钟前
TDengine IDMP 应用场景:工业锅炉监控
大数据·数据库·物联网·信息可视化·时序数据库·tdengine
dreams_dream3 小时前
Django的Settings 配置文件详解
数据库·django·sqlite
一只叫煤球的猫3 小时前
看到同事设计的表结构我人麻了!聊聊怎么更好去设计数据库表
后端·mysql·面试
2501_927539303 小时前
EndNote 2025 Mac 文献管理工具
macos·mac·文献管理
遇见你的雩风4 小时前
【MySQL】CRUD基础详解
数据库·mysql
夜雨听萧瑟6 小时前
sqlite创建数据库,创建表,插入数据,查询数据的C++ demo
数据库·sqlite
.Shu.6 小时前
Mysql InnoDB 底层架构设计、功能、原理、源码系列合集【四、事务引擎核心 - MVCC与锁机制】
数据库·mysql
多工坊7 小时前
【DataGrip】连接达梦数据库后,能查询数据但是看不到表的几种情况分析,达梦数据库驱动包下载DmJdbcDriver18.jar
java·数据库·jar
何中应7 小时前
如何用Redis作为消息队列
数据库·redis·缓存
liulilittle8 小时前
.NET反射与IL反编译核心技术
开发语言·数据库·c#·.net·反射·反编译·il