• mysql localhost与127.0.0.1以及ip连接的区别


    ------------------------原文链接 http://hi.baidu.com/mongodb/item/375f01868a74b6ceef083d80 --------------------

    一家之言:

    localhost与127.0.0.1的区别
    localhost与127.0.0.1的区别是什么?相信有人会说是本地ip,曾有人说,用127.0.0.1比localhost好,可以减少一次解析。看来这个入门问题还有人不清楚,其实这两者是有区别的。

    no1:

    localhost也叫local ,正确的解释是:本地服务器
    127.0.0.1在windows等系统的正确解释是:本机地址(本机服务器)

    no2:

    localhot(local)是不经网卡传输!这点很重要,它不受网络防火墙和网卡相关的的限制。
    127.0.0.1是通过网卡传输,依赖网卡,并受到网络防火墙和网卡相关的限制。

    一般设置程序时本地服务用localhost是最好的,localhost不会解析成ip,也不会占用网卡、网络资源。

    有时候用localhost可以,但用127.0.0.1就不可以的情况就是在于此。猜想localhost访问时,系统带的本机当前用户的权限去访问,而用ip的时候,等于本机是通过网络再去访问本机,可能涉及到网络用户的权限。

    他家之言:

    1. mysql -h 127.0.0.1 的时候,使用TCP/IP连接,
    mysql server 认为该连接来自于127.0.0.1或者是"localhost.localdomain"

    2. mysql -h localhost 的时候,是不使用TCP/IP连接的,而使用Unix socket;
    此时,mysql server则认为该client是来自"localhost"

    3. mysql权限管理中的"localhost"有特定含义:
    —— MySQL手册 5.6.4 ..... A Host value may be a hostname or an IPnumber, or 'localhost' to indicate the local host.

    注意:虽然两者连接方式有区别,但当localhost为默认的127.0.0.1时,两种连接方式使用的权限记录都是以下的1.row的记录(因为记录在前,先被匹配)

    *************************** 1. row***************************
                    Host: localhost
                    User: root
    ......
    ***************************
                    Host: 127.0.0.1
                    User: root

    证明:

    shell> mysql -h 127.0.0.1
    mysql> status;
    Currentuser:          root@127.0.0.1
    SSL:                   Not in use
    Currentpager:         stdout
    Usingoutfile:         ''
    Usingdelimiter:       ;
    Serverversion:        5.1.33-log Source distribution
    Protocolversion:      10
    Connection:          127.0.0.1via TCP/IP

    shell> mysql -h locahost
    mysql> status;
    Currentuser:          root@localhost
    SSL:                   Not in use
    Currentpager:         stdout
    Usingoutfile:         ''
    Usingdelimiter:       ;
    Serverversion:        5.1.33-log Source distribution
    Protocolversion:      10
    Connection:          Localhostvia UNIX socket

    shell> mysql -h XXXX(ip)
    mysql> status;
    Currentuser:          root@ip
    SSL:                   Not in use
    Currentpager:         stdout
    Usingoutfile:         ''
    Usingdelimiter:       ;
    Serverversion:        5.1.33-log Source distribution
    Protocolversion:      10
    Connection:          XXXX(ip)via TCP/IP

  • 相关阅读:
    Sysbench对Mysql进行基准测试
    yum安装软件时报错libmysqlclient.so.18()(64bit)
    redis启动报错Could not connect to Redis at 127.0.0.1:6379: 由于目标计算机积极拒绝,无法连接。
    cmd 中连接mysql时报'mysql'不是内部或外部命令,也不是可运行的程序或批处理文件
    Mysql远程连接权限
    Git基础教程
    电脑adb命令给智能电视安装APK
    python基础之类
    python基础之函数
    前端之CSS第二部分属性相关
  • 原文地址:https://www.cnblogs.com/20120810bubu/p/3154892.html
Copyright © 2020-2023  润新知