服务器上mysql -u -p没有_如何访问linux服务器上的mysql8.0

这篇博客详细介绍了如何在Linux服务器上安装并配置MySQL8.0,包括安装mysql-connector,初始化数据文件,启动服务,解决启动服务失败的问题,以及登录和设置/修改root用户密码。特别强调了MySQL8.0中密码认证插件的变化,以及处理远程连接权限的步骤,确保'%'主机允许任意IP连接。
摘要由CSDN通过智能技术生成

首先安装好了mysql-connector

1.1. 下载:

官网下载zip包,我下载的是64位的:

下载zip的包:

下载后解压:(解压在哪个盘都可以的)

我放在了这里 E:webmysql-8.0.11-winx64 ,顺便缩短了文件名,所以为 E:webmysql-8.0.11。

1.3. 生成data文件:

以管理员身份运行cmd

程序--输入cmd 找到cmd.exe 右键以管理员身份运行

进入E:webmysql-8.0.11in 下

执行命令:

mysqld --initialize-insecure --user=mysql

在E:webmysql-8.0.11目录下生成data目录

1.4. 启动服务:

执行命令:

net start mysql

启动mysql服务,若提示:服务名无效...(请看步骤:1.5);

1.5. 解决启动服务失败(报错):

提示:服务名无效

解决方法:

执行命令:

mysqld -install

即可(不需要my.ini配置文件 注意:网上写的很多需要my.ini配置文件,其实不需要my.ini配置文件也可以,我之前放置了my.ini文件,反而提示服务无法启动,把my.ini删除后启动成功了)

若出现提示“服务正在启动或停止中,请稍后片刻后再重试一次”,需要去资源管理器中把mysql进程全结束了,重新启动即可。

1.6. 登录mysql:

登录mysql:(因为之前没设置密码,所以密码为空,不用输入密码,直接回车即可)

E:mysql-5.7.20-winx64in>mysql -u root -p

Enter password:

1.7. 查询用户密码:

查询用户密码命令:

mysql> select host,user,authentication_string from mysql.user;

host: 允许用户登录的ip‘位置'%表示可以远程;

user:当前数据库的用户名;

authentication_string: 用户密码(后面有提到此字段);

1.8. 设置(或修改)root用户密码:

默认root密码为空的话 ,下面使用navicat就无法连接,所以我们需要修改root的密码。

这是很关键的一步。此处踩过N多坑,后来查阅很多才知道在mysql 5.7.9以后废弃了password字段和password()函数;authentication_string:字段表示用户密码。

下面直接演示正确修改root密码的步骤:

一、如果当前root用户authentication_string字段下有内容,先将其设置为空,否则直接进行二步骤。

use mysql;

update user set authentication_string='' where user='root'

3.下面直接演示正确修改root密码的步骤:

二、使用ALTER修改root用户密码,方法为

ALTER user 'root'@'localhost' IDENTIFIED BY '新密码'

如下:

ALTER user 'root'@'localhost' IDENTIFIED BY 'Cliu123#'

此处有两点需要注意:

1、不需要flush privileges来刷新权限。

2、密码要包含大写字母,小写字母,数字,特殊符号。

修改成功; 重新使用用户名密码登录即可;

注意: 一定不要采取如下形式该密码:

use mysql;

update user set authentication_string="newpassword" where user="root";

这样会给user表中root用户的authentication_string字段下设置了newpassword值;

当再使用

ALTER USER 'root'@'localhost' IDENTIFITED BY 'newpassword'

时会报错的;

因为authentication_string字段下只能是mysql加密后的41位字符串密码;其他的会报格式错误;

*THISISNOTAVALIDPASSWORDTHATCANBEUSEDHERE

至此,安装mysql和修改root密码告一段落。

开始navicat for mysql篇。

账号密码都正确,连接报错1251。OK 我们先来看看这个改动:

在MySQL 8.04前,执行:SET PASSWORD=PASSWORD('[新密码]');

但是MySQL8.0.4开始,这样默认是不行的。因为之前,MySQL的密码认证插件是“mysql_native_password”,而现在使用的是“caching_sha2_password”。

so,我们这里需要再次修改一次root密码。

先登录进入mysql环境:执行下面三个命令。(记得带上分号)

use mysql;

ALTER USER'root'@'localhost' IDENTIFIED WITH mysql_native_password BY '新密码';

FLUSH PRIVILEGES;

OK.现在再去重连。perfect!

折腾了这么久,总算可以开始我的SQL之路了,撒花!撒花!撒花!

本来准备好的有截图说明,发现插入图片失败,就先这样吧。

下面解决为什么会出现下面的情况;

D:pythonProjectsmysql_connect_test>python mysql_connect_test.py1130 (HY000): Host '113.140.84.102' is not allowed to connect to this MySQL server

这个问题是因为在数据库服务器中的mysql数据库中的user的表中没有权限(也可以说没有用户),下面将记录我遇到问题的过程及解决的方法。

在搭建完LNMP环境后用Navicate连接出错

遇到这个问题首先到mysql所在的服务器上用连接进行处理

1、连接服务器: mysql -u root -p

2、看当前所有数据库:show databases;

3、进入mysql数据库:use mysql;

4、查看mysql数据库中所有的表:show tables;

5、查看user表中的数据:select Host, User,Password from user;

6、修改user表中的Host:update user set Host='%' where User='root';

7、最后刷新一下:flush privileges;

#一定要记得在写sql的时候要在语句完成后加上" ; "下面是图示说明

7b547ae532717760f1fad4acfa5f1faf.png

遇到这个问题首先到mysql所在的服务器上用连接进行处理

连接服务器: mysql -u root -p

f5390a3f086d6203cd25e7dc64a26daf.png

查看当前所有数据库:show databases;

a93e57b99c63c9d28b57b5c9346045ab.png

进入mysql数据库:use mysql;

852da09bee87cf701d0e195ab7d1a5ad.png

查看mysql数据库中所有的表:show tables;

21d82622142c21b5f243ad323a2c56b6.png

查看user表中的数据:select Host, User,Password from user;

ef15b4e05ec2c02f29c8e858c118e1e5.png

修改user表中的Host:update user set Host='%' where User='root';

ff8e5f88464a1c51251b03b1a516f4e1.png

最后刷新一下:flush privileges;

391cdbe47b5f423a935ecfa8d044c2da.png

重新在Navicate中测试一下:

b360ce19cc7ff1831aec82f0bb484a32.png

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值