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;

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM