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