在Docker中使用MySQL的教程
提及虛擬化技術(shù),我可是linuxContainer(LXC)的熱愛者。但隨著Docker技術(shù)的聲名鵲起,我想在這展示一下如何使用帶有Docker的Mysql
Docker是什么?
實(shí)際上,Docker就是LXC的封裝。使用起來很有意思。Docker采用LXC來虛擬化每個(gè)應(yīng)用。所以在接下來的示例中,我們會(huì)啟動(dòng)chroot環(huán)境中一個(gè)被封裝在自己命名空間內(nèi)的mysql實(shí)例(你也可以設(shè)置Cgroups對(duì)應(yīng)的資源)使用Docker的一個(gè)亮點(diǎn)就是統(tǒng)一文件系統(tǒng)(aufs)。所以當(dāng)啟動(dòng)一個(gè)Docker容器后,它會(huì)記錄其aufs總數(shù)并只會(huì)更新新寫入的數(shù)據(jù)。
Aufs對(duì)于大多數(shù)應(yīng)用來說十分有用,并且也能很好地支持?jǐn)?shù)據(jù)庫測試。在這我只想做個(gè)簡單的示例-僅僅拋磚引玉,實(shí)用性也許并不高- Dockerfile. Dockerfile是Docker鏡像的構(gòu)建腳本
咱們來看看Dockerfile的內(nèi)容:
FROM ubuntu MAINTAINER erkan yanar <erkan.yanar@linsenraum.de> ENV DEBIAN_FRONTEND noninteractive RUN apt-get install -y python-software-properties RUN apt-key adv --recv-keys --keyserver hkp://keyserver.ubuntu.com:80 0xcbcb082a1bb943db RUN add-apt-repository 'deb http://mirror2.hs-esslingen.de/mariadb/repo/10.0/ubuntu precise main' RUN apt-get update RUN apt-get install -y mariadb-server RUN echo "[mysqld]" >/etc/mysql/conf.d/docker.cnf RUN echo "bind-address = 0.0.0.0" >>/etc/mysql/conf.d/docker.cnf RUN echo "innodb_flush_method = O_DSYNC" >>/etc/mysql/conf.d/docker.cnf RUN echo "skip-name-resolve" >>/etc/mysql/conf.d/docker.cnf RUN echo "init_file = /etc/mysql/init" >>/etc/mysql/conf.d/docker.cnf RUN echo "GRANT ALL ON *.* TO supa@'%' IDENTIFIED BY 'supa';" >/etc/mysql/init EXPOSE 3306 USER mysql ENTRYPOINT mysqld
你可以按自己的需求更改。明白了大意后,可以進(jìn)一步優(yōu)化代碼。比如,較少運(yùn)行步驟:)
運(yùn)行一下看看 (命名為mysql)
> cat $DOCKERFILENAME | docker build -t mysql -
很好!啟動(dòng)51個(gè)容器看看:
> time for i in $(seq 10 60 ) ; do docker run -d -p 50$i:3306 mysql ; done .. real 0m27.446s user 0m0.264s sys 0m0.211s
這都是在我筆記本上的結(jié)果. 如果使用KVM性能會(huì)更好 :)
> docker ps | grep mysqld |wc -l 51 > docker ps | head -2 CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES 6d3a5181cd56 mysql:latest /bin/sh -c mysqld About a minute ago Up About a minute 0.0.0.0:5060->3306/tcp lonely_pare
快來試試吧 \o/
相關(guān)文章
MySQL不用like+%實(shí)現(xiàn)模糊查詢
本文主要介紹了MySQL不用like+%實(shí)現(xiàn)模糊查詢,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-01-01
基于mysql時(shí)間處理函數(shù)的應(yīng)用詳解
本篇文章是對(duì)mysql時(shí)間處理函數(shù)進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-06-06
淺談選擇mysql存儲(chǔ)引擎的標(biāo)準(zhǔn)
本文介紹了如何選擇mysql存儲(chǔ)引擎,從存儲(chǔ)引擎的介紹、幾個(gè)常用引擎的特點(diǎn)三個(gè)方面進(jìn)行講解,感興趣的小伙伴們可以參考一下2015-07-07
Mysql數(shù)據(jù)庫綠色版安裝教程 解決系統(tǒng)錯(cuò)誤1067的方法
這篇文章主要為大家詳細(xì)介紹了MySql數(shù)據(jù)庫綠色版安裝教程,以及系統(tǒng)錯(cuò)誤1067的解決方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-08-08
MySql安裝與配置方法(MySQL添加用戶、刪除用戶與授權(quán))
這篇文章主要介紹了MySql安裝與配置方法(MySQL添加用戶、刪除用戶與授權(quán))的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2016-08-08

