localhost与127.0.0.1区别

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,高可用系列 2核4GB
简介:

BUG描述:linux Tomcat下xxxxx_com@localhost访问数据库访问不了

解决办法:改成:xxxxx_com@127.0.0.1即可。


bug分析:在windows也是用localhost链接的 没有问题。为什么在linux 下就不行了呢?


MySQL主机127.0.0.1与localhost区别:

1、localhost也叫local ,正确的解释是:本地服务器

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

他们的解析通过本机的host文件,windows自动将localhost解析为127.0.0.1


2、localhot(local)是不经网卡传输!这点很重要,它不受网络防火墙和网卡相关的的限制。

127.0.0.1是通过网卡传输,依赖网卡,并受到网络防火墙和网卡相关的限制。

本机IP 也是通过网卡传输的,依赖网卡,并受到网络防火墙和网卡相关的限制。


但是本机IP与127.0.0.1的区别是:

127.0.0.1 只能通过本机访问

本机IP 通过本机访问也能通过外部访问

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

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




发现问题
昨天在帮同事编译安装Linux环境时,遇到一个问题:

WEB服务器是apache,数据库是MySQL。

于是写了一个测试连接数据库的PHP页面:

代码如下 复制代码

$mysql = mysql_connect('localhost','root','');

打开 http://localhost/test.php 测试

提示:Can’t connect to local MySQL server through socket...

检查环境正常
以为是数据库没有启动,于是查看一下进程,MySQL在进程里,重启了一下MySQL.

使用mysql -u root -p 可以进入MySQL操作界面

直接使用/usr/local/php5/bin/php /web/test.php执行可以连上数据库

apache也重启了,一样无效

疑点:为何网页执行失败,命令执行却成功
这下就郁闷了,使用php命令直接执行就成功,通过网页执行就失败。难道是apache导致?网上搜索了大堆资料也没找到解决方案,重新编译安装apache问题依旧。

把localhost改成127.0.0.1成功
把localhost改成127.0.0.1后竟然连接成功了,开始陷入思考困局:localhost失败127.0.0.1却成功?

ping localhost 地址是127.0.0.1没错

打开hosts加入

代码如下 复制代码

127.0.0.1 qttc

使用qttc当主机连接也正常,唯独就不认localhost。

localhost连接方式不同导致
为了了解PHP连接数据库时,主机填写localhost与其它的区别阅读了大量资料,最后得知:

当主机填写为localhost时mysql会采用 unix domain socket连接

当主机填写为127.0.0.1时mysql会采用tcp方式连接

这是linux套接字网络的特性,win平台不会有这个问题

解决方法
在my.cnf的[mysql]区段里添加

代码如下 复制代码

protocol=tcp

保存重启MySQL,问题解决!







      本文转自许琴 51CTO博客,原文链接:http://blog.51cto.com/xuqin/1309451,如需转载请自行联系原作者




相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
2月前
|
网络协议
怎么理解localhost,和127.0.0.1有什么区别
怎么理解localhost,和127.0.0.1有什么区别
|
6月前
|
应用服务中间件 nginx
localhost和127.0.0.1的区别
【4月更文挑战第20天】
359 0
localhost和127.0.0.1的区别
|
6月前
|
安全 关系型数据库 MySQL
解决centos7.0安装mysql后出现access defind for user@'localhost'的错误
在使用yum 安装完mariadb, mariadb-server, mariadb-devel后
86 0
|
6月前
|
网络协议 安全 测试技术
localhost和127.0.0.1的区别是什么
与localhost不同的是,127.0.0.1是一个明确的IP地址,不受本地hosts文件或DNS设置的影响
315 2
|
6月前
|
关系型数据库 MySQL 数据库
连接mysql报Access denied for user 'root'@'localhost'错误的解决办法
连接mysql报Access denied for user 'root'@'localhost'错误的解决办法
664 0
|
6月前
|
应用服务中间件 nginx
Nginx 配置中root和alias的区别分析
Nginx 配置中root和alias的区别分析
176 0
|
6月前
|
安全 网络安全 数据库
localhost知识
localhost知识
424 0
|
Java 关系型数据库 MySQL
jdbc:mysql://localhost:3306/test是什么?jdbc代表什么?
jdbc:mysql://localhost:3306/test是什么?jdbc代表什么?
341 0
|
网络协议 关系型数据库 MySQL
bind-address如果是127.0.0.1,mysql只接受localhost,不接受远程连接。
bind-address如果是127.0.0.1,mysql只接受localhost,不接受远程连接。
231 0
|
应用服务中间件
关于 localhost 和网络的理解
关于 localhost 和网络的理解
关于 localhost 和网络的理解