《MySQL技术内幕:InnoDB存储引擎第2版》——1.5 连接MySQL

    xiaoxiao2021-04-17  214

    1.5 连接MySQL

    本节将介绍连接MySQL数据库的常用方式。需要理解的是,连接MySQL操作是一个连接进程和MySQL数据库实例进行通信。从程序设计的角度来说,本质上是进程通信。如果对进程通信比较了解,可以知道常用的进程通信方式有管道、命名管道、命名字、TCP/IP套接字、UNIX域套接字。MySQL数据库提供的连接方式从本质上看都是上述提及的进程通信方式。1.5.1 TCP/IPTCP/IP套接字方式是MySQL数据库在任何平台下都提供的连接方式,也是网络中使用得最多的一种方式。这种方式在TCP/IP连接上建立一个基于网络的连接请求,一般情况下客户端(client)在一台服务器上,而MySQL实例(server)在另一台服务器上,这两台机器通过一个TCP/IP网络连接。例如用户可以在Windows服务器下请求一台远程Linux服务器下的MySQL实例,如下所示:

    C:\>mysql -h192.168.0.101 -u david -p Enter password: Welcome to the MySQL monitor. Commands end with ; or \g. Your MySQL connection id is 18358 Server version: 5.0.77-log MySQL Community Server (GPL) Type 'help;' or '\h' for help.Type '\c' to clear the current input statement. mysql>

    这里的客户端是Windows,它向一台Host IP为192.168.0.101的MySQL实例发起了TCP/IP连接请求,并且连接成功。之后就可以对MySQL数据库进行一些数据库操作,如DDL和DML等。这里需要注意的是,在通过TCP/IP连接到MySQL实例时,MySQL数据库会先检查一张权限视图,用来判断发起请求的客户端IP是否允许连接到MySQL实例。该视图在mysql架构下,表名为user,如下所示:

    mysql>USE mysql; Database changed mysql>SELECT host,user,password FROM user; *************************** 1. row ***************************** host: 192.168.24.% user: root password: *75DBD4FA548120B54FE693006C41AA9A16DE8FBE **************************** 2. row ***************************** host: nineyou0-43 user: root password: *75DBD4FA548120B54FE693006C41AA9A16DE8FBE **************************** 3. row ***************************** host: 127.0.0.1 user: root password: *75DBD4FA548120B54FE693006C41AA9A16DE8FBE **************************** 4. row ***************************** host: 192.168.0.100 user: zlm password: *DAE0939275CC7CD8E0293812A31735DA9CF0953C **************************** 5. row ***************************** host: % user: david password: 5 rows in set (0.00 sec)

    从这张权限表中可以看到,MySQL允许david这个用户在任何IP段下连接该实例,并且不需要密码。此外,还给出了root用户在各个网段下的访问控制权限。1.5.2 命名管道和共享内存在Windows 2000、Windows XP、Windows 2003和Windows Vista以及在此之上的平台上,如果两个需要进程通信的进程在同一台服务器上,那么可以使用命名管道,Microsoft SQL Server数据库默认安装后的本地连接也是使用命名管道。在MySQL数据库中须在配置文件中启用--enable-named-pipe选项。在MySQL 4.1之后的版本中,MySQL还提供了共享内存的连接方式,这是通过在配置文件中添加--shared-memory实现的。如果想使用共享内存的方式,在连接时,MySQL客户端还必须使用--protocol=memory选项。1.5.3 UNIX域套接字在Linux和UNIX环境下,还可以使用UNIX域套接字。UNIX域套接字其实不是一个网络协议,所以只能在MySQL客户端和数据库实例在一台服务器上的情况下使用。用户可以在配置文件中指定套接字文件的路径,如--socket=/tmp/mysql.sock。当数据库实例启动后,用户可以通过下列命令来进行UNIX域套接字文件的查找:

    mysql>SHOW VARIABLES LIKE 'socket'; *************************** 1. row *************************** Variable_name: socket Value: /tmp/mysql.sock 1 row in set (0.00 sec)

    在知道了UNIX域套接字文件的路径后,就可以使用该方式进行连接了,如下所示:

    [root@stargazer ~]# mysql -udavid -S /tmp/mysql.sock Welcome to the MySQL monitor. Commands end with ; or \g. Your MySQL connection id is 20333 Server version: 5.0.77-log MySQL Community Server (GPL) Type 'help;' or '\h' for help.Type '\c' to clear the buffer. mysql> 相关资源:七夕情人节表白HTML源码(两款)

    最新回复(0)