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

一家之言:

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


转自:http://hi.baidu.com/mongodb/item/375f01868a74b6ceef083d80

  • 3
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
当 Django 无法连接到本地 MySQL 服务器时,可能是由于以下原因导致的: 1. MySQL 服务器未运行或已停止运行。 2. MySQL 服务器未配置为在 localhost (127.0.0.1) 上运行。 3. MySQL 服务器使用的端口与 Django 设置的端口不同。 4. Django 的数据库设置与 MySQL 服务器的设置不匹配。 解决方法: 1. 确认 MySQL 服务器是否正在运行。您可以通过运行以下命令来检查 MySQL 服务器是否正在运行: ``` sudo service mysql status ``` 如果 MySQL 服务器未运行,则可以通过运行以下命令来启动它: ``` sudo service mysql start ``` 2. 如果 MySQL 服务器未配置为在 localhost (127.0.0.1) 上运行,则可以通过编辑 MySQL 配置文件来更改这一设置。在 Ubuntu 中,MySQL 配置文件位于 /etc/mysql/mysql.conf.d/mysqld.cnf。确保在此文件中设置了以下内容: ``` bind-address = 127.0.0.1 ``` 3. 检查 MySQL 服务器使用的端口是否与 Django 设置的端口不同。默认情况下,MySQL 使用端口 3306。您可以在 Django 的设置文件中指定要使用的端口。确保 MySQL 服务器和 Django 使用的端口相同。 4. 检查 Django 的数据库设置是否正确。在 Django 的设置文件中,确保以下设置与 MySQL 服务器的设置匹配: ``` DATABASES = { 'default': { 'ENGINE': 'django.db.backends.mysql', 'NAME': 'mydatabase', 'USER': 'mydatabaseuser', 'PASSWORD': 'mypassword', 'HOST': '127.0.0.1', 'PORT': '3306', } } ``` 其中,'NAME' 是您的数据库名称,'USER' 和 'PASSWORD' 是用于访问数据库的用户名和密码,'HOST' 是 MySQL 服务器的 IP 地址或主机名,'PORT' 是 MySQL 服务器的端口号。 如果您进行了任何更改,请保存文件并重新启动 Django 服务器以使更改生效。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值