Ubuntu上安装MySQL 8并配置Navicat远程连接

1. 安装MySQL 8

bash 复制代码
sudo apt update
sudo apt install mysql-server -y

2. 启动MySQL服务

bash 复制代码
sudo systemctl start mysql
sudo systemctl enable mysql

3. 设置root密码

3.1 登录MySQL(默认无密码):
bash 复制代码
sudo mysql
3.2 修改root认证方式并设置密码:
sql 复制代码
ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY '你的密码';
FLUSH PRIVILEGES;
EXIT;
3.3 运行安全脚本(可选但推荐):
bash 复制代码
sudo mysql_secure_installation
  • 按提示操作:设置密码强度、删除匿名用户、禁止远程root登录等。

4. 创建远程访问用户

4.1 登录MySQL:
bash 复制代码
mysql -u root -p
4.2 创建用户并授权(替换用户名密码):
sql 复制代码
CREATE USER '用户名'@'%' IDENTIFIED WITH mysql_native_password BY '密码';
GRANT ALL PRIVILEGES ON *.* TO '用户名'@'%';
FLUSH PRIVILEGES;
EXIT;

5. 允许MySQL远程连接

5.1 修改配置文件:
bash 复制代码
sudo nano /etc/mysql/mysql.conf.d/mysqld.cnf
  • 找到 bind-address = 127.0.0.1,改为:

    ini 复制代码
    bind-address = 0.0.0.0
  • 保存并退出(Ctrl+OEnterCtrl+X)。


6. 开放防火墙端口

bash 复制代码
sudo ufw allow 3306/tcp
sudo ufw reload

7. 重启MySQL服务

bash 复制代码
sudo systemctl restart mysql

8. 验证远程连接

  • 在Navicat中使用以下信息连接:
    • 主机/IP: Ubuntu服务器的IP地址
    • 端口: 3306
    • 用户名/密码: 步骤4中创建的用户信息

常见问题解决

  1. 认证插件错误

    • 确保用户使用mysql_native_password插件(步骤4.2已配置)。
  2. 连接被拒绝

    • 检查防火墙规则:sudo ufw status
    • 确认MySQL监听所有IP:sudo netstat -tuln | grep 3306
  3. 密码策略问题

    • 临时降低密码策略:

      sql 复制代码
      SET GLOBAL validate_password.policy = LOW;
相关推荐
lzyuuuu1 分钟前
Ubuntu22.04 VMware虚拟机文件拖放问题:文字复制正常但文件拖放失效
ubuntu
Wang's Blog44 分钟前
MySQL: 高并发电商场景下的数据库架构演进与性能优化实践
mysql·性能优化·数据库架构
程序新视界1 小时前
什么是MySQL JOIN查询的驱动表和被驱动表?
数据库·后端·mysql
一匹电信狗2 小时前
【MySQL】数据库的相关操作
linux·运维·服务器·数据库·mysql·ubuntu·小程序
陈一Tender2 小时前
JavaWeb后端实战(登录认证 & 令牌技术 & 拦截器 & 过滤器)
java·开发语言·spring boot·mysql
小猫挖掘机(绝版)5 小时前
kalibr进行相机内参以及相机imu的融合标定
ubuntu·无人机·slam·标定·vinsfusion
Siren_dream5 小时前
在VMware上运行Linux(我选择的是Ubuntu)
linux·运维·ubuntu
Cabbage_acmer5 小时前
MySQL期中考试突击!
数据库·mysql
迷路爸爸1806 小时前
源码编译安装最新 tmux 教程(含 Debian/Ubuntu/CentOS/Arch/macOS 等系统)
linux·ubuntu·macos·centos·debian·tmux·archlinux
chenzhou__7 小时前
MYSQL学习笔记(个人)(第十五天)
linux·数据库·笔记·学习·mysql