在Docker中使用MySQL的教程
提及虚拟化技术,我可是linuxContainer(LXC)的热爱者。但随着Docker技术的声名鹊起,我想在这展示一下如何使用带有Docker的Mysql
Docker是什么?
实际上,Docker就是LXC的封装。使用起来很有意思。Docker采用LXC来虚拟化每个应用。所以在接下来的示例中,我们会启动chroot环境中一个被封装在自己命名空间内的mysql实例(你也可以设置Cgroups对应的资源)使用Docker的一个亮点就是统一文件系统(aufs)。所以当启动一个Docker容器后,它会记录其aufs总数并只会更新新写入的数据。
Aufs对于大多数应用来说十分有用,并且也能很好地支持数据库测试。在这我只想做个简单的示例-仅仅抛砖引玉,实用性也许并不高-Dockerfile.Dockerfile是Docker镜像的构建脚本
咱们来看看Dockerfile的内容:
FROMubuntu MAINTAINERerkanyanar<erkan.yanar@linsenraum.de> ENVDEBIAN_FRONTENDnoninteractive RUNapt-getinstall-ypython-software-properties RUNapt-keyadv--recv-keys--keyserverhkp://keyserver.ubuntu.com:800xcbcb082a1bb943db RUNadd-apt-repository'debhttp://mirror2.hs-esslingen.de/mariadb/repo/10.0/ubuntuprecisemain' RUNapt-getupdate RUNapt-getinstall-ymariadb-server RUNecho"[mysqld]">/etc/mysql/conf.d/docker.cnf RUNecho"bind-address=0.0.0.0">>/etc/mysql/conf.d/docker.cnf RUNecho"innodb_flush_method=O_DSYNC">>/etc/mysql/conf.d/docker.cnf RUNecho"skip-name-resolve">>/etc/mysql/conf.d/docker.cnf RUNecho"init_file=/etc/mysql/init">>/etc/mysql/conf.d/docker.cnf RUNecho"GRANTALLON*.*TOsupa@'%'IDENTIFIEDBY'supa';">/etc/mysql/init EXPOSE3306 USERmysql ENTRYPOINTmysqld
你可以按自己的需求更改。明白了大意后,可以进一步优化代码。比如,较少运行步骤:)
运行一下看看(命名为mysql)
>cat$DOCKERFILENAME|dockerbuild-tmysql-
很好!启动51个容器看看:
>timeforiin$(seq1060);dodockerrun-d-p50$i:3306mysql;done .. real0m27.446s user0m0.264s sys0m0.211s
这都是在我笔记本上的结果.如果使用KVM性能会更好:)
>dockerps|grepmysqld|wc-l 51 >dockerps|head-2 CONTAINERIDIMAGECOMMANDCREATEDSTATUSPORTSNAMES 6d3a5181cd56mysql:latest/bin/sh-cmysqldAboutaminuteagoUpAboutaminute0.0.0.0:5060->3306/tcplonely_pare
快来试试吧\o/