日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問(wèn)題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營(yíng)銷解決方案
MySQL進(jìn)行Docker容器化之體驗(yàn)與感悟

 原則

成都創(chuàng)新互聯(lián)擁有一支富有激情的企業(yè)網(wǎng)站制作團(tuán)隊(duì),在互聯(lián)網(wǎng)網(wǎng)站建設(shè)行業(yè)深耕十載,專業(yè)且經(jīng)驗(yàn)豐富。十載網(wǎng)站優(yōu)化營(yíng)銷經(jīng)驗(yàn),我們已為上千多家中小企業(yè)提供了做網(wǎng)站、網(wǎng)站建設(shè)解決方案,按需搭建網(wǎng)站,設(shè)計(jì)滿意,售后服務(wù)無(wú)憂。所有客戶皆提供一年免費(fèi)網(wǎng)站維護(hù)!

Docker 的使用原則是所有容器化的應(yīng)用程序都應(yīng)該是無(wú)狀態(tài)的 ,即容器內(nèi)部只跑業(yè)務(wù)邏輯,容器應(yīng)用的所有配置文件、日志文件和持久化數(shù)據(jù) 都應(yīng)該掛載到宿主機(jī)文件系統(tǒng),不應(yīng)該存儲(chǔ)在容器內(nèi)部,以免容器被誤刪或自身出現(xiàn)問(wèn)題導(dǎo)致數(shù)據(jù)丟失。

MySQL 容器化方式

MySQL 屬于有狀態(tài)應(yīng)用,若將其容器化需將其狀態(tài)抽離到宿主機(jī),其配置文件、日志文件和持久化數(shù)據(jù)都應(yīng)該掛載到宿主機(jī)。

容器內(nèi)各路徑

通過(guò)docker pull 命令拉取下來(lái)的官方 MySQL 鏡像內(nèi),有幾個(gè)重要路徑:

  • 配置文件
  • 鏡像內(nèi) MySQL 的配置文件路徑為/etc/mysql ,路徑下包含my.cnf 配置和一個(gè)conf.d 文件夾,my.cnf 文件內(nèi)是一些base setting ,我們自定義的配置應(yīng)該寫在conf.d 文件夾下的配置文件里,從而覆蓋base setting 。conf.d 文件夾下默認(rèn)有兩個(gè)配置文件:docker.cnf 和mysql.cnf ,在后文所講的掛載配置路徑到宿主機(jī)之后,應(yīng)將這兩個(gè)用戶自定義配置文件拷貝到宿主機(jī)配置路徑下。
  • 持久化數(shù)據(jù)
  • 鏡像內(nèi) MySQL 的持久化數(shù)據(jù)均存儲(chǔ)在/var/lib/mysql 下。

命令

 
 
 
  1. $ docker run \ 
  2.  --name db \ 
  3.  -e MYSQL_ROOT_PASSWORD=secret \ 
  4.  -v /path/to/confdir:/etc/mysql/conf.d \ 
  5.  -v /path/to/datadir:/var/lib/mysql \ 
  6.  -d 
  7.  mysql:tag 

參數(shù)解釋

  • --name 容器名稱
  • -e 為新容器設(shè)置環(huán)境變量,容器內(nèi) MySQL 會(huì)以此初始化 root 用戶密碼
  • -v 兩個(gè)-v 參數(shù)分別將容器內(nèi) MySQL 的自定義配置文件目錄和持久化數(shù)據(jù)目錄掛載到宿主機(jī),冒號(hào)前為宿主機(jī)目錄,后為容器內(nèi)目錄
  • -d 后臺(tái)啟動(dòng)容器

小技巧

我們可以在宿主機(jī)專門建立一個(gè)目錄用來(lái)存放容器狀態(tài)數(shù)據(jù),層級(jí)結(jié)構(gòu)為:

 
 
 
  1. docker-container-data 
  2.  | 
  3.  - container1 
  4.  | | 
  5.  | - conf 
  6.  | | 
  7.  | - logs (其下又可以細(xì)分路徑) 
  8.  | | 
  9.  | - data 
  10.  | 
  11.  - container2 
  12.  | 
  13.  - container3 
  14.  | 
  15.  ... 

災(zāi)難措施

將狀態(tài)數(shù)據(jù)掛載宿主機(jī)的好處就是如果容器發(fā)生問(wèn)題,可以啟動(dòng)一個(gè)新容器并將容器狀態(tài)路徑掛載到宿主機(jī)上的原狀態(tài)路徑,從而恢復(fù)生產(chǎn)。

可以直接將新啟動(dòng)的 MySQL 容器的配置和持久化數(shù)據(jù)掛載到之前容器的宿主路徑,新容器便可以無(wú)縫恢復(fù)數(shù)據(jù)(配置、用戶、庫(kù)、表、記錄均恢復(fù))。

注意事項(xiàng)

不可以將兩個(gè)均在運(yùn)行的容器的狀態(tài)路徑掛載到同一個(gè)宿主路徑 ,兩個(gè)容器同時(shí)在一個(gè)宿主路徑下寫狀態(tài),容器應(yīng)用讀取狀態(tài)時(shí)會(huì)無(wú)法識(shí)別,導(dǎo)致崩潰。

若新啟動(dòng)的容器要掛載之前容器的宿主數(shù)據(jù)路徑,則會(huì)忽略-e MYSQL_ROOT_PASSWORD=foo 命令參數(shù)所設(shè)定的 root 用戶密碼環(huán)境變量,因?yàn)閽燧d的數(shù)據(jù)路徑下已經(jīng)包含了 MySQL 用戶信息表,而 root 用戶的密碼之前已經(jīng)被設(shè)定過(guò)了。


當(dāng)前標(biāo)題:MySQL進(jìn)行Docker容器化之體驗(yàn)與感悟
新聞來(lái)源:http://www.5511xx.com/article/djopsge.html