Windows主机Navicat远程连接到Ubuntu18.04虚拟机MySQL

1. 在虚拟机上安装MySQL
bash 复制代码
sudo apt-get install mysql-server
sudo apt-get install libmysqlclient-dev
2. 检查安装
bash 复制代码
sudo netstat -tap | grep mysql
3. 查看默认密码
bash 复制代码
sudo cat /etc/mysql/debian.cnf
4. 用查看到的密码登录MySQL server,修改root用户的密码
bash 复制代码
mysql -u debian-sys-maint -pKk3TbShbFNvjvhpM
#注意-p后面紧跟上面查看到的密码
bash 复制代码
#进入mysql>的命令模式后,通过下面三行代码修改密码为123456
update mysql.user set authentication_string=password('123456') where
user='root' and host='localhost';

update mysql.user set plugin="mysql_native_password";

flush privileges;

#退出mysql命令模式
exit;

#重新用root和123456登录mysql-server
mysql -u root -p
#123456(输入密码)
5. 设置MySQL字符编码utf8,可以支持中文操作
sql 复制代码
#在MySQL命令模式下
show variables like "char%";

#修改
set character_set_server=utf-8;

接下来是连接到远程连接。

6. 远程连接

作者在远程连接的时候也遇到了一系列问题,经过查询最后成功解决。主要尝试了以下。

  • 首先进入MySQL配置文件中将bind-address修改为0.0.0.0
bash 复制代码
sudo vim /etc/mysql/mysql.conf.d/mysqld.cnf
  • 进入到MySQL命令模式,开启了远程连接权限
sql 复制代码
#自行登录MySQL服务后...
#开启远程连接权限
grant all privileges on *.* to 'root'@'%' identified by 'root' with grant option;
#刷新一下
flush privileges;
  • 查看并修改了Linux主机的防火墙状态
bash 复制代码
#开启对MySQL默认端口号3306的访问
ufw status
ufw allow 3306
#开启本机IP对Linux上服务器额度访问
#在本机打开CMD等终端,使用ipconfig找到虚拟机IP,回到Ubuntu
ufw allow from 本机IP

此后就是在Navicat上来连接虚拟机的MySQL数据库了

整个连接过程中,遇到了1130错误代码(如下图所示的错误代码),经过上面的步骤也是解决了,成功连接。

相关推荐
周全全2 分钟前
MySQL报错解决:The user specified as a definer (‘root‘@‘%‘) does not exist
android·数据库·mysql
白云如幻6 分钟前
MySQL的分组函数
数据库·mysql
荒川之神22 分钟前
ORACLE 闪回技术简介
数据库·oracle
plmm烟酒僧2 小时前
Windows下QT调用MinGW编译的OpenCV
开发语言·windows·qt·opencv
时差9532 小时前
【面试题】Hive 查询:如何查找用户连续三天登录的记录
大数据·数据库·hive·sql·面试·database
让学习成为一种生活方式2 小时前
R包下载太慢安装中止的解决策略-R语言003
java·数据库·r语言
秋意钟2 小时前
MySQL日期类型选择建议
数据库·mysql
Dxy12393102163 小时前
python下载pdf
数据库·python·pdf
ac-er88883 小时前
MySQL如何实现PHP输入安全
mysql·安全·php
桀桀桀桀桀桀4 小时前
数据库中的用户管理和权限管理
数据库·mysql