ICode9

精准搜索请尝试: 精确搜索
首页 > 数据库> 文章详细

Linux Ubuntu20.04下安装MySQL

2021-11-09 14:04:45  阅读:173  来源: 互联网

标签:Ubuntu20.04 grant privileges mysql Linux MySQL password root


Linux Ubuntu20.04下安装MySQL

环境信息:
OS:Ubuntu 20.04
MySQL server

1.安装MySQL

#命令1
sudo apt-get update
#命令2
sudo apt-get install mysql-server

2.配置MySQL

#1
VALIDATE PASSWORD PLUGIN can be used to test passwords...
Press y|Y for Yes, any other key for No: N (我的选项)

#2
Please set the password for root here...
New password: (输入密码)
Re-enter new password: (重复输入)

#3
By default, a MySQL installation has an anonymous user,
allowing anyone to log into MySQL without having to have
a user account created for them...
Remove anonymous users? (Press y|Y for Yes, any other key for No) : Y (我的选项)

#4
Normally, root should only be allowed to connect from
'localhost'. This ensures that someone cannot guess at
the root password from the network...
Disallow root login remotely? (Press y|Y for Yes, any other key for No) : N (我的选项)

#5
By default, MySQL comes with a database named 'test' that
anyone can access...
Remove test database and access to it? (Press y|Y for Yes, any other key for No) : y (我的选项)

#6
Reloading the privilege tables will ensure that all changes
made so far will take effect immediately.
Reload privilege tables now? (Press y|Y for Yes, any other key for No) : Y (我的选项)

在这里插入图片描述

2.2 检查mysql服务状态

安装完成之后可以使用如下命令来检查是否安装成功:

systemctl status mysql.service

在这里插入图片描述

ps -ef | grep mysql

在这里插入图片描述

通过上述命令检查之后,如果看到有 mysql 的socket处于 LISTEN 状态则表示安装成功。

sudo mysql -uroot -pmysql

在这里插入图片描述

使用navicat for mysql 连接 MySQL

# %为所有主机都可以连接
mysql> create user 'root'@'%' identified by  'mysql';
Query OK, 0 rows affected (0.03 sec)
 
mysql> grant all privileges on *.* to 'root'@'%' with grant option;
Query OK, 0 rows affected (0.01 sec)
 
mysql> flush privileges;
Query OK, 0 rows affected (0.00 sec)

更改加密方式,不然会报错

mysql> ALTER USER 'root'@'%' IDENTIFIED BY 'mysql' PASSWORD EXPIRE NEVER;

在这里插入图片描述

相关报错问题:mysql版本问题

查询mysql具体版本

SELECT @@VERSION

在这里插入图片描述
分别执行下面三条语句:

#1.创建账户
create user 'root'@'192.168.1.176' identified by  'mysql';

#2.赋予权限,with grant option这个选项表示该用户可以将自己拥有的权限授权给别人
grant all privileges on *.* to 'root'@'192.168.1.176' with grant option;

#3.改密码&授权超用户,flush privileges 命令本质上的作用是将当前user和privilige表中的用户信息/权限设置从mysql库(MySQL数据库的内置库)中提取到内存里
flush privileges;
# %为所有主机都可以连接
mysql> create user 'root'@'%' identified by  'mysql';
Query OK, 0 rows affected (0.03 sec)
 
mysql> grant all privileges on *.* to 'root'@'%' with grant option;
Query OK, 0 rows affected (0.01 sec)
 
mysql> flush privileges;
Query OK, 0 rows affected (0.00 sec)

在这里插入图片描述

navicat for mysql :1251-Client does not support authentication protocol requested by server

在这里插入图片描述
在这里插入图片描述

错误原因

使用MySQL客户端Navicat连接数据库MySQL8.0,MySQL8.0 之前的版本中加密规则是mysql_native_password,而MySQL8.0,加密规则是caching_sha2_password

更改加密方式:

mysql> ALTER USER 'root'@'localhost' IDENTIFIED BY 'password' PASSWORD EXPIRE NEVER;

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

标签:Ubuntu20.04,grant,privileges,mysql,Linux,MySQL,password,root
来源: https://blog.csdn.net/qq_43030934/article/details/121222724

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有