docker環境搭建mysql主從

本文主要研究怎麼在docker上搭建mysql的主從。由於在單機搭建mysql多實例而後再配主從,感受太痛苦了,環境各有不一樣,配置各不大相同,從網上找搭建方法,試了半天也沒成功,最後也沒耐心調試下去了,浪費了好多時間。以爲仍是應該用先進的技術來避免這種時間的浪費,正好docker能夠用上。html

搭好的鏡像

google到tutum搭建好的mysql的docker鏡像,關鍵的是人家也幫你弄好了主從的命令。mysql

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文件所在的文件夾的路徑git

查看鏡像

➜  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

參數解釋:github

  • -d,表示Detached mode,後臺運行sql

  • -t,讓Docker分配一個僞終端(pseudo-tty)並綁定到容器的標準輸入上docker

  • -i,讓容器的標準輸入保持打開,能夠-it配合用,與-d相對應shell

  • -e,表示傳入的環境變量數據庫

  • -p,表示暴露的端口,即本機端口與docker端口映射ubuntu

  • -v,表示掛載文件,這裏掛載了本地的文件夾到docker的文件夾dom

  • --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參數去掉了...

踩過的坑

相關文章
相關標籤/搜索