Docker是一種輕量級的虛擬化技術,它可以讓開發人員將應用程序和依賴項打包成一個容器,并在任何地方使用相同的容器運行應用程序。其中,MySQL是使用Docker非常頻繁的一個應用程序之一。本篇文章旨在介紹Docker MySQL Sock的使用方法。
docker pull mysql
docker run --name mysql-murach -e MYSQL_ROOT_PASSWORD=root -d mysql
docker exec -it mysql-murach bash
// 進入容器
mysql -u root -p
// 等待提示,輸入密碼
show databases;
// 查看當前容器中的數據庫
Docker建立在Linux上,并且她使用虛擬化功能實現了用戶空間容器隔離。這就是為什么在Docker鏡像中我們看不到其他容器或架構的原因。而MySQL是一個經典的數據庫,其流程包括三個主要組成部分:client、server 和 socket。
在Docker容器中,client和server都會使用socket進行通訊。這是因為當前的MySQL版本使用了Socket文件協議(Socket file protocol)。UNIX Domain Sockets提供了一種被當做網絡套接字的抽象接口。UNIX Domain Socket 連接也被稱為 IPC(Inter-Process Communication,進程間通信)連接。這種連接是本地連接,與 IP 地址或端口號無關。Linux系統內核直接支持Unix Domain Socket協議,而Docker主機和容器之間的連接也都是本地的。
在Docker容器中使用MySQL Sock非常簡單,如上述代碼所示。我們可以使用run命令構建MySQL容器,然后使用exec命令進入容器進行操作。當我們在容器內使用MySQL的時候,只需要通過unix socket建立通信即可??傮w而言,Docker MySQL Sock的使用方法十分簡單,同時也非常方便。與傳統的MySQL使用方法相比,它讓我們不再需要考慮網絡通訊的負擔,不會再因為網絡環境的復雜性而發生問題。