成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

docker環(huán)境搭建mysql主從

OpenDigg / 739人閱讀

摘要:序本文主要研究怎么在上搭建的主從。覺得還是應(yīng)該用先進(jìn)的技術(shù)來避免這種時(shí)間的浪費(fèi),正好可以用上。搭好的鏡像到搭建好的的鏡像,關(guān)鍵的是人家也幫你弄好了主從的命令。

本文主要研究怎么在docker上搭建mysql的主從。因?yàn)樵趩螜C(jī)搭建mysql多實(shí)例然后再配主從,感覺太痛苦了,環(huán)境各有不同,配置各不大相同,從網(wǎng)上找搭建方法,試了半天也沒成功,最后也沒耐心調(diào)試下去了,浪費(fèi)了好多時(shí)間。覺得還是應(yīng)該用先進(jìn)的技術(shù)來避免這種時(shí)間的浪費(fèi),正好docker可以用上。

搭好的鏡像

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

git clone https://github.com/tutumcloud/mysql.git
根據(jù)Dockerfile構(gòu)建鏡像
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參數(shù)為給鏡像貼個(gè)標(biāo)簽"xixicat/mysql",后面的參數(shù)為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
啟動(dòng)容器 啟動(dòng)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

參數(shù)解釋:

-d,表示Detached mode,后臺(tái)運(yùn)行

-t,讓Docker分配一個(gè)偽終端(pseudo-tty)并綁定到容器的標(biāo)準(zhǔn)輸入上

-i,讓容器的標(biāo)準(zhǔn)輸入保持打開,可以-it配合用,與-d相對(duì)應(yīng)

-e,表示傳入的環(huán)境變量

-p,表示暴露的端口,即本機(jī)端口與docker端口映射

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

--name,表示給容器起的名字,方便查看,若要配置主從,這里需要指定為mysql,我表示已經(jīng)采坑。

啟動(dòng)后查看容器:

~  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

查看啟動(dòng)logs(啟動(dòng)不起來時(shí)查看):

docker logs masterDb
啟動(dòng)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

參數(shù)解釋:

--link,該參數(shù)的格式為--link name:alias,其中name是要鏈接的容器的名稱,alias是這個(gè)連接的別名,若要?jiǎng)?chuàng)建主從這里也指定為mysql:mysql,表示已經(jīng)采坑。

查看容器:

 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
遇到的錯(cuò)誤 癥狀

容器啟動(dòng)一陣子就自動(dòng)關(guān)閉了,然后去docker logs mysql查看日志,發(fā)現(xiàn)錯(cuò)誤:

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

重點(diǎn)關(guān)注這一行:

/usr/sbin/mysqld: File "./mysql-bin.index" not found (Errcode: 13)
解決

可能是文件權(quán)限的問題,去查看數(shù)據(jù)庫根目錄的權(quán)限

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

參數(shù)詳解:

第一列:“drwxr-xr-x” 表示文件的類型和文件權(quán)限

第二列:“1”是純數(shù)字 ,表示文件鏈接個(gè)數(shù)

第三列:表示文件的所有者

第四列:所屬的組

第五列:“68”,表示為文件長度(大小)

第六列:“Jan 18 14:23”,表示文件最后更新(修改)時(shí)間

第七列:“mysql” 表示文件的名稱

但是,這里是掛載本地文件,于是修改掛載的本地文件夾權(quán)限

cd /Users/xixicat/devtool/docker-mysql/5.6/data
sudo chown -R mysql:mysql *

仍然報(bào)錯(cuò)

2016-01-18 17:26:23 988 [ERROR] InnoDB: ./ibdata1 can"t be opened in read-write mode

于是各種嘗試,都沒有成功,還是先把-v參數(shù)去掉了...

踩過的坑

Show_view_priv修改error

本地文件權(quán)限

MySQL 服務(wù)無法啟動(dòng) 1067錯(cuò)誤

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/26516.html

相關(guān)文章

  • (全棧學(xué)習(xí)實(shí)踐)四、docker搭建mysql主從實(shí)踐

    摘要:上需要主從服務(wù)器端配合完成初始化同步用戶主服務(wù)器端手動(dòng)同步初始數(shù)據(jù)添加測(cè)試數(shù)據(jù),適合從一臺(tái)拓展至多臺(tái)服務(wù)器的情況。 目前已完成:php7及擴(kuò)展、redis5的Dockerfile測(cè)試版編寫,稍許完善后同步上傳到github,(記下這里memcached還沒有剝離安裝)。今天數(shù)據(jù)庫,編程的一個(gè)重要原則是不要重復(fù)造輪子,php因?yàn)樾枰芏嘧远x插件、所以單獨(dú)編譯鏡像,其實(shí)其他包括redis...

    instein 評(píng)論0 收藏0
  • Dockerfile 與 Compose 環(huán)境搭建學(xué)習(xí)筆記(一)

    摘要:的主要作用是自己根據(jù)基礎(chǔ)鏡像,重新定制鏡像,而不是直接從官方倉庫拿現(xiàn)成的使用。以接下來要構(gòu)建的環(huán)境來說明下,下面我將要搭建一個(gè)的開發(fā)環(huán)境,需要進(jìn)行配合。它的主要作用是持久化數(shù)據(jù),避免容器銷毀后內(nèi)部數(shù)據(jù)丟失暴露到宿主機(jī)的端口。 以前一直使用 Vagrant 作為自己的開發(fā)環(huán)境,并且在上家公司也推行大家采用 Vagrant 作為開發(fā)環(huán)境,保障公司使用的是同一套開發(fā)環(huán)境。隨著docker的流...

    TZLLOG 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<