序
本文主要研究怎么在docker上搭建mysql的主從。因為在單機搭建mysql多實例然后再配主從,感覺太痛苦了,環境各有不同,配置各不大相 同,從網上找搭建方法,試了半天也沒成功,最后也沒耐心調試下去了,浪費了好多時間。覺得還是應該用先進的技術來避免這種時間的浪費,正好docker可 以用上。
搭好的鏡像
google到tutum搭建好的mysql的docker鏡像,關鍵的是人家也幫你弄好了主從的命令。
git clone https://github.com/tutumcloud/mysql.git
根據Dockerfile構建鏡像
docker build -t xixicat/mysql5.6 5.6/
......
Step 6 : ADD import_sql.sh /import_sql.sh
---> 8e105223fa8b Removing intermediate container add786317f4a Step 7 : ADD run.sh /run.sh ---> 6d3e93df4d46 Removing intermediate container 9d959e1f9684 Step 8 : ENV MYSQL_USER admin MYSQL_PASS **Random** ON_CREATE_DB **False** REPLICATION_MASTER **False** REPLICATION_SLAVE **False** REPLICATION_USER replica REPLICATION_PASS replica ON_CREATE_DB **False** ---> Running in 8d4857d7bf16 ---> 1329735e7b3a Removing intermediate container 8d4857d7bf16 Step 9 : VOLUME /etc/mysql /var/lib/mysql ---> Running in 1e654949edf5 ---> 2c88ab58a842 Removing intermediate container 1e654949edf5 Step 10 : EXPOSE 3306 ---> Running in f349784d176a ---> 412c34a688cf Removing intermediate container f349784d176a Step 11 : CMD /run.sh ---> Running in 5d81fa8627e2 ---> ccdd6bddfcf1 Removing intermediate container 5d81fa8627e2 Successfully built ccdd6bddfcf1
其中-t參數為給鏡像貼個標簽"xixicat/mysql",后面的參數為Dockerfile文件所在的文件夾的路徑
查看鏡像
➜ docker-mysql git:(master) ✗ docker images
REPOSITORY TAG IMAGE ID CREATED VIRTUAL SIZE
xixicat/mysql5.6 latest 0dbd5f7ff4c0 About a minute ago 471.8 MB
xixicat/mysql latest ccdd6bddfcf1 3 hours ago 317.8 MB
ubuntu 14.04 c4bea91afef3 13 days ago 187.9 MB
ubuntu trusty c4bea91afef3 13 days ago 187.9 MB
啟動容器
啟動master
docker run -d -e REPLICATION_MASTER=true -e REPLICATION_PASS=admin -e MYSQL_PASS=admin -e MYSQL_USER=admin -p 3307:3307 -v /Users/xixicat/devtool/docker-mysql/5.5/data/master:/var/lib/mysql --name mysql xixicat/mysql5.6
參數解釋:
-
-d,表示Detached mode,后台運行
-
-t,讓Docker分配一個偽終端(pseudo-tty)並綁定到容器的標准輸入上
-
-i,讓容器的標准輸入保持打開,可以-it配合用,與-d相對應
-
-e,表示傳入的環境變量
-
-p,表示暴露的端口,即本機端口與docker端口映射
-
-v,表示掛載文件,這里掛載了本地的文件夾到docker的文件夾
-
--name,表示給容器起的名字,方便查看,若要配置主從,這里需要指定為mysql,我表示已經采坑。
啟動后查看容器:
~ docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
66dbc9aa02d4 xixicat/mysql5.6 "/run.sh" 3 seconds ago Up 2 seconds 3306/tcp, 0.0.0.0:3307->3307/tcp mysql
登陸mysql:
mysql -uadmin -P3307
刪除容器(備用
):
docker ps -a
docker stop masterDb docker rm masterDb
查看啟動logs(啟動不起來時查看
):
docker logs masterDb
啟動slave
docker run -d -e REPLICATION_SLAVE=true -e MYSQL_PASS=admin -e MYSQL_USER=admin -p 3308:3308 -v /Users/xixicat/devtool/docker-mysql/5.6/data/slave:/var/lib/mysql --name slaveDb --link mysql:mysql xixicat/mysql5.6
參數解釋:
-
--link,該參數的格式為--link name:alias,其中name是要鏈接的容器的名稱,alias是這個連接的別名,若要創建主從這里也指定為mysql:mysql,表示已經采坑。
查看容器:
master git:(master) docker ps CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES 04fed79e8787 xixicat/mysql "/run.sh" 3 seconds ago Up 3 seconds 3306/tcp, 0.0.0.0:3308->3308/tcp slaveDb 66dbc9aa02d4 xixicat/mysql "/run.sh" 6 minutes ago Up 27 seconds 3306/tcp, 0.0.0.0:3307->3307/tcp mysql
登陸看看:
mysql -uadmin -P3308
遇到的錯誤
症狀
容器啟動一陣子就自動關閉了,然后去docker logs mysql查看日志,發現錯誤:
160118 15:08:57 mysqld_safe Starting mysqld daemon with databases from /var/lib/mysql
160118 15:08:57 [Warning] Using unique option prefix key_buffer instead of key_buffer_size is deprecated and will be removed in a future release. Please use the full name instead. 160118 15:08:57 [Note] /usr/sbin/mysqld (mysqld 5.5.46-0ubuntu0.14.04.2-log) starting as process 523 ... 160118 15:08:57 [Warning] Setting lower_case_table_names=2 because file system for /var/lib/mysql/ is case insensitive /usr/sbin/mysqld: File './mysql-bin.index' not found (Errcode: 13) 160118 15:08:57 [ERROR] Aborting 160118 15:08:57 [Note] /usr/sbin/mysqld: Shutdown complete 160118 15:08:57 mysqld_safe mysqld from pid file /var/run/mysqld/mysqld.pid ended
重點關注這一行:
/usr/sbin/mysqld: File './mysql-bin.index' not found (Errcode: 13)
解決
可能是文件權限的問題,去查看數據庫根目錄的權限
docker exec -it mysql /bin/sh # ls -l /var/lib/mysql total 0 drwxr-xr-x 1 1000 staff 68 Jan 18 14:23 mysql
參數詳解:
-
第一列:“drwxr-xr-x” 表示文件的類型和文件權限
-
第二列:“1”是純數字 ,表示文件鏈接個數
-
第三列:表示文件的所有者
-
第四列:所屬的組
-
第五列:“68”,表示為文件長度(大小)
-
第六列:“Jan 18 14:23”,表示文件最后更新(修改)時間
-
第七列:“mysql” 表示文件的名稱
但是,這里是掛載本地文件,於是修改掛載的本地文件夾權限
cd /Users/xixicat/devtool/docker-mysql/5.6/data sudo chown -R mysql:mysql *
仍然報錯
2016-01-18 17:26:23 988 [ERROR] InnoDB: ./ibdata1 can't be opened in read-write mode
於是各種嘗試,都沒有成功,還是先把-v參數去掉了...