程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> MYSQL數據庫 >> MySQL綜合教程 >> 在Docker中應用MySQL的教程

在Docker中應用MySQL的教程

編輯:MySQL綜合教程

在Docker中應用MySQL的教程。本站提示廣大學習愛好者:(在Docker中應用MySQL的教程)文章只能為提供參考,不一定能成為您想要的結果。以下是在Docker中應用MySQL的教程正文


說起虛擬化技巧,我可是linuxContainer(LXC)的酷愛者。但跟著Docker技巧的申明鵲起,我想在這展現一下若何應用帶有Docker的Mysql

Docker是甚麼?

現實上,Docker就是LXC的封裝。應用起來很成心思。Docker采取LXC來虛擬化每一個運用。所以在接上去的示例中,我們會啟動chroot情況中一個被封裝在本身定名空間內的mysql實例(你也能夠設置Cgroups對應的資本)應用Docker的一個亮點就是同一文件體系(aufs)。所以當啟動一個Docker容器後,它會記載其aufs總數並只會更新新寫入的數據。


Aufs關於年夜多半運用來講非常有效,而且也能很好地支撐數據庫測試。在這我只想做個簡略的示例-僅僅拋磚引玉,適用性或許其實不高- Dockerfile. Dockerfile是Docker鏡像的構建劇本

我們來看看Dockerfile的內容:
 

FROM ubuntu
MAINTAINER erkan yanar <[email protected]>
 
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)
 

> cat $DOCKERFILENAME | docker build -t mysql -

很好!啟動51個容器看看:
 

> 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

這都是在我筆記本上的成果. 假如應用KVM機能會更好 :)
 

> 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/

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved