• MySQL用户中的%到底包不包括localhost?


    1 前言

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

    2 两种连接方法

    这里说的两种连接方法指是执行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 不同版本的差别

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

    3.1 MySQL 8.0

    创建用户

    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版本的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版本的MySQL, % 包括localhost

    3.3 MySQL 5.6

    创建用户

    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
    ......
    --------------
    

    结果显示MySQL 5.6%不包括localhost

    3.4 MySQL 5.1

    创建用户

    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

    创建用户

    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
    

    结果显示MariaDB 10.3%不包括localhost

    4 结论

    版本 用户中的%是否包括localhost
    MySQL8.0 包括
    MySQL5.7 包括
    MySQL5.6 不包括
    MySQL5.1 不包括
    MariaDB 10.3 不包括
  • 相关阅读:
    Python中的passed by assignment与.NET中的passing by reference、passing by value
    从系统性能优化谈对象相等性
    .NET Core应用的三种部署方式
    cola-ui的使用
    谁不是一边娶妻生子,一边死在路上。请你好好生活
    MySQL的5种时间类型的比较
    压缩20M文件从30秒到1秒的优化过程
    CentOS 7下MySQL 5.7安装
    CentOS6.5下安装JDK1.7+MYSQL5.5+TOMCAT7+nginx1.7.5环境安装文档
    CentOS下安装FreeTDS
  • 原文地址:https://www.cnblogs.com/sanduzxcvbnm/p/12937982.html
Copyright © 2020-2023  润新知