《Mysql實例在Docker中使用MySQL的教程》要點:
本文介紹了Mysql實例在Docker中使用MySQL的教程,希望對您有用。如果有疑問,可以聯系我們。
MYSQL實例提及虛擬化技術,我可是linuxContainer(LXC)的熱愛者.但隨著Docker技術的聲名鵲起,我想在這展示一下如何使用帶有Docker的Mysql
MYSQL實例Docker是什么?
MYSQL實例實際上,Docker就是LXC的封裝.使用起來很有意思.Docker采用LXC來虛擬化每個應用.所以在接下來的示例中,我們會啟動chroot環境中一個被封裝在自己命名空間內的mysql實例(你也可以設置Cgroups對應的資源)使用Docker的一個亮點就是統一文件系統(aufs).所以當啟動一個Docker容器后,它會記錄其aufs總數并只會更新新寫入的數據.
MYSQL實例
Aufs對于大多數應用來說十分有用,并且也能很好地支持數據庫測試.在這我只想做個簡單的示例-僅僅拋磚引玉,實用性也許并不高- Dockerfile. Dockerfile是Docker鏡像的構建腳本
MYSQL實例咱們來看看Dockerfile的內容:
?
MYSQL實例
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
MYSQL實例你可以按自己的需求更改.明白了大意后,可以進一步優化代碼.比如,較少運行步驟:)
MYSQL實例運行一下看看 (命名為mysql)
?
MYSQL實例
> cat $DOCKERFILENAME | docker build -t mysql -
MYSQL實例很好!啟動51個容器看看:
?
MYSQL實例
> 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
MYSQL實例這都是在我筆記本上的結果. 如果使用KVM性能會更好 :)
?
MYSQL實例
> 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
MYSQL實例快來試試吧 \o/
轉載請注明本頁網址:
http://www.snjht.com/jiaocheng/5422.html