MySQL   发布时间:2022-05-15  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了分析MySQL用户中的百分号%是否包含localhost?大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
@H_891_0@mysqL用户中的%到底包不包括localhost?

1 前言

操作@H_726_5@mySQL的时候发现,有时只建了%的账号,可以通过localhost连接,有时候却不可以,网上搜索也找不到满意的答案,干脆手动测试一波

推荐学习:《mysql视频教程》

2 两种连接方法

这里说的两种连接方法指是执行@H_726_5@mysqL命令时,-h参数填的是localhost还是IP, 两种连接方式的区别如下

-h 参数为 localhost

-h参数为localhost的时候,实际上是使用socket连接的(默认连接方式), 实例如下

[MysqL@mysqL-test-83 ~]$ /usr/local/MysqL57/bin/MysqL -utest_user -p -hlocalhost
Enter password: 
========= 省略 ===========

MysqL> status
/usr/local/MysqL57/bin/MysqL  Ver 14.14 diStrib 5.7.21, for linux-glibc2.12 (x86_64) using  EditLine wrapper

Connection id:        9
Current database:    
Current user:        test_user@localhost
SSL:            Not in use
Current pager:        stdout
Using outfile:        ''
Using delimiter:    ;
Server version:        5.7.21-log MysqL Community Server (GPL)
Protocol version:    10
Connection:        Localhost via UNIX socket

Current user可以看到用户是xx@localhost, 连接方式为Localhost via UNIX socket

-h 参数为 IP

-h参数为IP的时候,实际上是使用TCP连接的, 实例如下

[MysqL@mysqL-test-83 ~]$ /usr/local/MysqL57/bin/MysqL -utest_user -p -h127.0.0.1
Enter password: 
========= 省略 ===========

MysqL> status
--------------
/usr/local/MysqL57/bin/MysqL  Ver 14.14 diStrib 5.7.21, for linux-glibc2.12 (x86_64) using  EditLine wrapper

Connection id:        11
Current database:    
Current user:        test_user@127.0.0.1
SSL:            Cipher in use is DHE-RSA-AES256-SHA
Current pager:        stdout
Using outfile:        ''
Using delimiter:    ;
Server version:        5.7.21-log MysqL Community Server (GPL)
Protocol version:    10
Connection:        127.0.0.1 via TCP/IP
Server characterset:    utf8

Current user可以看到用户是xx@127.0.0.1, 连接方式为TCP/IP

3 不@R_532_11197@的差别

测试方法就是看能不能连接,如果不想看测试过程可以拉到最后看结论

3.1 MysqL 8.0

@R_773_10589@

@H_557_37@mysqL> SELEct version(); +-----------+ | version() | +-----------+ | 8.0.11    | +-----------+ 1 row in set (0.00 seC) MysqL> create user test_user@'%' identified by 'test_user'; Query OK, 0 rows affected (0.07 seC)

使用 localhost 登录

[root@mysqL-test-72 ~]# /usr/local/MysqL80/bin/MysqL -utest_user -p -hlocalhost
Enter password: 
Welcome to the MysqL monitor.  Commands end with ; or \g.
Your MysqL connection id is 9
Server version: 8.0.11 MysqL Community Server - GPL
========= 省略 ===========

MysqL> status
--------------
/usr/local/MysqL80/bin/MysqL  Ver 8.0.11 for linux-glibc2.12 on x86_64 (MysqL Community Server - GPL)

Connection id:        9
Current database:    
Current user:        test_user@localhost
SSL:            Not in use
Current pager:        stdout
Using outfile:        ''
Using delimiter:    ;
Server version:        8.0.11 MysqL Community Server - GPL
Protocol version:    10
Connection:        Localhost via UNIX socket
...

使用 IP 登录

[root@mysqL-test-72 ~]# /usr/local/MysqL80/bin/MysqL -utest_user -p -h127.0.0.1
Enter password: 
Welcome to the MysqL monitor.  Commands end with ; or \g.
Your MysqL connection id is 8
Server version: 8.0.11 MysqL Community Server - GPL
========= 省略 ===========

MysqL> status
--------------
/usr/local/MysqL80/bin/MysqL  Ver 8.0.11 for linux-glibc2.12 on x86_64 (MysqL Community Server - GPL)

Connection id:        8
Current database:    
Current user:        test_user@127.0.0.1
SSL:            Cipher in use is DHE-RSA-AES128-GCM-SHA256
Current pager:        stdout
Using outfile:        ''
Using delimiter:    ;
Server version:        8.0.11 MysqL Community Server - GPL
Protocol version:    10
Connection:        127.0.0.1 via TCP/IP

结果显示8.0版本的@H_726_5@mysqL, % 包括localhost

3.2 MysqL 5.7

创建 % 用户

db83-3306>>create user test_user@'%' identified by 'test_user';
Query OK, 0 rows affected (0.00 seC)

使用 localhost 登录

[MysqL@mysqL-test-83 ~]$ /usr/local/MysqL57/bin/MysqL -utest_user -p -hlocalhost
========= 省略 ===========

MysqL> status
/usr/local/MysqL57/bin/MysqL  Ver 14.14 diStrib 5.7.21, for linux-glibc2.12 (x86_64) using  EditLine wrapper

Connection id:        9
Current database:    
Current user:        test_user@localhost
SSL:            Not in use
Current pager:        stdout
Using outfile:        ''
Using delimiter:    ;
Server version:        5.7.21-log MysqL Community Server (GPL)
Protocol version:    10
Connection:        Localhost via UNIX socket
....

使用 IP 登录

[MysqL@mysqL-test-83 ~]$ /usr/local/MysqL57/bin/MysqL -utest_user -p -h127.0.0.1
Enter password: 
========= 省略 ===========

MysqL> status
--------------
/usr/local/MysqL57/bin/MysqL  Ver 14.14 diStrib 5.7.21, for linux-glibc2.12 (x86_64) using  EditLine wrapper

Connection id:        11
Current database:    
Current user:        test_user@127.0.0.1
SSL:            Cipher in use is DHE-RSA-AES256-SHA
Current pager:        stdout
Using outfile:        ''
Using delimiter:    ;
Server version:        5.7.21-log MysqL Community Server (GPL)
Protocol version:    10
Connection:        127.0.0.1 via TCP/IP
Server characterset:    utf8
...

结果显示5.7版本的@H_726_5@mysqL, % 包括localhost

3.3 MysqL 5.6

@R_773_10589@

db83-3306>>SELEct version();
+------------+
| version()  |
+------------+
| 5.6.10-log |
+------------+
1 row in set (0.00 seC)

db83-3306>>create user test_user@'%' identified by 'test_user';
Query OK, 0 rows affected (0.00 seC)

使用 localhost 登录

[MysqL@mysqL-test-83 ~]$ /usr/local/MysqL57/bin/MysqL -utest_user -p -hlocalhost
Enter password: 
ERROR 1045 (28000): Access denied for user 'test_user'@'localhost' (using password: YES)

使用 IP 登录

[MysqL@mysqL-test-83 ~]$ /usr/local/MysqL57/bin/MysqL -utest_user -p -h127.0.0.1
Enter password: 
Welcome to the MysqL monitor.  Commands end with ; or \g.
Your MysqL connection id is 3
Server version: 5.6.10-log MysqL Community Server (GPL)
========= 省略 ===========

MysqL> status
--------------
/usr/local/MysqL57/bin/MysqL  Ver 14.14 diStrib 5.7.21, for linux-glibc2.12 (x86_64) using  EditLine wrapper

Connection id:        3
Current database:    
Current user:        test_user@127.0.0.1
SSL:            Not in use
Current pager:        stdout
Using outfile:        ''
Using delimiter:    ;
Server version:        5.6.10-log MysqL Community Server (GPL)
Protocol version:    10
Connection:        127.0.0.1 via TCP/IP
......
--------------

结果显示@H_726_5@mysqL 5.6的%不包括localhost

3.4 MysqL 5.1

@R_773_10589@

@H_557_37@mysqL> SELEct version(); +-----------+ | version() | +-----------+ | 5.1.73    | +-----------+ 1 row in set (0.00 seC) MysqL> create user test_user@'%' identified by 'test_user'; Query OK, 0 rows affected (0.00 seC)

使用 localhost 登录

[root@chengqm ~]# MysqL -utest_user -p
Enter password: 
ERROR 1045 (28000): Access denied for user 'test_user'@'localhost' (using password: YES)

使用 IP 登录

[root@chengqm ~]# MysqL -utest_user -p -h127.0.0.1
Enter password: 
Welcome to the MysqL monitor.  Commands end with ; or \g.
Your MysqL connection id is 4901339
Server version: 5.1.73 source diStribution
========= 省略 ===========

MysqL> status
--------------
MysqL  Ver 14.14 diStrib 5.1.73, for redhat-linux-gnu (x86_64) using readline 5.1

Connection id:        4901339
Current database:    
Current user:        test_user@127.0.0.1
SSL:            Not in use
Current pager:        stdout
Using outfile:        ''
Using delimiter:    ;
Server version:        5.1.73 source diStribution
Protocol version:    10
Connection:        127.0.0.1 via TCP/IP

结果显示 5.1 版本的%不包括localhost

3.5 MariaDb 10.3

@R_773_10589@

db83-3306>>SELEct version();
+---------------------+
| version()           |
+---------------------+
| 10.3.11-MariaDB-log |
+---------------------+
1 row in set (0.000 seC)

db83-3306>>create user test_user@'%' identified by 'test_user';
Query OK, 0 rows affected (0.001 seC)

使用 localhost 登录

[MysqL@mysqL-test-83 ~]$ /usr/local/mariadb/bin/MysqL -utest_user -p -hlocalhost
Enter password: 
ERROR 1045 (28000): Access denied for user 'test_user'@'localhost' (using password: YES)

使用 IP 登录

[MysqL@mysqL-test-83 ~]$ /usr/local/mariadb/bin/MysqL -utest_user -p -h127.0.0.1
Enter password: 
Welcome to the MariaDB monitor.  Commands end with ; or \g.
Your MariaDB connection id is 12
Server version: 10.3.11-MariaDB-log MariaDB Server
========= 省略 ===========

MariaDB [(nonE)]> status
--------------
/usr/local/mariadb/bin/MysqL  Ver 15.1 diStrib 10.3.11-MariaDB, for Linux (x86_64) using readline 5.1

Connection id:        12
Current database:    
Current user:        test_user@127.0.0.1
SSL:            Not in use
Current pager:        stdout
Using outfile:        ''
Using delimiter:    ;
Server:            MariaDB
Server version:        10.3.11-MariaDB-log MariaDB Server
Protocol version:    10
Connection:        127.0.0.1 via TCP/IP

结果显示@H_726_5@mariaDb 10.3的%不包括localhost

4 结论

@H_806_202@mysqL8.0@H_806_202@mysqL5.7@H_806_202@mysqL5.6@H_806_202@mysqL5.1@H_806_202@mariaDb 10.3
版本用户中的%是否包括localhost
包括
包括
不包括
不包括
不包括

大佬总结

以上是大佬教程为你收集整理的分析MySQL用户中的百分号%是否包含localhost?全部内容,希望文章能够帮你解决分析MySQL用户中的百分号%是否包含localhost?所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。
标签: