zoukankan      html  css  js  c++  java
  • MySQL的连接方式

    连接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;

  • 相关阅读:
    有用的博客
    高效处理字符串!——AC自动机
    从此开始的博客之旅!!
    Luogu3796 【模板】AC自动机(加强版)
    两个球相交部分体积计算
    C#使用DirectoryEntry操作IIS创建网站和虚拟路径
    C#管理IIS中的站点
    execlp函数使用
    Linux进程控制——exec函数族
    javascript操作json总结
  • 原文地址:https://www.cnblogs.com/wade-luffy/p/6274895.html
Copyright © 2011-2022 走看看