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;
相关推荐
SelectDB7 小时前
阶跃星辰基于 SelectDB 构建 PB 级 Agent 可观测平台
大数据·数据库·aigc
这个DBA有点耶8 小时前
GROUP BY优化全解:如何写出既不丢数据又飞快的分组查询
数据库·mysql·架构
掉头发的王富贵12 小时前
【StarRocks】极限十分钟入门StarRocks
数据库·sql·mysql
Nturmoils12 小时前
WHERE 条件别凭习惯写,常用查询先跑一遍
数据库
SamDeepThinking16 小时前
一条UPDATE语句在MySQL 8.0中到底加了几把锁?
后端·mysql·程序员
Databend1 天前
在 AWS 中国峰会逛了一天,我在 Databend 展台看到了 Agent 数据基础设施的新思路
数据库·人工智能·agent
李白客2 天前
KES新版MySQL兼容能力再升级意味着什么?
mysql·国产数据库
ClouGence3 天前
Oracle 数据同步为什么会出现数据不一致?长事务是常被忽略的原因
数据库·后端·oracle
飞将3 天前
从零实现数据库(2)——HashIndex + IndexManager
数据库
Nturmoils3 天前
订单列表慢查询,先看 WHERE、ORDER BY 和 LIMIT
数据库