localhost与127.0.0.1区别
一、连接MySQL数据库有两种方式:TCP/IP(一般理解的端口的那种)和Unix套接字(一般叫socket或者sock)
大部分情况下,可以用localhost代表本机127.0.0.,但是在MySQL连接时,二者不可混用,而且MySQL中权限设置中localhost与127.0.0.1也是分开设置的。
、mysql -h 127.0.0.1 的时候,使用 TCP/IP 连接, mysql server 认为该连接来自于127.0.0.1或者是"localhost.localdomain",系统通过TCP/IP方式连接数据库,127.0..1是通过网卡传输,依赖网卡,并受到网络防火墙和网卡相关的限制。
、mysql -h localhost 的时候,不使用TCP/IP 连接的,而使用 Unix socket连接 ,此时,mysql server则认为该client是来自"localhost",系统通过socket方式连接数据库,localhot(local)是不经网卡传输!这点很重要,它不受网络防火墙和网卡相关的的限制。
二、总结:
一般设置程序时本地服务用localhost是最好的,localhost不会解析成ip,也不会占用网卡、网络资源。而且通过socket连接时,socket文件可以在my.cnf配置文件中进行配置,参考如下:
[mysqld]
socket = /home/cdrom/work/mysql_3307/tmp/mysql.sock
其中/home/cdrom/work/mysql_3307/tmp路径必须真实存在,
默认是使用的sock的方式连接的,当没有指定sock文件的情况下,而默认的sock文件是从/tmp/mysql.sock路径下找的。
#######################################
三、单机多实例部署mysql后,通过socket登陆时,需要注意:
如果你想在本地通过“mysql -PYYY -uroot -pZZZ”来登陆mysql服务,那么你只能登陆其中的一个实例。
这是我在部署单机多实例遇到的问题,本想直接在本地通过端口来分别连接到不同实例上,结果连接到的实例都是同一个实例,你说气不气。于是想通过指定-h127.0.0.1来通过tcp/ip来连接数据库,然而可气的是,刚刚初始化的数据库根本就没有'root'@'127.0.0.1'这个用户,
只有'root'@'localhost'这个用户,以及'sys'@'localhost'用户。此时,我已经万念俱灰了,不得不用socket进行免密码登陆实例上去修改'root'@'localhost'这个用户密码,修改之后去掉skip-grant-tables参数,重启服务,
然后用'root'@'localhost'这个用户登陆上去创建其他用户,比如:'root'@'127.0.0.1'
此时登陆本地mysql服务,最佳方式就是通过指定socket文件来登陆,此时不需要指定port,这是多此一举的行为,即便指定端口号,也会被忽略,在未指定主机地址的情况下,也即-h参数,是会忽略端口号的参数值。通过指定socket文件来访问就能区别出哪一个实例了。
、如果在本地也即服务器端连接至MySQL实例的时候,未指定主机地址的情况下,默认是以sock的方式连接的,而未指定sock的时候,又是按照默认的路径找对应的sock文件此时会忽略连接命令中的端口号参数,不注意的情况下可能会造成一些凌乱。
、如果是从客户端(非服务器端)连接的话,肯定会指定IP,一旦指定了IP,对应的端口号就生效了,因此客户端不会发生类似情况。
# mysql -uroot --socket=/home/cdrom/work/mysql_3307/tmp/mysql.sock
localhost与127.0.0.1区别的更多相关文章
- MySQL主机127.0.0.1与localhost区别总结
1. mysql -h 127.0.0.1 的时候,使用TCP/IP连接, mysql server 认为该连接来自于127.0.0.1或者是"localhost.localdomain&q ...
- MySQL 127.0.0.1和localhost本质区别
登录方式: [root@10-4-14-168 ~]# mysql -uroot -p Enter password: 查看权限表 mysql> SELECT user,host,passwor ...
- 127.0.0.1与localhost与ip的区别
127.0.0.1与localhost与ip的区别 May 18, 2014 localhost 不联网不使用网卡,不受防火墙和网卡限制本机访问 一般使用 本地套接字文件AF_UNIX 应用程序一般约 ...
- localhost简介、localhost与 127.0.0.1 及 本机IP 的区别
localhost是什么意思? 相信有人会说是本地ip,曾有人说,用127.0.0.1比localhost好,可以减少一次解析. 看来这个入门问题还有人不清楚,其实这两者是有区别的. localhos ...
- 【转自知乎】:localhost、127.0.0.1 和 本机IP 三者的区别?
作者:知乎用户链接:https://www.zhihu.com/question/23940717/answer/26230963来源:知乎著作权归作者所有.商业转载请联系作者获得授权,非商业转载请注 ...
- localhost和127.0.0.1及ip区别
1.127.0.0.1是回送地址,指本地机,一般用来测试使用.回送地址是本机回送地址(Loopback Address),即主机IP堆栈内部的IP地址,主要用于网络软件测试以及本地机进程间通信,无论什 ...
- localhost,127.0.0.1 和 本机IP 三者的区别
localhost.127.0.0.1和本机IP的区别如下: 1.首先 localhost 是一个域名,在过去它指向 127.0.0.1 这个IP地址.在操作系统支持 ipv6 后,它同时还指向ipv ...
- [ASP.NET]关于DOT NET的IIS配置LocalHost访问和127.0.0.1访问的区别
项目上遇到一个问题跟大家分享下,配置的localhost地址本地无法访问接口,外网却可以访问,查其原因百度资料比较全面的解释 localhost与127.0.0.1的概念和工作原理之不同 要比较两个东 ...
- localhost/127.0.0.1/本机IP的区别以及端口号
端口号: http请求默认的端口是:80 PHPstudy中的端口号: Apache服务器的端口是:80 MySQL数据库的端口是:3306 PHP项目端口是:9000 禅道中的端口号: Apache ...
- localhost与127.0.0.1的区别 2
localhost与127.0.0.1的区别localhost与127.0.0.1的区别是什么?相信有人会说是本地ip,曾有人说,用127.0.0.1比localhost好,可以减少一次解析.看来这个 ...
随机推荐
- servlet和servlet-mapping的作用
转载:https://www.jianshu.com/p/6dadc489969a 某个工程的 web.xml 文件片段: 执行顺序 访问顺序为1—>2—>3—>4,其中2和3的 ...
- KEIL, MDK 关于C99结构体变量初始化
C99:here 例如声明了这样的结构体 void test1() { tt_t t1 ={ .a = , .d = 'd', .b = , .c = }; static tt_t t2 = { ,, ...
- maven-dependencyManagement和dependencies区别
在多模块的maven项目中,如果各个子项目的依赖包相同但版本不同的话,对于测试.发布和管理非常困难 dependencyManagement就是起统一版本作用的一个标签,好处有2,一是统一版本,二是子 ...
- HTML和CSS标签命名规则
1.Images 存放一些网站常用的图片: 2.Css 存放一些CSS文件: 3.Flash 存放一些Flash文件: 4.PSD 存放一些PSD源文件: 5.Temp 存放所有临时图片和其它文件: ...
- python脚本往redis加数据
#-*-coding:utf-8-*-from rediscluster import StrictRedisClusterimport pymysqlimport timeimport cProfi ...
- cms系统视频分享
cms_001-CMS系统功能需求简介-1.avicms_002-如何采用用例分析方法来理解需求-1.avicms_003-后台管理系统用例-1.avicms_004-实现验证码的初步思路-1.avi ...
- C 语言源代码说明
void bdmain(void){/* 禁止 Cache 和 MMU */ cache_disable(); mmu_disable(); /* 端口初始化 */ port_init(); /* 中 ...
- java 多项式
/****************************************************************************** * Compilation: javac ...
- js添加节点
<!DOCTYPE html><html><body><script>var message=document.createTextNode(" ...
- Java Queue队列
前言 Queue队列是一种特殊的线性表,它只允许在表的前端进行删除操作,而在表的后端进行插入操作,LinkedList类实现了Queue接口,因此我们可以把LinkedList当成Queue来用. ...