连接MySQL操作是连接进程和MySQL数据库实例进行通信。从开发的角度来说,本质上是进程通信。常用的进程通信方式有管道、命名管道、命名字、TCP/IP套接字、Unix域名套接字。MySQL提供的连接方式从本质上看都是上述提及的进程通信方式。

TCP/IP

TCP/IP套接字方式是MySQL在任何平台下都提供的连接方式,也是网络中使用得最多的一种方式。这种方式在TCP/IP连接上建立一个基于网络的连接请求,一般情况下客户端在一台服务器上,而MySQL实例在另一台服务器上,这两台机器通过一个TCP/IP网络连接。

例如,我可以在Windows服务器下请求一台远程Linux服务器下的MySQL实例,mysql -h192.168.0.101 -uroot -p123456;

这里的客户端是Windows,它向一台Host IP为192.168.0.101的MySQL实例发起了TCP/IP连接请求,并且连接成功。之后,就可以对MySQL数据库进行一些数据库操作,如DDL和DML等。

ps:在通过TCP/IP连接到MySQL实例时,MySQL会先检查一张权限视图,用来判断发起请求的客户端IP是否允许连接到MySQL实例。

该视图在mysql库下,表名为user:

use mysql;

select host, user from user;

host代表此用户(root)只能通过localhost的ip访问此数据库。

host:%,表示在任何IP段下连接该实例。host:192.168.24.%,表示在任何192.168.24.段下连接该实例.

命名管道和共享内存

在Windows 2000、Windows XP、Windows 2003和Windows Vista以及在此之后的Windows操作系统中,如果两个需要通信的进程在同一台服务器上,那么可以使用命名管道,SQL Server数据库默认安装后的本地连接也使用命名管道。在MySQL数据库中,需在配置文件中启用--enable-named-pipe选项。在MySQL 4.1之后的版本中,MySQL还提供了共享内存的连接方式,在配置文件中添加--shared-memory。如果想使用共享内存的方式,在连接时,Mysql客户端还必须使用-protocol=memory选项。

Unix域套接字

在Linux和Unix环境下,还可以使用Unix域套接字。Unix域套接字其实不是一个网络协议,所以只能在MySQL客户端和数据库实例在同一台服务器上的情况下使用。你可以在配置文件中指定套接字文件的路径,如-socket=/tmp/mysql.sock。

当数据库实例启动后,我们可以通过下列命令来进行Unix域套接字文件的查找:

show variables like 'socket';--登录实例后查询

mysql -uroot -p123456 -S /tmp/mysql.sock;

最新文章

  1. iOS-证书
  2. CFD冲蚀模拟的一些理论
  3. HTML、CSS、JS对unicode字符的不同处理
  4. wp8.1 VS2013部署手机发生 DEP6100 6200错误
  5. CodeIgniter框架中关于URL(index.php)的那些事
  6. React Native相关
  7. C# 读XML文件
  8. Linux基本命令(开发常用的、电脑常用的)
  9. Ants(思维)
  10. UITabBarController中自定义UITabBar
  11. WebGL自学教程——WebGL演示样本:开始
  12. Windows2008修改密码策略简单介绍
  13. java之Spring(AOP)前奏-动态代理设计模式(下)
  14. Confluence 6 从关闭的连接中恢复
  15. CAS 单点登录4.24版本 登录调用其它系统并且返回客户端用其它的用户信息改造
  16. 设计模式入门——Head First
  17. bzoj 1103
  18. NLP 装桶(Bucketing)和填充(padding)
  19. InputStream转换为String, byte[] data = new byte[1024]详解
  20. Oracle-本地连接没问题,远程连接有问题解决方式

热门文章

  1. MSP430 G2553 Launchpad实现电容测量
  2. PD生成SQL脚本附带注释命令
  3. (zxing.net)一维码ITF的简介、实现与解码
  4. windows 10 RelativePanel
  5. Mysql修改字段类型
  6. ANE-如何加入ane,调试时又不报错
  7. 云捕Redis实战
  8. django系列2--下载安装、项目创建、配置、启动
  9. 【Node】node.js实现服务器的反向代理,解决跨域问题
  10. HDU - 3085 Nightmare Ⅱ