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;
相关推荐
郝亚军几秒前
ubuntu-18.04.6-desktop-amd64安装步骤
linux·运维·ubuntu
Wiktok14 分钟前
MySQL的常用数据类型
数据库·mysql
夹锌饼干2 小时前
mysql死锁排查流程--(处理mysql阻塞问题)
java·mysql
无限码力2 小时前
华为OD技术面真题 - Mysql相关 - 4
mysql·华为od·华为od技术面真题·华为od技术面八股·华为od技术面八股文·华为od技术面mysql相关
源远流长jerry4 小时前
dpdk之kni处理dns案例
linux·网络·网络协议·ubuntu·ip
郝亚军4 小时前
ubutnu 64位系统,需要安装的工具包
linux·运维·ubuntu
惊讶的猫4 小时前
mysql多表查询
数据库·mysql
学习不止,掉发不停4 小时前
MySQL基础-DQL(四)
数据库·mysql
@ chen5 小时前
MySQL 中的锁机制
数据库·mysql
多多*5 小时前
2月3日面试题整理 字节跳动后端开发相关
android·java·开发语言·网络·jvm·adb·c#