阿里云服务器(Ubuntu22)上的MySQL8数据库下载,安装和远程连接

最近阿里云centos主机到期了改为使用Ubuntu操作系统,在上面安装mysql并远程连接出现了一系列问题并解决。

之前在centos系统上下载mysql8的教程如下:
阿里云服务器(centos7)上的MySQL8数据库下载,安装和远程连接

主机操作系统类型:

1.安装

bash 复制代码
#更新
apt-get update

#安装mysqlserver
apt-get install mysql-server

#使得mysql可以远程登陆
vim /etc/mysql/mysql.conf.d/mysqld.cnf
#注释掉这一行
#bind-address = 127.0.0.1

#重启mysql
service mysql restart;

2.修改root密码和能够远程连接

bash 复制代码
ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'P@ssw0rd'; 

mysql -u root -p (mysql8只能用两句执行了)  
CREATE USER 'root'@'%' IDENTIFIED BY 'P@ssw0rd';  
GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' WITH GRANT OPTION;

3.问题

ERROR 1698 (28000): Access denied for user 'root'@'localhost'。

原因:MySQL默认使用了UNIX auth_socket plugin插件。简单来说这意味着当db_users使用数据库时,将会通过系统用户认证表进行认证。你可以通过下面的命令看看你的root用户是否设置成了这样:

就像你在查询语句中看到的那样,root用户在使用auth_socket插件。

设置你的root用户使用mysql_native_password插件 。

bash 复制代码
UPDATE user SET plugin='mysql_native_password' WHERE User='root';

但是这样会导致root需要重新设置密码;

bash 复制代码
ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY 'P@ssw0rd'; 
相关推荐
疾风铸境1 分钟前
项目研发实录:电子称SDK封装dll给到QT和C#调用
linux·服务器·网络
cellurw8 分钟前
Day39 SQLite数据库操作与HTML核心API及页面构建
数据库·sqlite·html
小蒜学长18 分钟前
旅行社旅游管理系统的设计与实现(代码+数据库+LW)
java·数据库·spring boot·后端·旅游
Mr_hwt_12323 分钟前
基于mybatis-plus动态数据源实现mysql集群读写分离和从库负载均衡教程(详细案例)
数据库·spring boot·mysql·mybatis·mysql集群
D11_32 分钟前
【服务器】将本地项目部署到服务器
运维·服务器
万邦科技Lafite34 分钟前
实战演练:通过API获取商品详情并展示
大数据·数据库·python·开放api接口
黄焖鸡能干四碗1 小时前
智慧教育,智慧校园,智慧安防学校建设解决方案(PPT+WORD)
java·大数据·开发语言·数据库·人工智能
敲上瘾1 小时前
Docker 存储卷(Volume)核心概念、类型与操作指南
linux·服务器·数据库·docker·容器·架构
DemonAvenger1 小时前
MySQL内存优化:缓冲池与查询缓存调优实战指南
数据库·mysql·性能优化
RationalDysaniaer1 小时前
了解etcd
数据库·etcd