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;
相关推荐
2301_7679026410 小时前
MySQL 入门
数据库·mysql
7ioik11 小时前
说一说MySQL数据库基本架构?
数据库·mysql·架构
东东的脑洞11 小时前
【面试突击】MySQL 查询优化核心面试知识点
mysql·面试·职场和发展
-dcr12 小时前
45.MySQL
mysql
大学生资源网12 小时前
基于Javaweb技术的宠物用品商城的设计与实现(源码+文档)
java·mysql·毕业设计·源码·springboot
小无名呀12 小时前
视图(View)
数据库·mysql
星光一影12 小时前
教育培训机构消课管理系统智慧校园艺术舞蹈美术艺术培训班扣课时教务管理系统
java·spring boot·mysql·vue·mybatis·uniapp
lkbhua莱克瓦2412 小时前
MySQL介绍
java·开发语言·数据库·笔记·mysql
蜂蜜黄油呀土豆12 小时前
MySQL 锁机制全解析:从锁的分类到并发更新是否阻塞
mysql·innodb·并发控制·数据库锁·事务隔离级别
40kuai13 小时前
Mysql 主从同步
mysql