ubuntu上的mysql远程连不上root

一、远程连不上

1. 先确认 MySQL 服务的监听配置

这是最常见的远程连接失败原因,MySQL 默认只监听本地 127.0.0.1,不对外网开放。

查看当前绑定的 IP

sql 复制代码
SHOW GLOBAL VARIABLES LIKE 'bind_address';
  • 如果结果是 127.0.0.1 → 只允许本地连接,需要修改。
  • 如果结果是 0.0.0.0 → 已经允许所有 IP 访问,跳过这一步。

2.先定位到 Ubuntu 上正确的配置文件

在 Ubuntu 中,MySQL 的主配置文件通常是:

bash 复制代码
/etc/mysql/mysql.conf.d/mysqld.cnf

修改 bind-address

在 [mysqld] 部分,找到这一行:

bash 复制代码
bind-address = 127.0.0.1

改成

bash 复制代码
bind-address = 0.0.0.0

3、重启mysql

bash 复制代码
sudo systemctl restart mysql

二、root连不上

先查询权限配置

sql 复制代码
#执行以下SQL查询root账号的所有权限配置
SELECT user, host, authentication_string, plugin FROM mysql.user WHERE user = 'root';

如果没有root&'%'

先显式创建用户,再执行授权

需要分两步操作,先创建 root'@'% 用户(可设置密码),再给该用户授予权限,步骤如下:

步骤 1:先创建 'root'@'%' 用户(必做)

执行创建语句(替换 你的密码 为实际要设置的 root 远程密码,也可留空但不推荐):

sql 复制代码
-- MySQL 5.7 及以下版本(password()函数可用)
CREATE USER 'root'@'%' IDENTIFIED BY '你的密码';

-- MySQL 8.0 及以上版本(推荐,password()函数已废弃)
CREATE USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY '你的密码';

步骤 2:再执行你的授权语句(此时用户已存在,不会报错)

sql 复制代码
GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' WITH GRANT OPTION;

步骤 3:刷新权限(使授权立即生效,必做)

sql 复制代码
FLUSH PRIVILEGES;
相关推荐
Turnip12021 天前
深度解析:为什么简单的数据库"写操作"会在 MySQL 中卡住?
后端·mysql
加号32 天前
windows系统下mysql多源数据库同步部署
数据库·windows·mysql
シ風箏2 天前
MySQL【部署 04】Docker部署 MySQL8.0.32 版本(网盘镜像及启动命令分享)
数据库·mysql·docker
欧云服务器2 天前
怎么让脚本命令可以同时在centos、debian、ubuntu执行?
ubuntu·centos·debian
WeiXin_DZbishe2 天前
基于django在线音乐数据采集的设计与实现-计算机毕设 附源码 22647
javascript·spring boot·mysql·django·node.js·php·html5
智渊AI2 天前
Ubuntu 20.04/22.04 下通过 NVM 安装 Node.js 22(LTS 稳定版)
ubuntu·node.js·vim
爱可生开源社区2 天前
MySQL 性能优化:真正重要的变量
数据库·mysql
小马爱打代码2 天前
MySQL性能优化核心:InnoDB Buffer Pool 详解
数据库·mysql·性能优化
风流 少年2 天前
mysql mcp
数据库·mysql·adb
西门吹雪分身3 天前
mysql之数据离线迁移
数据库·mysql